Ati*_*Asi 5 android-layout material-design android-textinputlayout material-ui material-components-android
我正在使用材料设计1.1.0
对于带有Viewpager2
. 我将其更新为'1.2.0-alpha05'
材质库版本,它对于单个模块工作正常,但对于我开发了自定义材质设计的TextInputLayout的另一个模块则崩溃了。我将主题从 更改为'Theme.AppCompat.Light.NoActionBar'
并Theme.MaterialComponents.Light.NoActionBar
修复了崩溃。修复崩溃并升级主题后,它向我显示白色浮动标签、按钮、指示器等,有人请指导我哪里做错了。?
GITHUB 问题票链接: https://github.com/material-components/material-components-android/issues/1207
@颜色/白色 @颜色/colorPrimary_New @颜色/a465661Style.xml(旧文件)
旧文件在使用 AppCompact 时与材质发生冲突,parent="Widget.MaterialComponents.TextInputLayout.OutlinedBox.Dense"
更新到 1.2.0-alpha05 后已解决,但样式背景现在不起作用
图书馆
materialVersion = '1.2.0-alpha05'
"com.google.android.material:material:$materialVersion"
Run Code Online (Sandbox Code Playgroud)
.XML(设计)
<com.google.android.material.textfield.TextInputLayout
android:id="@+id/textInputLayout"
style="@style/contentInputLayoutStyle"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_marginStart="@dimen/_8dp"
android:paddingStart="5dp"
android:paddingLeft="5dp"
app:helperTextEnabled="true"
android:layout_marginLeft="@dimen/_8dp"
android:layout_marginEnd="@dimen/_8dp"
android:layout_marginRight="@dimen/_8dp"
app:errorEnabled="false"
app:layout_constraintBottom_toTopOf="@+id/errorTextView"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintLeft_toLeftOf="parent"
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toTopOf="parent"
tools:hint="@string/EnterMobileNumber">
<com.google.android.material.textfield.TextInputEditText
android:id="@+id/textInputEditText"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:inputType="phone"
android:gravity="start"
android:textDirection="anyRtl"
tools:text="0335510023"
android:background="@null"
android:paddingEnd="@dimen/inputFieldPadding_36dp"
android:paddingRight="@dimen/inputFieldPadding_36dp" />
</com.google.android.material.textfield.TextInputLayout>
Run Code Online (Sandbox Code Playgroud)
样式.xml
<style name="AppTheme" parent="Theme.MaterialComponents.Light.NoActionBar" >
<!-- Customize your theme here. -->
<item name="colorPrimary">@color/white</item>
<item name="colorPrimaryDark">@color/green</item>
<item name="colorAccent">@color/a465661</item>
</style>
<style name="contentInputLayoutStyle" parent="Widget.MaterialComponents.TextInputLayout.OutlinedBox.Dense">
<item name="boxStrokeColor">@color/border_stroke_grey</item>
<item name="android:textColor">@color/black</item>
<item name="android:textStyle">normal</item>
<item name="errorTextAppearance">@style/error_label</item>
<item name="counterOverflowTextAppearance">@style/AppTheme.TextFloatLabelAppearance</item>
<item name="android:actionOverflowButtonStyle">@style/AppTheme.TextFloatLabelAppearance
</item>
<item name="hintTextAppearance">@style/text_label</item>
</style>
<style name="text_label" parent="TextAppearance.Design.Hint">
<item name="android:textSize">@dimen/title_heading_12sp</item>
<item name="colorControlNormal">@color/black</item>
<item name="colorControlActivated">@color/black</item>
<item name="colorControlHighlight">@color/black</item>
</style>
<style name="text_label_green" parent="TextAppearance.Design.Hint">
<item name="android:textSize">@dimen/title_heading_12sp</item>
<item name="colorControlNormal">@color/green_field</item>
<item name="android:background">@null</item>
<item name="colorControlActivated">@color/green_field</item>
<item name="colorControlHighlight">@color/green_field</item>
</style>
<style name="AppTheme.TextFloatLabelAppearance" parent="text_label">
<!-- Floating label appearance here -->
<item name="android:textColor">@color/label_title_black</item>
<item name="android:textSize">@dimen/title_heading_12sp</item>
<item name="android:background">@android:color/transparent</item>
<item name="colorControlNormal">@color/label_title_black</item>
<item name="colorControlHighlight">@color/label_title_black</item>
<item name="colorControlActivated">@color/label_title_black</item>
</style>
<style name="material_edit_text" parent="Widget.AppCompat.EditText">
<item name="android:paddingStart">50dp</item>
<item name="android:paddingLeft">50dp</item>
<item name="android:background">@null</item>
<item name="android:textSize">16sp</item>
</style>
<style name="error_label" parent="TextAppearance.Design.Hint">
<item name="android:textSize">0sp</item>
<item name="android:textColor">@color/red</item>
<item name="android:visibility">gone</item>
</style>
<style name="BtnCustomStyle">
<item name="android:background">@drawable/btn_confirm_selector</item>
<item name="android:textColor">@android:color/white</item>
<item name="android:textSize">15dp</item>
<item name="android:layout_width">match_parent</item>
<item name="android:layout_height">46dp</item>
<item name="android:layout_marginStart">10dp</item>
<item name="android:layout_marginEnd">10dp</item>
<item name="android:textAllCaps">false</item>
<item name="android:foreground">android:attr/selectableItemBackground</item>
</style>
Run Code Online (Sandbox Code Playgroud)
Style(v27).xml (已删除文件)
<style name="AppTheme" parent="Theme.MaterialComponents.Light.NoActionBar">
<!-- Customize your theme here. -->
<item name="colorPrimary">@color/white</item>
<item name="colorPrimaryDark">@color/colorPrimary_New</item>
<item name="colorAccent">@color/a465661</item>
<item name="android:windowLayoutInDisplayCutoutMode">never</item>
</style>
Run Code Online (Sandbox Code Playgroud)
更新
"Widget.MaterialComponents.TextInputLayout.OutlinedBox.Dense"
Run Code Online (Sandbox Code Playgroud)
此行在使用 appCompact 主题时导致崩溃。
阅读有关材料设计UI 更新的主题。根据此文档,我必须添加以下一些属性!
<!-- New MaterialComponents attributes. -->
<item name="colorOnPrimary">@color/whitee</item>
<item name="colorOnSecondary">@color/colorPrimary_New</item>
<item name="colorOnSurface">@color/a465661</item>-->
<item name="colorSurface">@color/a465661</item>-->
<item name="colorOnBackground">#212121</item>-->
<item name="android:colorBackground">@color/background</item>
<item name="colorError">#F44336</item>-->
<item name="colorOnError">#FFFFFF</item>
Run Code Online (Sandbox Code Playgroud)
但是,我尝试更改 TextInputLayout 的颜色,它工作正常,但对于按钮则不然。有人请指导我如何使用新材料设计来处理这个问题吗?
更新 :
android:theme="@style/Theme.MaterialComponents.Light"
Run Code Online (Sandbox Code Playgroud)
将上述主题添加到小部件中,它将解决您的问题。例如。
<com.google.android.material.bottomnavigation.BottomNavigationView
android:id="@+id/navigation"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_marginEnd="0dp"
android:layout_marginStart="0dp"
android:theme="@style/Theme.MaterialComponents.Light"
app:itemIconTint="@drawable/bottom_navigation_background"
app:itemTextColor="@drawable/bottom_navigation_background"
android:layout_alignParentBottom="true"
app:menu="@menu/navigation"
app:labelVisibilityMode="labeled"
app:itemTextAppearanceActive="@style/BottomNavigationActive"
app:itemTextAppearanceInactive="@style/BottomNavigationInactive" />
Run Code Online (Sandbox Code Playgroud)