Android開發(fā)之自定義Spinner

自定義Spinner七兜,需要定制的有默認(rèn)背景丸凭、按下背景,顯示時(shí)每一項(xiàng)的樣式以及彈出時(shí)每一項(xiàng)的樣式四個(gè)方面腕铸。下面舉個(gè)簡(jiǎn)單例子惜犀。

</br>

1、準(zhǔn)備兩張圖片狠裹,處理為.9png虽界,分別為spinner.9.png和spinner_press.9.png,作為背景涛菠,如下圖所示

spinner.9.png

spinner_press.9.png

2莉御、在drawable中定義spinner_selector.xml,定義兩種狀態(tài)分別對(duì)應(yīng)上面兩種顏色

<?xml version="1.0" encoding="utf-8"?>
<selector xmlns:android="http://schemas.android.com/apk/res/android" >
    <item android:state_pressed="true"   
        android:drawable="@drawable/spinner_press" /><!--按下時(shí)效果-->  
    <item android:state_pressed="false"   
        android:drawable="@drawable/spinner" /><!--默認(rèn)效果-->   
</selector>

3俗冻、定義一個(gè)style礁叔,也可以直接放在布局中,我為了復(fù)用拿出來單獨(dú)定義了

<!-- spinner -->
<style name="spinner_style">
    <item name="android:background">@drawable/spinner_selector</item>
    <item name="android:paddingLeft">5dip</item>
</style>

4迄薄、在布局的Spinner中引用上述style

<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent">

    <Spinner
        android:id="@+id/field_item_spinner_content"
        style="@style/spinner_style"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:layout_centerInParent="true"
        android:layout_margin="10dp" />
</RelativeLayout>

5琅关、每一項(xiàng)的樣式 simple_spinner_item.xml

<?xml version="1.0" encoding="utf-8"?>
<CheckedTextView xmlns:android="http://schemas.android.com/apk/res/android"
    android:id="@android:id/text1"
    android:layout_width="fill_parent"
    android:layout_height="wrap_content"
    android:gravity="center_vertical"
    android:paddingLeft="5dip"
    android:paddingRight="5dip"
    android:singleLine="true"
    android:textColor="#808080" />

6、彈出時(shí)的每一項(xiàng)顯示布局 my_drop_down_item.xml

<?xml version="1.0" encoding="utf-8"?>
<TextView xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    android:padding="10dip"
    android:textColor="#000000"
    android:textSize="15dp" >
</TextView>

7讥蔽、定義一個(gè)字符數(shù)組涣易,作為數(shù)據(jù)顯示

<string-array name="meinv">
   <item>美女1</item>
   <item>美女2</item>
   <item>美女3</item>
   <item>美女4</item>
   <item>美女5</item>
   <item>美女6</item>
   <item>美女7</item>
</string-array>

8、Activity

public class MainActivity extends AppCompatActivity {

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);


        Spinner spinner = (Spinner) findViewById(R.id.field_item_spinner_content);

        //資源轉(zhuǎn)[]
        String meinv[] = getResources().getStringArray(R.array.meinv);

        //構(gòu)造ArrayAdapter
        ArrayAdapter<String> adapter = new ArrayAdapter<String>(this,
                R.layout.simple_spinner_item, meinv);
        //設(shè)置下拉樣式以后顯示的樣式
        adapter.setDropDownViewResource(R.layout.my_drop_down_item);

        spinner.setAdapter(adapter);
    }
}

9冶伞、測(cè)試效果

自定義Spinner.gif
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末都毒,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子碰缔,更是在濱河造成了極大的恐慌账劲,老刑警劉巖,帶你破解...
    沈念sama閱讀 217,657評(píng)論 6 505
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件金抡,死亡現(xiàn)場(chǎng)離奇詭異瀑焦,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)梗肝,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,889評(píng)論 3 394
  • 文/潘曉璐 我一進(jìn)店門榛瓮,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人巫击,你說我怎么就攤上這事禀晓【” “怎么了?”我有些...
    開封第一講書人閱讀 164,057評(píng)論 0 354
  • 文/不壞的土叔 我叫張陵粹懒,是天一觀的道長(zhǎng)重付。 經(jīng)常有香客問我,道長(zhǎng)凫乖,這世上最難降的妖魔是什么确垫? 我笑而不...
    開封第一講書人閱讀 58,509評(píng)論 1 293
  • 正文 為了忘掉前任,我火速辦了婚禮帽芽,結(jié)果婚禮上删掀,老公的妹妹穿的比我還像新娘。我一直安慰自己导街,他們只是感情好披泪,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,562評(píng)論 6 392
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著搬瑰,像睡著了一般款票。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上跌捆,一...
    開封第一講書人閱讀 51,443評(píng)論 1 302
  • 那天徽职,我揣著相機(jī)與錄音象颖,去河邊找鬼佩厚。 笑死,一個(gè)胖子當(dāng)著我的面吹牛说订,可吹牛的內(nèi)容都是我干的抄瓦。 我是一名探鬼主播,決...
    沈念sama閱讀 40,251評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼陶冷,長(zhǎng)吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼钙姊!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起埂伦,我...
    開封第一講書人閱讀 39,129評(píng)論 0 276
  • 序言:老撾萬榮一對(duì)情侶失蹤煞额,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后沾谜,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體膊毁,經(jīng)...
    沈念sama閱讀 45,561評(píng)論 1 314
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,779評(píng)論 3 335
  • 正文 我和宋清朗相戀三年八千,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了憨降。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片萎战。...
    茶點(diǎn)故事閱讀 39,902評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖栅螟,靈堂內(nèi)的尸體忽然破棺而出荆秦,到底是詐尸還是另有隱情,我是刑警寧澤力图,帶...
    沈念sama閱讀 35,621評(píng)論 5 345
  • 正文 年R本政府宣布步绸,位于F島的核電站,受9級(jí)特大地震影響搪哪,放射性物質(zhì)發(fā)生泄漏靡努。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,220評(píng)論 3 328
  • 文/蒙蒙 一晓折、第九天 我趴在偏房一處隱蔽的房頂上張望惑朦。 院中可真熱鬧,春花似錦漓概、人聲如沸漾月。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,838評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽梁肿。三九已至,卻和暖如春觅彰,著一層夾襖步出監(jiān)牢的瞬間吩蔑,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 32,971評(píng)論 1 269
  • 我被黑心中介騙來泰國打工填抬, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留烛芬,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 48,025評(píng)論 2 370
  • 正文 我出身青樓飒责,卻偏偏與公主長(zhǎng)得像赘娄,于是被迫代替她去往敵國和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子宏蛉,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,843評(píng)論 2 354

推薦閱讀更多精彩內(nèi)容