Compose实现状态选择器(原生drawable select标签效果) InteractionSource

前言

在Compose中做drawable shape是很方便的,比如加个圆角,加个边框之类的,只需要如下:

shape:

            Surface(
                shape = MaterialTheme.shapes.large,
                color = Color.Gray,
                modifier = Modifier.size(50.dp)
            ) {
            }

shape+边框:

            Surface(
                shape = MaterialTheme.shapes.large,
                border = BorderStroke(
                    width = 3.dp,
                    color = Color.Yellow,
                ),
                color = Color.Gray,
                modifier = Modifier.size(50.dp)
            ) {
            }

但是却没有很直接的select状态选择器

正文

于是我们就找一下文档+问群友,发现了一个稍微简单点做状态选择器的东西:InteractionSource

 ps:由于isSelect,isCheck,isEnable状态我们可以使用State对象很容易来实现,所以就不赘述了

我们来实现一下按下控件改变颜色的状态选择器

            val interactionSource = remember { MutableInteractionSource() }
            val isPressed by interactionSource.collectIsPressedAsState()//按下的状态
            Text(
                text = "按下我试试试试试试试试试试试试",
                color = if (isPressed) Color.Blue else Color.Cyan,//监听状态设置颜色
                modifier = M.clickable(
                    interactionSource = interactionSource,//设置
                    indication = LocalIndication.current//按下的指示器效果,当前是水波纹,null就没有东西了
                ) {
                    "123".showToast()
                }
            )

正常状态: 

按下状态:

只是找不到什么好的封装方式,貌似就只能这样用

 结语

好了,又水了一篇

这个InteractionSource也可以监听拖动,焦点,悬停事件,具体请参考官方文档: InteractionSource  |  Android Developers (google.cn)

对Kotlin或KMP感兴趣的同学可以进Q群 101786950

如果这篇文章对您有帮助的话

可以扫码请我喝瓶饮料或咖啡(如果对什么比较感兴趣可以在备注里写出来)

  • 2
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值