如何更改微调器文本大小和文本颜色?
Posted
技术标签:
【中文标题】如何更改微调器文本大小和文本颜色?【英文标题】:How to change spinner text size and text color? 【发布时间】:2012-03-17 14:43:19 【问题描述】:在我的 android 应用程序中,我正在使用微调器,并且我已将 SQLite 数据库中的数据加载到微调器中,并且它工作正常。这是它的代码。
Spinner spinner = (Spinner) this.findViewById(R.id.spinner1);
List<String> list = new ArrayList<String>();
ArrayAdapter<String> dataAdapter = new ArrayAdapter<String> (this,android.R.layout.simple_spinner_item, list);
cursor.moveToFirst();
list.add("All Lists");
if (cursor.getCount() > 0)
for (int i = 0; i < cursor.getCount(); i++)
keyList[i] = cursor.getString(cursor.getColumnIndex(AndroidOpenDbHelper.KEYWORD));
list.add(keyList[i]);
cursor.moveToNext();
Database.close();
cursor.close();
dataAdapter.setDropDownViewResource(android.R.layout.simple_spinner_dropdown_item);
spinner.setAdapter(dataAdapter);
现在我想更改微调器数据的文本颜色和文本大小。我在我的 XML 文件中使用了以下 XML 行到我的微调器标记,但它不起作用。
android:textColor="@android:color/white"
android:textSize="11dp"
如何更改微调器的文本颜色和文本大小?
【问题讨论】:
检查以下站点 [***][1] [***][2] [***][3] 我认为这是重复的问题 [1]:***.com/questions/4880413/… [2]:***.com/questions/4989817/… [3]:***.com/questions/5836254/… 试试这个帖子***.com/questions/6159113/… 对于 textSize 正确的是使用 SP... android:textSize="11sp" 【参考方案1】:为您的微调器项目制作自定义 XML 文件。
spinner_item.xml:
为此文件中的文本提供您自定义的颜色和大小。
<?xml version="1.0" encoding="utf-8"?>
<TextView
xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_
android:layout_
android:textSize="20sp"
android:gravity="left"
android:textColor="#FF0000"
android:padding="5dip"
/>
现在使用此文件显示您的微调器项目,例如:
ArrayAdapter<String> adapter = new ArrayAdapter<String>(this, R.layout.spinner_item,list);
您不需要设置下拉资源。 spinner_item.xml
只会在微调器中显示您的项目。
【讨论】:
@Hiral 文本将仅针对当前选定项目为白色。 @vilpe89 你能修改你上面的代码来说明你的意思吗?这个 android:id 去哪里了?当然不在 spinner 标签中,因为它有自己的 id。但是将它添加到您在上面创建的 textview 标记中是没有意义的。我如何引用我想直接从 XML 中使用这个标签?另外,当从 Eclipse 创建 XML 时,我没有看到任何选项来创建仅包含 TextView 的 XML 文件,这是如何工作的??? 请注意。 Textsize 应该使用 sp 而不是 dp/dip 嗨,正如@GyRo 所问,.xml 文件必须位于您的“布局”文件夹中。 这不能只使用样式来完成吗?我很惊讶在 android 中很难设计小东西。这令人沮丧。我希望他们有一个像 css 这样的样式系统【参考方案2】:简单明了...:
private OnItemSelectedListener OnCatSpinnerCL = new AdapterView.OnItemSelectedListener()
public void onItemSelected(AdapterView<?> parent, View view, int pos, long id)
((TextView) parent.getChildAt(0)).setTextColor(Color.BLUE);
((TextView) parent.getChildAt(0)).setTextSize(5);
public void onNothingSelected(AdapterView<?> parent)
;
【讨论】:
这对我来说是最好的解决方案,因为我需要在微调器中更改文本的颜色,而不是在出现的列表中。谢谢。 对我来说,项目颜色闪烁,从原始颜色变为我选择的颜色 @FelipeConde 你找到答案了吗?我也有同样的问题。我的问题在这里:***.com/questions/33908564/… @FelipieConde 对你来说,一开始是上升色,然后你手动换成其他颜色,所以看起来很累。一开始它需要如果所有微调器的 TextView 项可能具有相同的文本颜色,另一种方法是对微调器下拉项使用自定义样式:
在res/values/styles.xml
:
<resources>
<style name="AppBaseTheme" parent="android:Theme.Light">
</style>
<style name="AppTheme" parent="AppBaseTheme">
<item name="android:spinnerDropDownItemStyle">@style/mySpinnerItemStyle</item>
</style>
<style name="mySpinnerItemStyle" parent="@android:style/Widget.Holo.DropDownItem.Spinner">
<item name="android:textColor">@color/my_spinner_text_color</item>
</style>
</resources>
并在 res/values/colors.xml 中定义您的自定义颜色:
<color name="my_spinner_text_color">#808080</color>
【讨论】:
以及如何将此解决方案应用于 Appcompt 主题?我通过覆盖父主题“@style/Widget.AppCompat.DropDownItem.Spinner”进行了尝试,但没有成功 我还要添加:android:
这样的 <item name="spinnerDropDownItemStyle">@style/mySpinnerItemStyle</item>
要清楚,你必须将样式指定为主题,否则将不起作用:<Spinner android:theme="@style/mySpinnerItemStyle" ... />
【参考方案4】:
这里有一个链接可以帮助您更改 Spinner 的颜色:
Click here
<Spinner
android:layout_
android:layout_
android:id="@+id/spinner"
android:textSize="20sp"
android:entries="@array/planets"/>
您需要创建自己的布局文件,其中包含微调器项目的自定义定义spinner_item.xml:
<TextView xmlns:android="http://schemas.android.com/apk/res/android"
android:id="@android:id/text1"
android:layout_
android:layout_
android:textSize="20sp"
android:textColor="#ff0000" />
如果您想自定义下拉列表项,您将需要创建一个新的布局文件。 spinner_dropdown_item.xml:
<?xml version="1.0" encoding="utf-8"?>
<CheckedTextView xmlns:android="http://schemas.android.com/apk/res/android"
android:id="@android:id/text1"
style="?android:attr/spinnerDropDownItemStyle"
android:maxLines="1"
android:layout_
android:layout_
android:ellipsize="marquee"
android:textColor="#aa66cc"/>
最后是微调器声明的另一个变化:
ArrayAdapter adapter = ArrayAdapter.createFromResource(this,
R.array.planets_array, R.layout.spinner_item);
adapter.setDropDownViewResource(R.layout.spinner_dropdown_item);
spinner.setAdapter(adapter);
就是这样。
【讨论】:
这是来自新用户评论帖子的自动回复。很高兴看到您编辑了答案! :) 看来,第一个代码sn -p中的android:textSize="20sp"
是没用的:控件的textsize定义在spinner_item.xml
【参考方案5】:
如果您使用 android.support.v7.widget.AppCompatSpinner,这里是使用样式的最简单的测试解决方案:
<android.support.v7.widget.AppCompatSpinner
android:id="@+id/spefcialFx"
style="@style/Widget.AppCompat.Spinner.Underlined"
android:layout_
android:layout_
android:layout_marginLeft="4dp"
android:theme="@style/Spinner"
android:entries="@array/special_fx_arrays"
android:textSize="@dimen/text_size_normal"></android.support.v7.widget.AppCompatSpinner>
还有风格:
<style name="Spinner" parent="Widget.AppCompat.Light.DropDownItem.Spinner">
<item name="android:paddingStart">0dp</item>
<item name="android:paddingEnd">0dp</item>
<item name="android:textColor">@color/white</item>
<item name="android:backgroundTint">@color/red</item>
<item name="android:textSize">14sp</item>
</style>
唯一的缺点是 android:backgroundTint 为下拉箭头和下拉背景设置颜色。
【讨论】:
你使用style="@style/Widget.AppCompat.Spinner.Underlined"
,但你只有style name="Spinner"
...
paddingStart
需要 API 17,backgroundTint
需要 API 21。【参考方案6】:
为了防止卡顿,你不仅需要在onItemSelected
监听器中设置文本属性,还需要在Activity的onCreate
方法中设置文本属性(不过有点棘手)。
具体来说,需要在设置好适配器后把这个放在onCreate
中:
spinner.setSelection(0, true);
View v = spinner.getSelectedView();
((TextView)v).setTextColor(backgroundColor);
然后把这个放到onItemSelected
:
((TextView) view).setTextColor(backgroundColor);
这是一个完整的例子:
@Override
protected void onCreate(Bundle savedInstanceState)
Spinner spinner = (Spinner) findViewById(R.id.spinner);
//Set the choices on the spinner by setting the adapter.
spinner.setAdapter(new SpinnerAdapter(toolbar.getContext(), new String[]"Overview", "Story", "Specifications", "Poll", "Video", accentColor, backgroundColor));
//Set the text color of the Spinner's selected view (not a drop down list view)
spinner.setSelection(0, true);
View v = spinner.getSelectedView();
((TextView)v).setTextColor(backgroundColor);
//Set the listener for when each option is clicked.
spinner.setOnItemSelectedListener(new AdapterView.OnItemSelectedListener()
@Override
public void onItemSelected(AdapterView<?> parent, View view, int position, long id)
//Change the selected item's text color
((TextView) view).setTextColor(backgroundColor);
@Override
public void onNothingSelected(AdapterView<?> parent)
);
更多详情请见my question。
【讨论】:
【参考方案7】:如果您希望仅在所选项目中更改文本颜色,那么这可能是一种解决方法。它对我有用,也应该对你有用。
spinner.getViewTreeObserver().addOnGlobalLayoutListener(new ViewTreeObserver.OnGlobalLayoutListener()
@Override
public void onGlobalLayout()
((TextView) spinner.getSelectedView()).setTextColor(Color.WHITE);
);
【讨论】:
【参考方案8】:对于只需要Style
方式的人来说AppCompat
。
结果
styles.xml
<resources>
...
<style name="Spinner" parent="Widget.AppCompat.Light.DropDownItem.Spinner">
<item name="android:paddingStart">0dp</item>
<item name="android:paddingEnd">0dp</item>
<item name="android:textColor">@color/material_grey_700</item>
<item name="android:textSize">12sp</item>
</style>
</resources>
your_spinner_layout.xml
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto"
xmlns:tools="http://schemas.android.com/tools"
android:layout_
android:layout_ />
...
<android.support.v7.widget.AppCompatSpinner
android:id="@+id/content_spinner"
style="@style/Widget.AppCompat.Spinner.Underlined"
android:layout_
android:layout_
android:entries="@array/shipping_tracking_carrier_names"
android:spinnerMode="dropdown"
android:theme="@style/Spinner" />
<EditText
android:id="@+id/content_input"
android:layout_
android:layout_
android:inputType="text"
android:maxLines="1"
android:paddingEnd="8dp"
android:paddingStart="8dp"
android:textColor="@color/material_grey_700"
android:textSize="12sp" />
...
</LinearLayout>
加号
如果您想使用定义的样式以编程方式设置android:entries
。
尝试这个。
AppCompatSpinner spinner = findViewById(R.id.content_spinner);
CharSequence[] entries = getResources().getTextArray(R.array.shipping_tracking_carrier_names);
ArrayAdapter<CharSequence> adapter = new ArrayAdapter<>(spinner.getContext(), android.R.layout.simple_spinner_item, entries);
adapter.setDropDownViewResource(android.support.v7.appcompat.R.layout.support_simple_spinner_dropdown_item);
spinner.setAdapter(adapter);
在代码中,使用相同的Context
和Spinner
是最重要的。
spinner.getContext()
【讨论】:
【参考方案9】:更改微调器文本的颜色:
public void onItemSelected(AdapterView<?> parent, View view, int position, long id)
((TextView) parent.getChildAt(0)).setTextColor(Color.WHITE);
【讨论】:
我也喜欢这个解决方案。它很简单,效果很好。【参考方案10】:我们可以像这样为微调器更改微调器文本视图集主题的样式:
styles.xml:
<style name="mySpinnerItemStyle" parent="@android:style/Widget.Holo.DropDownItem.Spinner">
<item name="android:textSize">@dimen/_11ssp</item>
<item name="android:textColor">@color/blue</item>
<item name=...</item>
</style>
然后
<Spinner
android:theme="@style/mySpinnerItemStyle"
android:layout_
android:layout_/>
如果您想以编程方式更改微调器 textview 属性:
以编程方式:
val textView = (view.getChildAt(0) as TextView)
textView.setTextColor(resources.getColor(R.color.dark_mode))
【讨论】:
【参考方案11】:对于那些想要改变DrowDownIcon
颜色的人
你可以这样使用
spinner.getBackground().setColorFilter(Color.parseColor("#ffffff"), PorterDuff.Mode.SRC_ATOP);
【讨论】:
你可以试试<item name="android:colorControlNormal" tools:targetApi="lollipop">@color/light_gray</item>
把这行写成你的风格AppTheme
这是有效的代码Drawable spinnerDrawable = spinner.getBackground().getConstantState().newDrawable(); spinnerDrawable.setColorFilter(getResources().getColor(R.color.md_white_1000), PorterDuff.Mode.SRC_ATOP); if (android.os.Build.VERSION.SDK_INT >= Build.VERSION_CODES.JELLY_BEAN) spinner.setBackground(spinnerDrawable); else spinner.setBackgroundDrawable(spinnerDrawable);
【参考方案12】:
可以通过重写getView方法来改变文字颜色,如下:
new ArrayAdapter<String>(getContext(), android.R.layout.simple_spinner_dropdown_item, list())
@Override
public View getView(int position, View convertView, @NonNull ViewGroup parent)
View view = super.getView(position, convertView, parent);
//change the color to which ever you want
((CheckedTextView) view).setTextColor(Color.RED);
//change the size to which ever you want
((CheckedTextView) view).setTextSize(5);
//for using sp values use setTextSize(TypedValue.COMPLEX_UNIT_SP, 16);
return view;
【讨论】:
【参考方案13】:与其制作自定义布局以获得小尺寸,而且如果您想使用 Android 内部的小尺寸 LAYOUT 作为微调器,您应该使用:
“android.R.layout.simple_gallery_item”而不是“android.R.layout.simple_spinner_item”。
ArrayAdapter<CharSequence> madaptor = ArrayAdapter
.createFromResource(rootView.getContext(),
R.array.String_visitor,
android.R.layout.simple_gallery_item);
它可以减小微调器的布局大小。这只是一个简单的技巧。
如果您想减小下拉列表的大小,请使用:
madaptor.setDropDownViewResource(android.R.layout.simple_gallery_item);
【讨论】:
【参考方案14】:重用/更改 android.R.layout 资源的最简单方法就是去定义。在 Android Studio 中,对 android.R.layout.simple_spinner_item.xml 执行 Ctrl + B。
它将带你到资源文件。只需复制资源文件并在您的 Package.R.layout 文件夹中添加一个新布局,然后根据需要更改 textview 的 textColor,然后像这样在适配器中调用它:
ArrayAdapter<String> adapter = new ArrayAdapter<String(Context,R.layout.spinner_item, spinnerlist);
【讨论】:
【参考方案15】:最简单:适合我
TextView spinnerText = (TextView) spinner.getChildAt(0);
spinnerText.setTextColor(Color.RED);
【讨论】:
spinner.getChildAt(0) 返回 null 给我:/ 我认为这种技术适用于 API 19+。【参考方案16】:如果您想要一个简单的方法,为了将项目添加到下拉列表,您通常将它们添加到 strings.xml。下面是一个关于如何使用 strings.xml 文件添加颜色的示例:
选择年龄范围
<string-array name="age_array">
<item> 0-6 </item> //No custom colour
<item><font fgcolor='#FF4CD964'> 12+ </font></item> //With custom colour
</string-array>
【讨论】:
可爱的技巧...对于一次性微调器有用且快速,颜色需要是不是来自 xml 的原始颜色值字符串【参考方案17】:<?xml version="1.0" encoding="utf-8"?>
<TextView xmlns:android="http://schemas.android.com/apk/res/android"
android:id="@android:id/text1"
style="?android:attr/spinnerItemStyle"
android:singleLine="true"
android:layout_
android:layout_
android:textColor="#fff"
android:ellipsize="marquee"
android:textAlignment="inherit"/>
就用这个吧:
ArrayAdapter<String> adapter_category = new ArrayAdapter<String>(this,
R.layout.spinner_list_item, categories);
adapter_category
.setDropDownViewResource(android.R.layout.simple_spinner_dropdown_item);
【讨论】:
【参考方案18】:只是想对顶部的正确答案稍作改动。 在布局目录中为您的微调器项创建一个自定义 XML 文件。
spinner_style.xml:
为此文件中的文本提供您自定义的颜色和大小。
<?xml version="1.0" encoding="utf-8"?>
<TextView
xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_
android:layout_
style="?android:attr/spinnerItemStyle"
android:singleLine="true"
android:ellipsize="marquee"
android:textAlignment="inherit"
android:textSize="15sp"
android:textColor="#FF0000"
android:padding="5dp"
/>
现在使用此文件在您的 java 文件中显示您的微调器项目:
ArrayAdapter<String> adapter = new ArrayAdapter<>(this,R.layout.spinner_style,list);
adapter.setDropDownViewResource(R.layout.spinner_style);
【讨论】:
【参考方案19】:Ashraf 解决方案的另一个变体是确保您考虑到屏幕尺寸。设置适配器后,您需要在 onCreate 中获取微调器并设置侦听器:
//set your adapter with default or custom spinner cell, then://
serverSpinner.setOnItemSelectedListener(spinnerSelector);
serverSpinner.setSelection(defaultServer);
然后您可以开始更改在单击微调器之前显示的视图的文本大小:
private AdapterView.OnItemSelectedListener spinnerSelector = new AdapterView.OnItemSelectedListener()
public void onItemSelected(AdapterView<?> parent, View view, int pos, long id)
boolean tabletSize = getResources().getBoolean(R.bool.isTablet);
boolean largeTablet = getResources().getBoolean(R.bool.isLargeTablet);
if (tabletSize) ((TextView)parent.getChildAt(0)).setTextSize(16);
else if (largeTablet) ((TextView)parent.getChildAt(0)).setTextSize(18);
else ((TextView)parent.getChildAt(0)).setTextSize(12);
public void onNothingSelected(AdapterView<?> parent)
;
您需要做的就是像这样创建特定于布局的文件夹:
值-sw360dp
值-sw600dp
值-sw800dp
然后将名为“bool.xml”的 xml 文件添加到每个文件夹中:
<?xml version="1.0" encoding="utf-8"?>
<resources>
<bool name="isTablet">false</bool>
<bool name="isLargeTablet">false</bool>
</resources>
【讨论】:
【参考方案20】:首先,我们必须为textview
创建简单的xml
资源文件,如下所示:
<?xml version="1.0" encoding="utf-8"?>
<TextView
xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_
android:layout_
android:textSize="20sp"
android:gravity="left"
android:textColor="#FF0000"
android:padding="5dip"
/>
并保存。在您的适配器列表上设置之后。
【讨论】:
【参考方案21】:您可以拥有这种类型的微调器适配器,完全定制:
ArrayAdapter<String> genderAdapter = new ArrayAdapter<String>(getActivity(), R.layout.spinner_text, genderList)
public View getView(int position, View convertView, ViewGroup parent)
View v = super.getView(position, convertView, parent);
((TextView) v).setTextSize(TypedValue.COMPLEX_UNIT_DIP, 16);
((TextView) v).setTextColor(Color.parseColor("#676767"));
((TextView) v).setTypeface(vrFont);
return v;
public View getDropDownView(int position, View convertView, ViewGroup parent)
View v = super.getDropDownView(position, convertView, parent);
((TextView) v).setTextSize(TypedValue.COMPLEX_UNIT_DIP, 16);
((TextView) v).setTypeface(vrFont);
((TextView) v).setTextColor(Color.parseColor("#676767"));
if (position == 0)
((TextView) v).setTextColor(Color.parseColor("#979797"));
return v;
而 R.layout.spinner_text 是:
<TextView xmlns:android="http://schemas.android.com/apk/res/android"
android:id="@+id/text1"
style="?android:attr/spinnerItemStyle"
android:layout_
android:layout_
android:gravity="center_vertical|left"
android:ellipsize="marquee"
android:maxLines="1"
android:textColor="@color/whiteThree" />
【讨论】:
【参考方案22】:试试这个方法。它对我有用。
@Override
public void onItemSelected(AdapterView<?> adapterView, View view, int i, long l)
TextView textView = (TextView) view;
((TextView) adapterView.getChildAt(0)).setTextColor(Color.RED);
((TextView) adapterView.getChildAt(0)).setTextSize(20);
Toast.makeText(this, textView.getText()+" Selected", Toast.LENGTH_SHORT).show();
【讨论】:
我认为这是一个简单的解决方案。【参考方案23】: String typeroutes[] = "Select","Direct","Non Stop";
Spinner typeroute;
typeroute = view.findViewById(R.id.typeroute);
final ArrayAdapter<String> arrayAdapter5 = new ArrayAdapter<String>(
getActivity(), android.R.layout.simple_spinner_item, typeroutes)
@Override
public boolean isEnabled(int position)
if (position == 0)
// Disable the first item from Spinner
// First item will be use for hint
return false;
else
return true;
public View getView(int position, View convertView, ViewGroup parent)
View v = super.getView(position, convertView, parent);
((TextView) v).setTextSize(TypedValue.COMPLEX_UNIT_DIP, 16);
((TextView) v).setTextColor(Color.parseColor("#ffffff"));
return v;
---->in this line very important so add this
@Override
public View getDropDownView(int position, View convertView,
ViewGroup parent)
View view = super.getDropDownView(position, convertView, parent);
TextView tv = (TextView) view;
if (position == 0)
// Set the hint text color gray
tv.setTextColor(Color.GRAY);
else
tv.setTextColor(Color.BLACK);
return view;
;
arrayAdapter5.setDropDownViewResource(android.R.layout.simple_spinner_dropdown_item);
typeroute.setAdapter(arrayAdapter5);
这就是享受你的编码......
【讨论】:
【参考方案24】:我已经按照以下方式完成了。我使用了 getDropDownView() 和 getView() 方法。
使用 getDropDownView()
打开 Spinner。
@Override
public View getDropDownView(int position, View convertView, ViewGroup parent)
View view = convertView;
if (view == null)
LayoutInflater vi = (LayoutInflater) activity.getSystemService(Context.LAYOUT_INFLATER_SERVICE);
view = vi.inflate(R.layout.context_row_icon, null);
TextView mTitle = (TextView) view.findViewById(R.id.context_label);
ImageView flag = (ImageView) view.findViewById(R.id.context_icon);
mTitle.setText(values[position].getLabel(activity));
if (!((LabelItem) getItem(position)).isEnabled())
mTitle.setTextColor(activity.getResources().getColor(R.color.context_item_disabled));
else
mTitle.setTextColor(activity.getResources().getColor(R.color.context_item));
return view;
并使用 getView()
关闭 Spinner。
@Override
public View getView(int position, View convertView, ViewGroup parent)
View view = convertView;
if (view == null)
LayoutInflater vi = (LayoutInflater) activity.getSystemService(Context.LAYOUT_INFLATER_SERVICE);
view = vi.inflate(R.layout.context_row_icon, null);
TextView mTitle = (TextView) view.findViewById(R.id.context_label);
ImageView flag = (ImageView) view.findViewById(R.id.context_icon);
mTitle.setText(values[position].getLabel(activity));
mTitle.setTextColor(activity.getResources().getColor(R.color.context_item_disabled));
return view;
【讨论】:
它是经过适当测试的代码并在应用商店的应用程序中工作【参考方案25】:只需像这样添加新样式:
<style name="mySpinnerItemStyle" parent="ThemeOverlay.AppCompat.Dark">
<item name="android:textColor">#000</item>
<item name="android:color">#000</item>
</style>
并使用它:
<Spinner
android:id="@+id/spinnerCategories"
android:layout_
android:layout_
style="@style/mySpinnerItemStyle"
android:layout_margin="5dp" />
【讨论】:
以上是关于如何更改微调器文本大小和文本颜色?的主要内容,如果未能解决你的问题,请参考以下文章