自定义View之Switch

作者: 薛之涛 | 来源:发表于2018-11-18 15:46 被阅读9次

    今天我们来聊一下自定义Switch控件,我们先看一看Switch的相关属性:

    1.Switch相关属性

    • android:splitTrack:是否设置间隙让滑块与底部图片分隔开来
    • android:switchMinWidth:设置开关的最小宽度
    • android:switchPadding:设置滑块内文字的间隔
    • android:switchTextAppearance:设置开关的文字外观
    • android:textOff:按钮没有被选中时显示的文字
    • android:textOn:按钮被选中时显示的文字
    • android:showText:设置on/off的时候是否显示文字,如果不显示则textOn,textOff不起作用
    • android:textStyle:文字风格,粗体,斜体
    • android:track:滑块底部的背景图片,类似Background效果
    • android:thumb:滑块的图片

    2.Switch普通效果展示及监听

    2.1普通效果展示

    代码:


    image.png

    效果:


    1542502989411.gif

    那我们加入thumb和track属性看看效果,为了方便我们都用项目自带的机器人。效果如下:

    代码:


    image.png

    效果:


    1542502939538.gif

    不得不说真心丑,看来还得自定义。

    2.2监听
    image.png

    3.Switch的自定义

    自定义Switch的步骤如下:

    • 定义Switch的开关按钮状态
    • 定义一下Switch滑动轨道的状
    • 自定义文字颜色
    • 应用效果展示
    3.1定义Switch的开关按钮状态

    我们先定义thumb这个属性值,它有开关两种状态

    • 我们先定义打开的thumb的xml文件叫switch_custom_thumb_on


      image.png
    • 关闭thumb的xml的文件叫switch_custom_thumb_off


      image.png
    • 定义一个selector:switch_custom_thumb_selector


      image.png
    3.2 Switch滑动轨道的状态

    定义track这个属性值,它也有开启和关闭两种状态

    • 打开状态的track:switch_custom_track_on


      image.png
    • 关闭状态的track: switch_custom_track_off


      image.png
    • 定义一个selector:switch_custom_track_selector


      image.png

    补充:
    thumb和track默认大小是一致的,那如果我们想看起来thumb比tarck或者thumb比track小该怎么办呢?

    • 想track高度低于thumb高度就给track增加一个透明的边框。
    • 想track高度高于thumb按钮高度就给thumb按钮增加一个透明的边框。
    3.3 定义Switch文字的颜色

    定义switchTextAppearance这个属性值

    • 定义一个文本颜色状态的selector:switch_switchtextcolor_selector.xml
    image.png
    • 在style文件中定义一个样式叫 SwitchTextColorTheme的样式


      image.png
    3.3 定义Switch效果展示

    代码:


    image.png

    效果:

    1542526310848.gif

    基本也就这么多,告辞!

    相关文章

      网友评论

        本文标题:自定义View之Switch

        本文链接:https://www.haomeiwen.com/subject/zqoxxqtx.html