Android自定義Switch

前言

由于最近需要實(shí)現(xiàn)一個(gè)自定義的switch奕翔,本想寫(xiě)一個(gè)MySwitch繼承Switch來(lái)進(jìn)行自定義降盹,但是后來(lái)發(fā)現(xiàn)其實(shí)只需要通過(guò)定義switch的thumb和track的圖片來(lái)達(dá)到自定義switch樣式的目的护戳。

關(guān)閉樣式.jpeg
開(kāi)啟樣式.jpeg

實(shí)現(xiàn)

1.定義track

track即滑動(dòng)的軌道金闽。

在res/drawable內(nèi)先定義一個(gè)軌道關(guān)閉狀態(tài)的drawable隧饼,switch_gray_track.xml

<?xml version="1.0" encoding="utf-8"?>
<shape xmlns:android="http://schemas.android.com/apk/res/android"
    android:shape="rectangle" >
    <!-- switch的高度-->
    <size android:height="20dp"/>
    <corners android:radius="10dp"/>
    <solid android:color="#D9D9D9" />
</shape>

再定義一個(gè)軌道開(kāi)啟狀態(tài)的drawable乖菱,switch_yellow_track.xml

<?xml version="1.0" encoding="utf-8"?>
<shape xmlns:android="http://schemas.android.com/apk/res/android"
    android:shape="rectangle">
    <size android:height="20dp" />
    <corners android:radius="10dp" />
    <solid android:color="#FECD15" />
</shape>

最后定義一個(gè)selector作為軌道的樣式乖寒,switch_track.xml

<?xml version="1.0" encoding="utf-8"?>
<selector xmlns:android="http://schemas.android.com/apk/res/android">
    <item android:drawable="@drawable/switch_yellow_track" android:state_checked="true" />
    <item android:drawable="@drawable/switch_gray_track" />
</selector>

2.定義thumb

thumb即滑動(dòng)塊蒙秒。

在res/drawable內(nèi)定義一個(gè)滑動(dòng)塊的drawable,switch_thumb.xml

<?xml version="1.0" encoding="utf-8"?>
<shape xmlns:android="http://schemas.android.com/apk/res/android"
    android:shape="oval">
    <!-- 滑動(dòng)塊的寬高 -->
    <size
        android:width="20dp"
        android:height="20dp" />
    <solid android:color="#FFFFFF" />
    <!-- 透明的描邊-->
    <stroke android:width="3dp"
        android:color="@android:color/transparent"/>
</shape>

增加了一個(gè)透明的描邊宵统,不然白色的小滑塊就完全覆蓋掉了外面的軌道晕讲。

3.設(shè)置Switch

修改android:layout_width,android:layout_height 這兩個(gè)屬性马澈,并不會(huì)實(shí)際修改Switch的大小設(shè)置大了瓢省,邊上會(huì)出現(xiàn)空白部分,設(shè)置小了痊班,Switch顯示不全勤婚。

Switch的高度是由track的高度決定的,寬度呢則可以通過(guò)設(shè)置switchMinWidth(開(kāi)關(guān)最小寬度 )來(lái)更改涤伐。

    <Switch
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:switchMinWidth="20dp"
        android:track="@drawable/switch_track"
        android:thumb="@drawable/switch_thumb"/>

源碼

github: https://github.com/JeremySun823/MySwitchTest

參考鏈接

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末馒胆,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子凝果,更是在濱河造成了極大的恐慌祝迂,老刑警劉巖,帶你破解...
    沈念sama閱讀 221,576評(píng)論 6 515
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件器净,死亡現(xiàn)場(chǎng)離奇詭異型雳,居然都是意外死亡,警方通過(guò)查閱死者的電腦和手機(jī)山害,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 94,515評(píng)論 3 399
  • 文/潘曉璐 我一進(jìn)店門(mén)纠俭,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái),“玉大人浪慌,你說(shuō)我怎么就攤上這事冤荆。” “怎么了权纤?”我有些...
    開(kāi)封第一講書(shū)人閱讀 168,017評(píng)論 0 360
  • 文/不壞的土叔 我叫張陵钓简,是天一觀的道長(zhǎng)乌妒。 經(jīng)常有香客問(wèn)我,道長(zhǎng)涌庭,這世上最難降的妖魔是什么芥被? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 59,626評(píng)論 1 296
  • 正文 為了忘掉前任欧宜,我火速辦了婚禮坐榆,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘冗茸。我一直安慰自己席镀,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 68,625評(píng)論 6 397
  • 文/花漫 我一把揭開(kāi)白布夏漱。 她就那樣靜靜地躺著豪诲,像睡著了一般。 火紅的嫁衣襯著肌膚如雪挂绰。 梳的紋絲不亂的頭發(fā)上屎篱,一...
    開(kāi)封第一講書(shū)人閱讀 52,255評(píng)論 1 308
  • 那天,我揣著相機(jī)與錄音葵蒂,去河邊找鬼交播。 笑死,一個(gè)胖子當(dāng)著我的面吹牛践付,可吹牛的內(nèi)容都是我干的秦士。 我是一名探鬼主播,決...
    沈念sama閱讀 40,825評(píng)論 3 421
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼永高,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼隧土!你這毒婦竟也來(lái)了?” 一聲冷哼從身側(cè)響起命爬,我...
    開(kāi)封第一講書(shū)人閱讀 39,729評(píng)論 0 276
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤曹傀,失蹤者是張志新(化名)和其女友劉穎,沒(méi)想到半個(gè)月后饲宛,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體卖毁,經(jīng)...
    沈念sama閱讀 46,271評(píng)論 1 320
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡仰坦,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 38,363評(píng)論 3 340
  • 正文 我和宋清朗相戀三年些己,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片辉阶。...
    茶點(diǎn)故事閱讀 40,498評(píng)論 1 352
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡练链,死狀恐怖翔脱,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情媒鼓,我是刑警寧澤届吁,帶...
    沈念sama閱讀 36,183評(píng)論 5 350
  • 正文 年R本政府宣布错妖,位于F島的核電站,受9級(jí)特大地震影響疚沐,放射性物質(zhì)發(fā)生泄漏暂氯。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,867評(píng)論 3 333
  • 文/蒙蒙 一亮蛔、第九天 我趴在偏房一處隱蔽的房頂上張望痴施。 院中可真熱鬧,春花似錦究流、人聲如沸辣吃。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 32,338評(píng)論 0 24
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)神得。三九已至,卻和暖如春偷仿,著一層夾襖步出監(jiān)牢的瞬間哩簿,已是汗流浹背。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 33,458評(píng)論 1 272
  • 我被黑心中介騙來(lái)泰國(guó)打工酝静, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留节榜,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 48,906評(píng)論 3 376
  • 正文 我出身青樓形入,卻偏偏與公主長(zhǎng)得像全跨,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子亿遂,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,507評(píng)論 2 359

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