Wie Stil die EditText-widget in einem TextInputLayout
Haben gerade erst begonnen styling und theming app.
Ich habe viele EditText
s in TextInputLayout
s in einem AppCompatActivity
.
Meine Fragen sind:
- Nicht sicher, was die Linie (die Blaue Linie oben), die
EditText
widget aufgerufen wird, nur bezieht es als 'Herrscher'. Wie kann der Herrscher (unsichtbar oben), sichtbar gemacht werden, und in jeder beliebigen benutzerdefinierten Farbe. Derzeit liegt das Lineal zeigt nur auf die Erschließung derEditText
. - Die
EditText
cursor nicht zeigen, wie kann es sichtbar gemacht werden? - Wie kann die Schaltfläche "Hinzufügen" oben angepasst werden, in Bezug auf seinen hintergrund Farbe und text Farbe?
- Wie kann der Fokus auf das erste
EditText
zunächst? - Wie kann die
TextInputLayout
's Tipp Farbe geändert werden, nachdem es schrumpft und fliegt nach oben? (Derzeit blau.) - Ist die Standard-Android-schriftart
Roboto
? Wie kann ich die schriftart ändern, um alles, was verfügbar ist da draußen, 'real quick'?
Sehr zu schätzen jede Hilfe oder Hinweise.
Entsprechenden code-Fragmente:
Layout
Datei
<TextView
android:id="@+id/pocLabel"
style="@style/DialogLabelColor"
android:text="Business Owner"/>
<android.support.design.widget.TextInputLayout
android:id="@+id/tilPOCFName"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_below="@+id/pocLabel">
<android.support.v7.widget.AppCompatEditText
android:id="@+id/POCFName"
style="@style/InputDialogText"
android:hint="First name (REQUIRED)"
android:inputType="textCapWords"/>
</android.support.design.widget.TextInputLayout>
<android.support.design.widget.TextInputLayout
android:id="@+id/tilPOCLName"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_below="@+id/tilPOCFName"
android:textColor="#000000">
<EditText
android:id="@+id/POCLName"
style="@style/InputDialogText"
android:hint="Last name"
android:inputType="textCapWords"/>
</android.support.design.widget.TextInputLayout>
styles.xml
<!--
Base application theme, dependent on API level. This theme is replaced
by AppBaseTheme from res/values-vXX/styles.xml on newer devices.
-->
<style name="AppBaseTheme" parent="android:Theme.Light">
<!--
Theme customizations available in newer API levels can go in
res/values-vXX/styles.xml, while customizations related to
backward-compatibility can go here
-->
</style>
<style name="activated" parent="AppBaseTheme"></style>
<!-- Application theme -->
<style name="MyThemeNavy" parent="Theme.AppCompat.NoActionBar">
<!-- All customizations that are NOT specific to a particular API-level can go here. -->
<item name="windowActionBar">false</item>
<item name="android:windowActionBar">false</item>
<item name="android:colorPrimary">@color/primaryColor</item>
<item name="android:colorPrimaryDark">@color/primaryColorDark</item>
<item name="android:colorAccent">@color/accentColor</item>
<item name="android:textColor">@color/main_list_text_color</item>
<item name="android:textColorHint">@color/main_list_text_color</item>
<item name="drawerArrowStyle">@style/Widget.AppCompat.DrawerArrowToggle</item>
</style>
<style name="Base.Widget.AppCompat.DrawerArrowToggle." parent="Base.Widget.AppCompat.DrawerArrowToggle">
<item name="spinBars">true</item>
<item name="color">#FFF</item>
</style>
<style name="InfoDlgTextLHS" parent="AppBaseTheme">
<item name="android:layout_width">match_parent</item>
<item name="android:layout_height">wrap_content</item>
<item name="android:textAppearance">?android:attr/textAppearanceSmall</item>
<item name="android:textStyle">normal</item>
<item name="android:textColor">@color/main_list_text_color</item>
</style>
<style name="InputDialogText" parent="MyThemeNavy">
<item name="android:layout_width">match_parent</item>
<item name="android:layout_height">wrap_content</item>
<item name="android:textAppearance">?android:attr/textAppearanceMedium</item>
<item name="android:textStyle">normal</item>
<item name="android:textColor">@color/main_list_text_color</item>
</style>
<style name="InfoDlgTextRHS" parent="AppBaseTheme">
<item name="android:layout_width">match_parent</item>
<item name="android:layout_height">wrap_content</item>
<item name="android:textAppearance">?android:attr/textAppearanceSmall</item>
<item name="android:textStyle">bold</item>
<item name="android:textColor">@color/main_list_text_color</item>
</style>
<style name="DialogLabelColor" parent="MyThemeNavy">
<item name="android:layout_width">wrap_content</item>
<item name="android:layout_height">wrap_content</item>
<item name="android:layout_margin">4dp</item>
<item name="android:padding">10dp</item>
<item name="android:background">@drawable/dialog_label_background</item>
<item name="android:textColor">@color/main_list_text_color_inverse</item>
<item name="android:textStyle">bold</item>
</style>
<style name="MyThemeNavy.Dialogs" parent="MyThemeNavy">
<item name="android:textColor">@color/main_list_text_color</item>
<item name="android:textColorHint">@color/main_list_text_color</item>
</style>
</resources>
colors.xml
<?xml version="1.0" encoding="utf-8"?>
<resources>
<color name="primaryColor">#006989</color>
<color name="primaryColorDark">#FFFFFF</color>
<color name="accentColor">#FFFFFF</color>
<color name="colorBackground">#B1C1C0</color>
<!-- Drawer -->
<color name="mainDrawerBackground">#564639</color>
<!-- Main (non-drawer) lists -->
<color name="commonMainListsBackground">#FFFFFF</color>
<color name="main_list_text_color">#000000</color>
<color name="list_item_pressed_color">#CADAFF</color>
<color name="list_item_color">#FFFFFF</color>
<color name="drawer_list_item_pressed_color">#E4FDE1</color>
<color name="drawer_list_item_color">@color/mainDrawerBackground</color>
<color name="divider_color">#DFF8EB</color>
<!-- Counters -->
<color name="distance_counter_color">#FE5F55</color>
<color name="deals_counter_color">#388659</color>
<!-- Information dialog -->
<color name="info_content_color">#FFFFFF</color>
<color name="primary_material_dark">#9e9e9e</color>
<color name="primary_dark_material_dark">#cad7ff</color>
<color name="accent_material_dark">#3469ff</color>
<color name="background_material_dark">#344055</color>
<color name="foreground_material_dark">#ffffff</color>
<color name="colorPrimaryDark">#044389</color>
<!-- Input dialogs -->
<color name="input_dialog_backgroud">#6DAEDB</color>
<color name="main_list_text_color_inverse">#FFFFFF</color>
AndroidManifest.xml
<activity
android:name=".xxx.xxxCRUActivity"
android:label="@string/title_activity_add"
android:theme="@style/MyThemeNavy.Dialogs">
<intent-filter>
<action android:name="android.intent.action.VIEW"/>
<category android:name="android.intent.category.DEFAULT"/>
</intent-filter>
</activity>
Danke!
- WENN Sie ändern möchten, Hiint Farbe des text-Eingabe-layout-ändern Sie die Farbe der colorAccent in color.xml Datei.
- Posten Sie Ihre Ihre vollständigen style.xml, color.xml und layoutfile hier.
- Danke @ChiragSavsani. Veröffentlicht die komplette
colors
undstyles
XML. Meine layout-Datei ist viel zu groß für diesen Beitrag.
Du musst angemeldet sein, um einen Kommentar abzugeben.
Bezüglich Ihrer
TextInputLayout
erstellen Sie einen Stil für SieDies gibt Ihnen eine gewisse Flexibilität für das styling der
AppCompatEditText
. Vergessen Sie nicht, fügen Sie den Stil auf dieTextInputLayout
.Caused by: java.lang.UnsupportedOperationException: Can't convert to color: type=0x2 at android.content.res.TypedArray.getColor(TypedArray.java:327)
Nicht sicher, warum. Meine Tätigkeit, die in der Manifest-Datei, wird mit einem benutzerdefinierten theme (code oben). Ist dieser Fehler denn das?EditText
stattAppCompatEditText
.colorControl
Attribute tun, obwohl. Sind Sie für die Herrscher?<item name="android:textCursorDrawable">@null</item>
Funktioniert!