パーティーの後半、これが私の答えです、
これは、親テーマでを変更するつもりはないcolorAccent
が、EditText
属性を変更したい人向けです。
この回答は、変更方法のデモです......
- ボトムラインの色
- カーソルの色
- カーソルポインターの色(カスタムイメージを使用しました).........
EditText
アクティビティテーマに適用されるスタイルの使用。
<android.support.v7.widget.AppCompatEditText
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:text="Hey" />
例:
<style name="AppTheme.EditText" parent="@style/Widget.AppCompat.EditText">
<item name="android:textColor">@color/white</item>
<item name="android:textColorHint">#8AFFFFFF</item>
<item name="android:background">@drawable/edit_text_background</item> // background (bottom line at this case)
<item name="android:textCursorDrawable">@color/white</item> // Cursor
<item name="android:textSelectHandle">@drawable/my_white_icon</item> // For pointer normal state and copy text state
<item name="android:textSelectHandleLeft">@drawable/my_white_icon</item>
<item name="android:textSelectHandleRight">@drawable/my_white_icon</item>
</style>
次に、drawable(edit_text_background
)を作成し、背景にリソースxmlを追加します!必要に応じてカスタマイズできます!
<?xml version="1.0" encoding="utf-8"?>
<layer-list xmlns:android="http://schemas.android.com/apk/res/android">
<item
android:bottom="0dp"
android:left="-3dp"
android:right="-3dp"
android:top="-3dp">
<shape android:shape="rectangle">
<stroke
android:width="1dp"
android:color="@color/white"/>
</shape>
</item>
</layer-list>
これで、アクティビティテーマでこのスタイルを設定しました。
例:
アクティビティにeditText
テーマがあります。このカスタムテーマをそれに設定します。
<style name="AppTheme" parent="Theme.AppCompat.Light.DarkActionBar">
<!-- Your Theme data -->
<item name="editTextStyle">@style/AppTheme.EditText</item> // inculude this
</style>