3

我正在使用带有浮动标签提示的 TextInputLayout。但在正常状态下,我无法将提示颜色从白色更改为其他颜色。有没有办法做到这一点 ?

<android.support.design.widget.TextInputLayout
    android:id="@+id/fullNameTextLayout"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:gravity="center"
    android:layout_weight="0.75">
    <EditText
        android:id="@+id/etFullName"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:layout_marginStart="15dp"
        android:layout_marginLeft="15dp"
        android:layout_marginEnd="15dp"
        android:layout_marginRight="15dp"
        android:singleLine="true"
        android:hint="Full Name"
        android:textColor="@color/gray_dark"
        android:textColorHint="@color/green"
        android:textColorHighlight="@color/green" />
</android.support.design.widget.TextInputLayout>

附上两个背景改变的屏幕截图。

绿色背景的相同视图

白色背景的相同视图

4

5 回答 5

7

请在 TextInputLayout 中添加这个,

  app:hintTextAppearance="@style/mytext 

所以你的布局会是这样的:

 <android.support.design.widget.TextInputLayout
        android:id="@+id/aeal_input_layout_zipcode"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:textColorHint="@color/green"
        app:hintTextAppearance="@style/mytext">
    <EditText
        android:id="@+id/aeal_etZipCode"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:hint="Zipcode"
        android:singleLine="true"
        android:inputType="number"
        android:textColor="@color/primaryTextColor" />
</android.support.design.widget.TextInputLayout>

样式.xml:

 <style name="mytext" parent="@android:style/TextAppearance">
    <item name="android:textColor">@color/green</item>
    <item name="android:textColorHint">@color/green</item>
    <item name="colorAccent">@color/green</item>
    <item name="android:textSize">14sp</item>
</style>

已编辑:您需要在 TextInputLayout 中添加 textColorHint,它会根据您的需要正常工作。

它对我有用,所以也可以帮助你。

于 2016-01-29T07:02:20.833 回答
2

遇到了同样的问题,并使用 TextInputLayout 的 setHintTextAppearance(int) 方法解决了这个问题。

例子:

首先找到你的 TextInputLayout

android.support.design.widget.TextInputLayout textInputLayout = (TextInputLayout) view.findViewById(R.id.textInputLayout);

现在执行以下操作:

textInputLayout.setHintTextAppearance(R.style.Inactive);

在您的 styles.xml 文件中,您使用提示颜色的颜色创建样式。例如

<style name="Inactive" parent="AppThemeLight">
    <item name="android:textColorPrimary">@android:color/darker_gray</item>
    <item name="android:textColor">@android:color/darker_gray</item>
</style>

<style name="Active" parent="AppThemeLight">
    <item name="android:textColorPrimary">@android:color/black</item>
    <item name="android:textColor">@android:color/black</item>
</style>

现在,当您更改诸如 onButtonClick 之类的内容时,您只需更改您的样式。

final Button button = (Button) findViewById(R.id.button_id);
         button.setOnClickListener(new View.OnClickListener() {
             public void onClick(View v) {
textInputLayout.setHintTextAppearance(R.style.Active);
             }
         });

请记住,您还必须在 TextInputLayout 中处理 EditText 的颜色。

于 2016-05-31T12:13:19.180 回答
0

尝试这个

<android.support.design.widget.TextInputLayout ........ android:textColorHint="requiredColor" ....>更改浮动提示颜色和

<EditText android:textColor="requiredColor"更改 edittxt 中的提示颜色

于 2016-01-29T07:55:50.930 回答
0

使用它来更改提示颜色。-

editText.setHintTextColor(getResources().getColor(R.color.xyz));

解决您的问题 -

editText.addTextChangedListener(new TextWatcher() {
    @Override
    public void onTextChanged(CharSequence arg0, int arg1, int arg2,int arg3){
        //do something
    }

    @Override
    public void beforeTextChanged(CharSequence arg0, int arg1, int arg2, int arg3) {
        //do something
    }

    @Override
    public void afterTextChanged(Editable arg0) {
        if(arg0.toString().length() <= 0) //check if length is equal to zero
            editText.setHintTextColor(getResources().getColor(R.color.xyz));
    }
});
于 2016-01-29T06:54:08.033 回答
0

在您的 Style.xml 中,您可以更改提示的颜色

<style name="AppTheme" parent="Theme.AppCompat.Light.NoActionBar">
    <item name="colorAccent">#3498db</item>
</style>

有关更多信息,请参阅

于 2016-01-29T06:58:08.760 回答