Ste*_*sen 11 android styles android-edittext material-design android-textinputlayout
我有我的AppTheme定义style.xml,我全局应用自定义样式为我所有的应用程序的TextView,EditText,Button等.
现在我想做同样的android.support.design.widget.TextInputEditText但是如何做?
它没有扩展,EditText因此忽略了样式.
这是我得到的:
<?xml version="1.0" encoding="utf-8"?>
<resources>
<style name="AppTheme" parent="@style/Theme.AppCompat.Light.NoActionBar">
<item name="colorPrimary">@color/primary</item>
<item name="colorPrimaryDark">@color/primary</item>
<item name="colorAccent">@color/accent</item>
<!-- Globally override default widget styles with custom -->
<item name="android:textViewStyle">@style/App.TextView</item>
<item name="android:editTextStyle">@style/App.EditText</item>
<item name="android:buttonStyle">@style/App.Button.Primary</item>
</style>
<style name="App.TextView" parent="@android:style/Widget.TextView">
<item name="android:textColor">@color/text</item>
<item name="android:fontFamily">sans-serif-light</item>
<item name="android:textSize">@dimen/textsize_normal</item>
</style>
<style name="App.EditText" parent="@android:style/Widget.EditText">
<item name="android:textColor">#f00</item>
<item name="android:fontFamily">sans-serif-light</item>
<item name="android:textSize">@dimen/textsize_xxxlarge</item>
<item name="android:textStyle">bold</item>
<item name="android:textColorHint">@color/text_hint</item>
</style>
<style name="App.Button" parent="@android:style/Widget.Button">
<item name="android:textSize">@dimen/button_text_size</item>
<item name="android:fontFamily">sans-serif-medium</item>
<item name="android:textAllCaps">false</item>
</style>
<style name="App.Button.Primary">
<item name="android:background">@drawable/button_primary_background</item>
<item name="android:height">@dimen/button_primary_height</item>
<item name="android:width">@dimen/button_primary_width</item>
<item name="android:paddingLeft">@dimen/padding_normal</item>
<item name="android:paddingRight">@dimen/padding_normal</item>
<item name="android:textColor">@color/button_primary_text</item>
</style>
...
Run Code Online (Sandbox Code Playgroud)
使用 Material 主题,您可以使用textInputStyle来设置com.google.android.material.textfield.TextInputLayout组件的样式。
<style name="AppTheme" parent="Theme.MaterialComponents.Light">
....
<item name="textInputStyle">@style/MyTextInputLayoutStyle</item>
</style>
<style name=MyTextInputLayoutStyle" parent="@style/Widget.MaterialComponents.TextInputLayout.FilledBox">
....
</style>
Run Code Online (Sandbox Code Playgroud)
如果您想自定义TextInputEditText只需添加:
<style name=MyTextInputLayoutStyle" parent="@style/Widget.MaterialComponents.TextInputLayout.FilledBox">
....
<item name="materialThemeOverlay">
@style/MyThemeOverlayTextInputEditTextFilledBox</item>
</style>
<style name="MyThemeOverlayTextInputEditTextFilledBox">
<item name="editTextStyle">@style/MyTextInputEditText</item>
</style>
Run Code Online (Sandbox Code Playgroud)
例如:
<style name="MyTextInputEditText" parent="@style/Widget.MaterialComponents.TextInputEditText.FilledBox">
<item name="android:paddingTop">8dp</item>
<item name="android:paddingBottom">8dp</item>
<item name="android:textAppearance">myTextAppearance</item>
...
</style>
Run Code Online (Sandbox Code Playgroud)
新的 MDC 组件在这里提供了很大的灵活性,但它仍然很奇怪。我想要为所有 TextInputEditTexts 和填充(默认)样式使用自定义字体。它对我有用的唯一方法是使用全局样式属性在 TextInputEditText 上指定字体:
<!-- Base application theme. -->
<style name="MyAppTheme" parent="Theme.MaterialComponents.Light.NoActionBar">
<item name="textInputStyle">@style/MyTextField.Outlined</item>
<item name="editTextStyle">@style/MyEditTextFont</item>
</style>
<style name="MyEditTextFont" parent="Widget.MaterialComponents.TextInputEditText.FilledBox">
<item name="android:fontFamily">@font/my_font</item>
</style>
<style name="MyTextField" parent="Widget.MaterialComponents.TextInputLayout.FilledBox"/>
<style name="MyTextField.Outlined" parent="Widget.MaterialComponents.TextInputLayout.OutlinedBox"/>
Run Code Online (Sandbox Code Playgroud)
例如,如果您没有指定editTextStyle,那么 确实textInputStyle可以工作,但会缺少填充。无论如何,我建议使用这两个字段并根据需要对它们进行样式设置。
| 归档时间: |
|
| 查看次数: |
803 次 |
| 最近记录: |