繁体   English   中英

无法更改 Material TextInputEditText 的光标和气泡颜色

[英]Can't change cursor and bubble color for Material TextInputEditText

我想更改 Material TextInputEditText 的气泡和光标颜色。 我试过 colorAccent、android:textCursorDrawable 这些都不能正常工作。

文件在这里

你可以在这张图片中看到它

材料属性颜色colorControlActivated发挥了神奇的作用。 您必须为 TextInputLayout 创建样式。

例如:

<style name="TextInputLayoutAppearance" parent="Widget.Design.TextInputLayout">
    <item name="colorControlNormal">@color/white</item>
    <item name="colorControlActivated">@color/red</item>
    <item name="colorControlHighlight">@color/blue</item>
</style>

然后你必须在控件的主题属性中应用这个样式:

 <com.google.android.material.textfield.TextInputLayout
                android:id="@+id/lblObservaciones"
                android:theme="@style/TextInputLayoutAppearance"
                style="@style/Widget.MaterialComponents.TextInputLayout.OutlinedBox"
                android:layout_width="match_parent"
                android:layout_height="wrap_content"
                app:boxStrokeColor="@color/blue"
                app:hintTextAppearance="@style/TextAppearance.AppCompat.Medium"
                app:hintTextColor="@color/blue">

            <com.google.android.material.textfield.TextInputEditText
                    android:id="@+id/comments"
                    android:layout_width="match_parent"
                    android:layout_height="100dp"
                    android:gravity="top"
                    android:inputType="textMultiLine"
                    android:maxLength="200" />
</com.google.android.material.textfield.TextInputLayout>

只需在应用程序主题(白天/黑夜)中应用colorControlActivated ,所有 Material TextInputEditField 都将具有更改的光标颜色

<item name="android:colorControlActivated">@color/green</item>

您必须使用以下属性:

<style name="AppTheme" parent="Theme.MaterialComponents.Light">
    <item name="colorPrimary">#212121</item>
    <item name="colorPrimaryVariant">#000000</item>
    <item name="colorOnPrimary">#FFFFFF</item>
    <item name="colorSecondary">#2962FF</item>
    <item name="colorSecondaryVariant">#0039CB</item>
    <item name="colorOnSecondary">#FFFFFF</item>
    <item name="colorError">#F44336</item>
    <item name="colorOnError">#FFFFFF</item>
    <item name="colorSurface">#FFFFFF</item>
    <item name="colorOnSurface">#212121</item>
    <item name="android:colorBackground">@color/background</item>
    <item name="colorOnBackground">#212121</item>
</style>

<color name="background">#FAFAFA</color>

要了解更多信息: 为 Android 设置 Material Components 主题

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM