Reputation: 1761
I tried to customize a spinnerItem with styles file. I can change spinner style (bg, border or font color etc.) but spinnerItem has always white colored text and grayed background.
do you have any idea?
ps: I shouldn't use new adapter for this.
This is my styles.xml:
<style name="AppTheme" parent="AppTheme.Base">
<item name="android:spinnerItemStyle">@style/SpinnerItemTheme</item>
</style>
<style name="SpinnerTheme" parent="Edit">
<item name="android:background">@color/blueColor</item>
<item name="android:dropDownSelector">@color/darkRedColor</item>
<item name="android:dropDownItemStyle">@style/SpinnerItemTheme</item>
<item name="android:spinnerItemStyle">@style/SpinnerItemTheme</item>
</style>
<style name="Edit" parent="Text.Display">
<item name="android:layout_width">match_parent</item>
<item name="android:layout_height">match_parent</item>
<item name="android:gravity">top|left</item>
<item name="android:textSize">20sp</item>
</style>
<style name="SpinnerItemTheme" parent="SpinnerTheme">
<item name="android:textColor">#000000</item>
<item name="android:background">@color/blueColor</item>
</style>
This is my layout file:
<android.support.v7.widget.AppCompatSpinner
android:layout_width="match_parent"
android:layout_height="match_parent"
style="@style/SpinnerTheme"
android:prompt="@string/prompt_nation"
android:entries="@array/countries">
</android.support.v7.widget.AppCompatSpinner>
Upvotes: 1
Views: 4305
Reputation: 129
styles.xml:
<style name="ToolbarSpinner" parent="AppTheme">
<item name="android:spinnerItemStyle">@style/ToolbarSpinnerItem</item>
<item name="android:spinnerDropDownItemStyle">@style/ToolbarSpinnerDropDownItem</item>
</style>
<style name="ToolbarSpinnerItem" parent="TextMedium">
<item name="android:textColor">@color/material_grey_white_1000</item>
<item name="android:gravity">center_vertical</item>
</style>
<style name="ToolbarSpinnerDropDownItem" parent="TextMedium">
<item name="android:textColor">@color/material_grey_black_1000</item>
<item name="android:gravity">center_vertical</item>
<item name="android:paddingRight">@dimen/space_small</item>
<item name="android:paddingLeft">@dimen/space_small</item>
</style>
layout:
<Spinner
android:id="@+id/spinner"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:spinnerMode="dialog"
android:theme="@style/ToolbarSpinner"/>
onCreateView:
spinnerAdapter = new ArrayAdapter<>(spinner.getContext(), android.R.layout.simple_spinner_item, listSource);
spinnerAdapter.setDropDownViewResource(android.R.layout.simple_spinner_dropdown_item);
spinner.setAdapter(spinnerAdapter);
Note that ArrayAdapter should be initialized with spinner.getContext(), because this context contains needed theme
Upvotes: 1
Reputation: 9512
Try this code :
<resources>
<style name="customtheme" parent="@android:style/Theme.Light">
<item name="android:spinnerItemStyle">@style/SpinnerItem</item>
<item name="android:spinnerDropDownItemStyle">@style/SpinnerDropDownItem</item>
</style>
<style name="SpinnerItem">
<item name="android:textColor">@color/your_color</item>
<item name="android:background">@drawable/your_backgroung</item>
</style>
<style name="SpinnerDropDownItem">
<item name="android:textColor">@color/your_color</item>
<item name="android:background">@drawable/your_background</item>
</style>
</resources>
Upvotes: 2