在UI中經(jīng)常會(huì)使用到下拉列表,在android控件中有兩個(gè)下拉列表控件:
- Spinner
- AppCompatSpinner 兼容低版本,在高版本中才能使用的方法換了V7下的Spinner后可以兼容到2.1,推薦使用這個(gè)。
使用步驟:
- 在布局中添加Spinner
- 設(shè)置數(shù)據(jù)源
- 設(shè)置顯示的主題
- 添加點(diǎn)擊的響應(yīng)事件
在xml中添加控件的使用:
<android.support.v7.widget.AppCompatSpinner
android:id="@+id/achievement_spinner_acs"
style="@style/spinner"
android:minHeight="45dip"
android:minWidth="140dip"
android:padding="@dimen/padding_size_two"
android:spinnerMode="dropdown"
android:theme="@style/spinnerHead"
app:layout_constraintTop_toBottomOf="@+id/achievement_title_view" />
主題:
<style name="spinnerHead" parent="Widget.AppCompat.DropDownItem.Spinner">
<item name="android:textColor">@color/colorSpinnerText</item>
<item name="android:textSize">14sp</item>
</style>
<style name="spinner" parent="Widget.AppCompat.DropDownItem.Spinner">
<item name="android:layout_width">wrap_content</item>
<item name="android:layout_height">wrap_content</item>
<!--設(shè)置 spinner 顯示位置往下偏移 actionBarSize 的高度, 默認(rèn)顯示是直接顯示在 Spinner 的選中項(xiàng)的上方-->
<item name="android:dropDownVerticalOffset">?attr/actionBarSize</item>
<!--設(shè)置選中之后Item 的背景變換 設(shè)置背景為 灰色背景色-->
<item name="android:dropDownSelector">@color/colorWhite</item>
<!--設(shè)置下拉框的 list 的樣式, 主要是設(shè)置 分割線, 當(dāng)然也可以設(shè)置下拉的 list 的背景顏色-->
<item name="android:dropDownListViewStyle">@style/spinnerListStyle</item>
<!--設(shè)置顯示在 popup 中 item(TextView) 的樣式-->
<item name="android:dropDownItemStyle">@style/itemSpinnerStyle</item>
</style>
<!--設(shè)置分割線-->
<style name="spinnerListStyle" parent="@android:style/Widget.ListView.DropDown">
<item name="android:divider">#c1bdbd</item>
<item name="android:dividerHeight">1dp</item>
</style>
<!--設(shè)置文本顏色 和大小-->
<style name="itemSpinnerStyle" parent="@android:style/Widget.TextView.SpinnerItem">
<item name="android:textColor">@color/colorWhite</item>
<item name="android:textSize">16sp</item>
</style>
這些都沒(méi)有達(dá)到我要的效果:
mSpinner = findViewById(R.id.achievement_spinner_acs) as AppCompatSpinner
val mData = ArrayList<String>()
mData.add("全部")
mData.add("已提貨")
mData.add("線下")
mData.add("門店")
val adapter = ArrayAdapter(mContext!!, android.R.layout.simple_spinner_item, mData)
adapter.setDropDownViewResource(android.R.layout.simple_spinner_dropdown_item)
mSpinner?.adapter = adapter
mSpinner?.onItemSelectedListener = object : AdapterView.OnItemSelectedListener {
override fun onItemSelected(parent: AdapterView<*>, view: View, position: Int, id: Long) {
//修改了字體的顏色,大小最好不要在這里設(shè)置了
val tv = view as TextView
tv.setTextColor(resources.getColor(R.color.colorSpinnerText))
// tv.setTextSize(12.0f)
}
override fun onNothingSelected(parent: AdapterView<*>) {
}
}
mSpinner?.setSelection(0)
屬性說(shuō)明:
mSpinner.setPopupBackgroundResource(R.drawable.back);//popUp顯示的背景顏色
mSpinner.setBackgroundResource(R.drawable.back); //顯示的背景顏色
android:entries // 傳入的是values文件夾下的arrayx.xml內(nèi)的數(shù)據(jù)
android:spinnerMode //顯示模式有popmenu和dialog兩種
android:prompt //當(dāng)顯示模式為dialog時(shí)生效,作用為顯示dialog的標(biāo)題內(nèi)容

其他屬性