设置背景
在使用Spinner时,如果单纯的设置背景色,则下拉框的箭头会被覆盖,这并非想要的。通过上网查找资料,这篇文章的方法简单可行。
文章链接:https://www.jianshu.com/p/25121c36f753
附注:如果觉得背景色太深不好看,可以使用android:alpha=“0.7”(数字可修改,为0~1之间的小数)来设置透明度。这里附上我的背景设置代码:
<?xml version="1.0" encoding="utf-8"?>
<layer-list xmlns:android="http://schemas.android.com/apk/res/android">
<!-- 第一组item:设置边框 -->
<item>
<shape>
<!-- 设置边框线宽度和颜色 -->
<stroke
android:width="0.5dp"
android:color="#ff66cc" >
</stroke>
<!-- 设置圆角度数 -->
<corners android:radius="20dp" />
<!-- 设置背景颜色 -->
<solid android:color="#ccccff" />
<!-- padding:设置边距 -->
<padding
android:bottom="5dp"
android:left="5dp"
android:right="5dp"
android:top="5dp" >
</padding>
</shape>
</item>
<!-- 第二组item:设置spinner箭头图片(替换默认箭头) -->
<item>
<!-- bitmap.gravity:设置spinner的箭头放置位置 -->
<!-- bitmap.src:设置替换原spinner的箭头的图片资源 -->
<bitmap
android:gravity="end"
android:src="@drawable/arrow_down">
</bitmap>
</item>
</layer-list>
修改字体大小、颜色
过程如下:
step1:写一个单独的布局文件personal_spinner.xml(自定义命名),里面只包含一个TextView,其作用是用来设置Spinner内文字的属性,比如大小、颜色等。该布局文件与activity_main.xml放在同一个文件夹下。
<?xml version="1.0" encoding="utf-8"?>
<TextView xmlns:android="http://schemas.android.com/apk/res/android"
android:id="@android:id/text1"
android:textColor="#000033"
android:textSize="30sp"
android:ellipsize="marquee"
android:singleLine="true"
android:textAlignment="inherit"
android:layout_width="match_parent"
android:layout_height="wrap_content" />
step2:在activity_main.xml(可以换成自己的activity)中定义一个spinner
<Spinner
android:id="@+id/select_number"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_gravity="center_vertical|top"
android:entries="@array/numbers"
android:background="@drawable/spinner_border"
android:alpha="0.7"
android:spinnerMode="dropdown"
android:textAlignment="center">
</Spinner>
step3:在MainActivity(可以换成自己的activity)中,使用ArrayAdapter进行绑定。
以下代码写在onCreate里。
//修改Spinner中的字体和颜色
Spinner mSpinner = (Spinner)findViewById(R.id.select_number);//根据id选中Spinner
String[] curs = getResources().getStringArray(R.array.numbers);//获取Spinner的选项
ArrayAdapter<String> adapter = new ArrayAdapter<String>(this,R.layout.personal_spinner, curs);//修改样式
adapter.setDropDownViewResource(R.layout.personal_spinner);
mSpinner.setAdapter(adapter);
ok,完工啦~
给大家看一下我的效果图: