android 事件的坐标,Android如何基于坐标对View进行模拟点击事件详解

前言

大家应该都知道,在Android中,我们对于View进行模拟点击事件,很容易,比如调用View.performClick即可。

但是有些时候,我们想要更加精细的点击,比如View的某一区域或者某一点进行点击。比如下面的例子。

c76ee3ed6140e8b56bd693125dc4532c.png

上面是一个WebView加载了一个视频,我们必须手动点一下播放按钮才能让视频播放,当然我们想要的最好是如下的自动播放效果(进入界面后,自动播放视频)

88caec3eba92ee7ab9f8755aaac417b4.gif

当然方法有很多,比如通过javascript调用视频元素的click事件。在这里我们暂不对该方法进行细究。本文旨在提供一种解决问题的可行方法。

其实我们可以通过View.dispatchTouchEvent就能解决,因为一个click事件可以理解成一个Action_down和一个Action_up MotionEvent的组合,所以实现起来如下即可。

private fun simulateTouchEvent(view: View, x: Float, y: Float) {

val downTime = SystemClock.uptimeMillis()

val eventTime = SystemClock.uptimeMillis() + 100

val metaState = 0

val motionEvent = MotionEvent.obtain(downTime, eventTime,

MotionEvent.ACTION_DOWN, x, y, metaState)

view.dispatchTouchEvent(motionEvent)

val upEvent = MotionEvent.obtain(downTime + 1000, eventTime + 1000,

MotionEvent.ACTION_UP, x,y, metaState)

view.dispatchTouchEvent(upEvent)

}

关于坐标位置的选择,仔细分析你会发现,上面的视频的播放按钮其实是有特点的,播放按钮始终处于WebView的中心,即模拟的点击可以是WebView.getWidth/2和WebView.height/2这个点。

为了便于测试和验证模拟事件的成功,我们可以增加OnTouchListener进行验证,如下代码

webview?.setOnTouchListener { v, event ->

debugMessage("onTouchListener x=${event.x};y=${event.y}")

false

}

对于例子中的何时出发模拟事件,我们可以在WebView网页加载完成的时候实现,即

webview?.webViewClient = object : WebViewClient() {

override fun onPageFinished(view: WebView?, url: String?) {

super.onPageFinished(view, url)

webview?.post {

webview?.let {

simulateTouchEvent(it, it.width / 2f, it.height / 2f)

}

}

}

}

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,如果有疑问大家可以留言交流,谢谢大家对我们的支持。

您可能感兴趣的文章:

Android中父View和子view的点击事件处理问题探讨

Android 自定义view模板并实现点击事件的回调

时间: 2018-03-11

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值