造型的Androidsearch视图和下拉列表中的操作栏

在我的应用程序中,我有一个显示searchbuild议的search视图。 我想下拉/微调和文字是一个特定的颜色。 目前我能做的唯一变化就是通过以下方式input文本的文本颜色:

<style name="MyApp.AutoCompleteTextView" parent="Widget.AppCompat.Light.AutoCompleteTextView"> <item name="android:textColor">@color/white</item> <item name="android:textCursorDrawable">@null</item> <item name="android:background">@color/myBackgroundColor</item> </style> 

该应用程序目前显示如下search结果:

这是目前的样子

我想知道的是我将如何去改变像searchHint颜色,下拉背景和下拉项目文本颜色的部分?

我的目标是API 19+

Solutions Collecting From Web of "造型的Androidsearch视图和下拉列表中的操作栏"

在你的styles.xml中,将以下内容设置为你的AppTheme

 <style name="AppTheme" parent="AppTheme.Base"> <!-- Customize your theme here. --> <item name="android:dropDownItemStyle">@style/myDropDownItemStyle</item> </style> <style name="myDropDownItemStyle" parent="Widget.AppCompat.DropDownItem.Spinner"> <item name="android:textColor">@color/secondary_text_default_material_light</item> </style> 

这可以改变下拉项目的文字颜色。 试试。

所以经过大量的search,我能find的最接近的解决scheme如下(感谢GZ95的回答 !):

 SearchView searchView = new SearchView(context); LinearLayout linearLayout1 = (LinearLayout) searchView.getChildAt(0); LinearLayout linearLayout2 = (LinearLayout) linearLayout1.getChildAt(2); LinearLayout linearLayout3 = (LinearLayout) linearLayout2.getChildAt(1); AutoCompleteTextView autoComplete = (AutoCompleteTextView) linearLayout3.getChildAt(0); //Set the input text color autoComplete.setTextColor(Color.WHITE); // set the hint text color autoComplete.setHintTextColor(Color.WHITE); //Some drawable (eg from xml) autoComplete.setDropDownBackgroundResource(R.drawable.drop_down_bg); 

这不是最优雅的,但它已经为我工作。 我唯一的问题是如何改变build议的项目文字颜色。 我很高兴听到这个问题的更好的解决scheme

如果您使用的是android.support.v7.widget.SearchView,则可以在res / styles.xml中定义以下样式。

 <style name="AppTheme" parent="Theme.AppCompat.Light.DarkActionBar"> <!-- Customize your theme here. --> <item name="autoCompleteTextViewStyle">@style/myAutoCompleteTextViewStyle</item> <item name="textAppearanceSearchResultTitle">@style/mySearchResult</item> </style> <style name="myAutoCompleteTextViewStyle" parent="Widget.AppCompat.Light.AutoCompleteTextView"> <item name="android:popupBackground">#ffffff</item> </style> <style name="mySearchResult" parent="TextAppearance.AppCompat.SearchResult.Title"> <item name="android:textColor">#000000</item> </style> 

如果您使用默认的SearchView,则属性应该是“android:autoCompleteTextViewStyle”和“android:textAppearanceSearchResultTitle”。 我写了一篇文章描述这个细节。

使用样式可以更改下拉菜单的背景和项目的文字颜色

 <!-- ToolBar --> <style name="ToolBarStyle" parent="Theme.AppCompat"> <item name="android:textColorPrimary">@android:color/white</item> <item name="android:textColorSecondary">@android:color/white</item> <item name="actionMenuTextColor">@android:color/white</item> <item name="android:dropDownItemStyle">@style/myDropDownItemStyle</item> <item name="android:dropDownListViewStyle">@style/myDropDownListViewStyle</item> </style> <style name="myDropDownItemStyle" parent="Widget.AppCompat.DropDownItem.Spinner"> <item name="android:textColor">@color/secondary_text_default_material_light</item> <item name="android:textSize">14dp</item> </style> <style name="myDropDownListViewStyle" parent="Widget.AppCompat.ListView.DropDown"> <item name="android:background">#FFF</item> </style> 

您可以在themes.xml中定义suggestionRowLayout:

 <resources> <style name="AppTheme" parent="AppTheme.Base"> <item name="searchViewStyle">@style/AppTheme.SearchView</item> </style> <style name="AppTheme.Base" parent="Theme.AppCompat.Light.NoActionBar"> <item name="colorPrimary">@color/bluegrey_500</item> <item name="colorPrimaryDark">@color/bluegrey_900</item> <item name="colorAccent">@color/teal_500</item> <item name="android:windowNoTitle">true</item> <item name="windowActionBar">false</item> </style> <style name="AppTheme.SearchView" parent="Widget.AppCompat.SearchView"> <!-- The layout for the search view. Be careful. --> <!--<item name="layout">...</item>--> <!-- Background for the search query section (eg EditText) --> <!--<item name="queryBackground">@color/bluegrey_400</item>--> <!-- Background for the actions section (eg voice, submit) --> <!--<item name="submitBackground">...</item>--> <!-- Close button icon --> <!--<item name="closeIcon">...</item>--> <!-- Search button icon --> <!--<item name="searchIcon">...</item>--> <!-- Go/commit button icon --> <!--<item name="goIcon">...</item>--> <!--Voice search button icon--> <!--<item name="voiceIcon">@drawable/abc_ic_voice_search_api_mtrl_alpha</item>--> <!-- Commit icon shown in the query suggestion row --> <!--<item name="commitIcon">...</item>--> <!-- Layout for query suggestion rows --> <item name="suggestionRowLayout">@layout/item_suggestion_place</item> </style>