自定义View之Switch

本文详细介绍自定义Switch控件的方法,包括定义开关按钮状态、滑动轨道状态、文字颜色等,通过实例代码展示了如何实现美观的Switch效果。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

今天我们来聊一下自定义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普通效果展示

代码:


6748497-4638d943b4258b75.png
image.png

效果:


6748497-bfc61cb9b46f0127.gif
1542502989411.gif

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

代码:


6748497-86417efecf44d0fa.png
image.png

效果:


6748497-393b8358c0fa4259.gif
1542502939538.gif

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

2.2监听
6748497-b26966adfcfd15f7.png
image.png
3.Switch的自定义

自定义Switch的步骤如下:

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

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

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


    6748497-86e1d7286691b900.png
    image.png
  • 关闭thumb的xml的文件叫switch_custom_thumb_off


    6748497-69106cb1a3a244b4.png
    image.png
  • 定义一个selector:switch_custom_thumb_selector


    6748497-8e5dfa6b8c0a753b.png
    image.png
3.2 Switch滑动轨道的状态

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

  • 打开状态的track:switch_custom_track_on


    6748497-3f85654ae6b59ae9.png
    image.png
  • 关闭状态的track: switch_custom_track_off


    6748497-23bfb0f66d953717.png
    image.png
  • 定义一个selector:switch_custom_track_selector


    6748497-ceafeec01024893e.png
    image.png

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

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

定义switchTextAppearance这个属性值

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


    6748497-20d33bea38f922a9.png
    image.png
3.3 定义Switch效果展示

代码:


6748497-3564c6958719d2f9.png
image.png

效果:

6748497-98941a704fa9d845.gif
1542526310848.gif

基本也就这么多,告辞!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

薛之涛

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值