Change TextColor in SearchView using Android Toolbar

前端 未结 4 1824
情深已故
情深已故 2020-12-30 05:24

I have the following problem. I\'ve setup my Actionbar to use a Toolbar instead using the API 21 with the appcompat-v7:21. The textColorPrimary style tag is con

相关标签:
4条回答
  • 2020-12-30 05:40

    Simply change or add an android:textcolorPrimary to your styles, all your styles in some cases. Wat ever color you choose for this item will be the color of your searchview text.

    0 讨论(0)
  • 2020-12-30 05:45

    This is possible to do purely in XML using a ThemeOverlay:

    <style name="ThemeOverlay.MyApp.ActionBar" parent="ThemeOverlay.AppCompat.ActionBar">
        <item name="autoCompleteTextViewStyle">@style/Widget.MyApp.AutoCompleteTextView.SearchView</item>
        <item name="searchViewStyle">@style/Widget.MyApp.SearchView</item>
    </style>
    
    <style name="Widget.MyApp.AutoCompleteTextView.SearchView" parent="Widget.AppCompat.AutoCompleteTextView">
        <item name="android:textColor">#000</item>
        <item name="android:textColorHint">#5000</item>
    </style>
    
    <style name="Widget.MyApp.SearchView" parent="Widget.AppCompat.SearchView">
        <item name="queryBackground">@drawable/search_background</item>
        <item name="searchIcon">@drawable/icon_search</item>
    </style>
    

    And then in your layout file:

    <android.support.v7.widget.Toolbar
        app:theme="@style/ThemeOverlay.MyApp.ActionBar"
        ... />
    

    If you also want it to apply to activities that are using an ActionBar instead of a ToolBar, you can add this to the Activity's theme:

    <style name="Theme.MyApp" parent="Theme.AppCompat">
        <item name="actionBarTheme">@style/ThemeOverlay.MyApp.ActionBar</item>
        ...
    </style>
    
    0 讨论(0)
  • 2020-12-30 05:49

    After some research I found a secure way to do it.

    Digging up in the SearchView styles, I found the layout that is used to display the SearchView. Inside that layout there's a TextView (the actual field where you type in the SearchView)

    <TextView
            android:id="@+id/search_badge"
            android:layout_width="wrap_content"
            android:layout_height="match_parent"
            android:gravity="center_vertical"
            android:layout_marginBottom="2dip"
            android:drawablePadding="0dip"
            android:textAppearance="?android:attr/textAppearanceMedium"
            android:textColor="?android:attr/textColorPrimary"
            android:visibility="gone" />
    

    Notice the field android:textColor="?android:attr/textColorPrimary". This causes the problem I originally had, the text color in the SearchView is the same as the one defined for the Title text color in the Android Toolbar.

    Now there're are several solutions that might work here, but I think that most of those solutions have the same problem. They all rely in the id of the TextView in order to access the view and change the text color, as described here

    Personally I think that hardcoding the id of the TextView inside the code is highly risky, because we don't know if tomorrow Google decides to use another id value for this view, in that case, our code will be broken.

    For that reason I've created a recursive method that obtains the TextView object in the SearchView, and changes the color to whatever we want.

    @Override
    public void onCreateOptionsMenu(Menu menu, MenuInflater inflater) {
        super.onCreateOptionsMenu(menu, inflater);
        menu.clear();
        inflater.inflate(R.menu.search, menu);
        SearchView searchView = (SearchView) menu.findItem(R.id.search).getActionView();
    
        searchView.setOnQueryTextListener(new SearchTextListener());
        changeSearchViewTextColor(searchView);
    }
    
    
    private void changeSearchViewTextColor(View view) {
        if (view != null) {
            if (view instanceof TextView) {
                ((TextView) view).setTextColor(Color.BLACK);
                return;
            } else if (view instanceof ViewGroup) {
                ViewGroup viewGroup = (ViewGroup) view;
                for (int i = 0; i < viewGroup.getChildCount(); i++) {
                    changeSearchViewTextColor(viewGroup.getChildAt(i));
                }
            }
        }
    }
    

    I've tested this code using API 21 with the Toolbar, having the Toolbar Title text color set to white, and setting up the SearchView text color to black and it works perfectly. Also, as we're accessing the TextView object directly, we can change the hint, drawable, paddings, and everything related to the TextView.

    0 讨论(0)
  • 2020-12-30 05:49

    Solution by @David_E works, but there's another way. You can also define custom layout:

    <style name=”MySearchViewStyle” parent=”Widget.AppCompat.SearchView”>
        <item name="layout">@layout/my_Search_view</item>
    </style>
    

    Then you can take default layout file, which you can find by name: abc_search_view.xml, used by search view and modify it.

    0 讨论(0)
提交回复
热议问题