Android扩大View点击区域方案示例

 更新时间:2023年08月03日 14:38:06   作者:寻水的鱼Chock  
这篇文章主要为大家介绍了Android扩大View点击区域方案示例,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪

1、前言

开发过程中经常会遇到如下这种场景,对于CheckBox而言,整体较小,然后为了用户体验--“好点”,往往需要扩大点击区域。通常的做法就是给CheckBox增加Padding以达到扩大点击区域的目的,但是为了对齐UI,往往需要一通计算跟调整才能“如愿以偿”,可谓哭笑不得。那怎么样可以优雅的解决这个问题呢?

可以配合BindingAdapter实现在xml上的直接处理。

2、解决方案

2.1、直接上代码

@BindingAdapter("expandTouchArea")
fun expandTouchArea(view: View, size: String) {
    view.postDelayed({
        val bounds = Rect()
        view.getHitRect(bounds)
        var left = 0
        var top = 0
        var right = 0
        var bottom = 0
        /*
        *  size 举例 `2` or `2 4` or `2 4 6 8`
         */
        val mSize = size.trim()
        val ss = mSize.split(" ")
        when (ss.size) {
            1 -> {
                val sdp = (ss[0].toIntOrNull() ?: 0).idp()
                left = sdp
                top = sdp
                right = sdp
                bottom = sdp
            }
            2 -> {
                val sdp = (ss[0].toIntOrNull() ?: 0).idp()
                val sdp1 = (ss[1].toIntOrNull() ?: 0).idp()
                left = sdp
                top = sdp1
                right = sdp
                bottom = sdp1
            }
            4 -> {
                left = (ss[0].toIntOrNull() ?: 0).idp()
                top = (ss[1].toIntOrNull() ?: 0).idp()
                right = (ss[2].toIntOrNull() ?: 0).idp()
                bottom = (ss[3].toIntOrNull() ?: 0).idp()
            }
            else -> {
                return@postDelayed
            }
        }
        bounds.left -= left
        bounds.top -= top
        bounds.right += right
        bounds.bottom += bottom
        val mTouchDelegate = TouchDelegate(bounds, view);
        val p = view.parent
        if (p is ViewGroup) {
            p.touchDelegate = mTouchDelegate;
        }
    }, 100)
}

 其中idp()是dp转px的转换函数(Kotlin扩展),实际使用时请替换。

2.2、使用示例:

<CheckBox
    android:layout_width="14dp"
    android:layout_height="14dp"
    android:background="@drawable/ic_cb_common"
    android:button="@null"
    android:checked="false"
    app:expandTouchArea="@{`20 10 50 20`}"/>

2.3、参数解析

//表示在View原有范围的基础上在四周增加20dp的区域
app:expandTouchArea="@{`20`}
//表示在View原有范围的基础上左右增加20dp, 上下增加10dp的区域
app:expandTouchArea="@{`20 10`}
//表示在View原有范围的基础上, 左上右下分别增加20dp 10dp 50dp 20dp的区域
app:expandTouchArea="@{`20 10 50 20`}

2.4、注意事项

1、若View的自定义触摸范围超出View.parent的大小,则超出的那部分无效。

2、一个ViewGroup里只能设置一个,设置多个时只有最后设置的那个有效。(也可以多个,需要自定义ViewGroup

3、只有设置那个View的View.parent接收到点击事件时才能触发,也就是说这个区域是可以被其他View遮挡的,so被遮挡时也无效。

以上就是Android扩大View点击区域方案示例的详细内容,更多关于Android扩大View点击区域的资料请关注脚本之家其它相关文章!

相关文章

  • Android 实现九宫格抽奖功能

    Android 实现九宫格抽奖功能

    这篇文章主要介绍了Android 实现九宫格抽奖功能,帮助大家更好的理解和学习使用Android,感兴趣的朋友可以了解下
    2021-03-03
  • Android Webview的postUrl与loadUrl加载页面实例

    Android Webview的postUrl与loadUrl加载页面实例

    这篇文章主要介绍了Android Webview的postUrl与loadUrl加载页面实例,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2020-03-03
  • Android中wifi与数据流量的切换监听详解

    Android中wifi与数据流量的切换监听详解

    本文主要介绍了Android中wifi与数据流量的切换监听的方法步骤。具有一定的参考价值,下面跟着小编一起来看下吧
    2017-01-01
  • Android 串口通信编程及串口协议分析

    Android 串口通信编程及串口协议分析

    这篇文章主要介绍了Android 串口通信编程及串口协议分析的相关资料,这里对Android 串口通信进行详解,及简单实现步骤和协议进行分析,需要的朋友可以参考下
    2016-11-11
  • Android仿支付宝微信支付密码界面弹窗封装dialog

    Android仿支付宝微信支付密码界面弹窗封装dialog

    这篇文章主要介绍了Android仿支付宝微信支付密码界面弹窗封装dialog的实例代码,非常不错,具有参考借鉴价值,需要的朋友可以参考下
    2017-03-03
  • Android EditText实现输入金额类型详解

    Android EditText实现输入金额类型详解

    EditText是Android中一个非常实用的控件,有很多InputType,可以来达到不同的输入效果,下面这篇文章主要给大家介绍了关于Android EditText实现输入金额类型的相关资料,需要的朋友可以参考借鉴,下面来一起看看吧。
    2017-09-09
  • Kotlin高阶函数reduce与fold使用实例

    Kotlin高阶函数reduce与fold使用实例

    Kotlin的高阶函数reduce和fold可以用来对集合进行聚合操作。reduce函数将集合元素逐个累加,而fold函数则可以指定一个初始值进行累加。这两个函数在处理大数据集时非常有用
    2023-04-04
  • Android自定义View实现左右滑动选择出生年份

    Android自定义View实现左右滑动选择出生年份

    这篇文章主要介绍了Android自定义View实现左右滑动选择出生年份,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2016-06-06
  • Android Studio常用快捷键功能说明

    Android Studio常用快捷键功能说明

    本文给大家收藏整理了关于Android Studio常用快捷键功能说明,需要的朋友可以参考下
    2017-10-10
  • Android端代码量非常小的分页加载库

    Android端代码量非常小的分页加载库

    这篇文章主要给大家介绍了关于Android端代码量非常小的分页加载库的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2021-03-03

最新评论