分享1个模拟各种复杂的滑动或手势操作的方法,赶紧学起来~

版权声明:允许转载,但转载必须保留原链接;请勿用作商业或者非法用途
此文章来源于项目官方公众号:“AirtestProject”

前言

滑动操作千千万,你是否会遇到过使用 swipedrag_to 都实现不了的滑动情况?或者你有没有为手势操作不知道如何模拟而苦恼的时候呢?

比如模拟长按删除操作,再比如模拟安卓的多指手势操作等等,这些操作用 swipedrag_to 等方法,都不能满足大家的实际需求。

所以今天想跟大家一起来学习下airtest的 basetouch 模块。这个模块提供了很多 底层的 点击、滑动等操作,用这个模块的方法或者类,我们可以轻松模拟出各种 自定义 的点击、滑动甚至其它手势操作。下文我们将详细了解下这个模块以及如何在实际的应用场景中使用这个模块。

basetouch 模块介绍

我们常使用的 minitouchmaxtouch ,其共同的底层操作都来自于 basetouch

举个例子,之前我们在“用airtest做滑动解锁怎么搞?其实很简单!”这篇推文中,也有详细介绍过 basetouch 模块里面的一些接口:

  • 实现连续划过一系列坐标的 swipe_along 接口
  • 实现双指捏合操作的 pinch 接口
  • 实现双指同时滑动的 two_finger_swipe 接口

除了这些接口以外,今天我们重点要了解的是这个模块里面的4个类:

  • DownEvent(coordinates, contact=0, pressure=50)
  • UpEvent(contact=0)
  • MoveEvent(coordinates, contact=0, pressure=50)
  • SleepEvent(seconds)

调用这4个类,理论上可以拼接组合出来所有的手势操作。我们举个简单的例子:比如 touch 接口,就是先调用 DownEvent ,实现点下某个坐标点,然后再调用 SleepEvent,停顿0.01s, 最后调用 UpEvent,实现抬起操作,拼接这三个“event”,就组成了1个完整的 touch 操作。

案例1:长按删除某个应用

我们先来分解下长按删除应用的整个操作,首先是长按某个应用不松手,然后再把应用滑动到垃圾桶的位置,最后点击弹窗的确认按钮即可完成删除应用的操作。

如果使用封装好的接口来实现,先使用 long_click ,再使用 swipe ,是完成不了这个任务的。因为 long_click 实现的是 点下-停顿-抬起 的动作,而我们在把应用拖到删除应用的垃圾桶之前,是不能有抬起操作的。

所以对于长按删除应用的操作,我们可以使用 basetouch 里面的4个 “event” 来拼接:

image

from airtest.core.android.touch_methods.base_touch import *
dev = device()

# 案例一
# 长按删除应用
longtouch_event = [
    DownEvent([908, 892]),# 待删除应用的坐标
    SleepEvent(2),
    MoveEvent([165,285]),# 删除应用的垃圾桶坐标
    UpEvent(0)]

dev.touch_proxy.perform(longtouch_event)

# 取消卸载
poco("android:id/button2").click()

案例2:双指点击屏幕的不同坐标

模拟2个手指分别点击屏幕上的不同坐标,然后再松开2个手指。

image

# 案例二
# 双指点击屏幕
multitouch_event = [
    DownEvent([335, 1383], 0),
    DownEvent([629, 1345], 1),  # 第二根手指
    SleepEvent(1),
    UpEvent(0), UpEvent(1)]

dev.touch_proxy.perform(multitouch_event)
sleep(1.0)

案例3:模拟三指滑动

三根手指同时在设备屏幕上滑动一定距离。

image

# 案例三
# 三指滑动
swipe_event2 = [DownEvent((100, 300), 0), DownEvent((100, 500), 1), DownEvent((100, 700), 2), SleepEvent(0.1)]

for i in range(5):
    swipe_event2.append(MoveEvent((100 + 100*i, 300), 0))# 第一根手指
    swipe_event2.append(MoveEvent((100 + 100*i, 500), 1))# 第二根手指
    swipe_event2.append(MoveEvent((100 + 100*i, 700), 2))# 第三根手指
    swipe_event2.append(SleepEvent(0.2))

swipe_event2.append(UpEvent(0))
swipe_event2.append(UpEvent(1))
swipe_event2.append(UpEvent(2))

dev.touch_proxy.perform(swipe_event2)

使用小结

  • 使用 DownEventUpEventSleepEventMoveEvent,可以分别模拟按下、抬起、等待和移动这些基本操作;
  • 组合使用上述的“event”,可以模拟各种复杂的手势操作;
  • DownEvent((100, 300), 0) ,坐标后面的0代表第1根手指,依次类推, DownEvent((100, 500), 1) 坐标后面的1代表第2根手指;
  • 组合使用“event”的常见方式:把1个手势所需要的各个动作按顺序储存到1个列表(例如swipe_event)里面,最后使用 device().touch_proxy.perform(swipe_event)去执行这个动作列表,完成手势操作的模拟

Airtest官网:http://airtest.netease.com/
Airtest教程官网:https://airtest.doc.io.netease.com/
搭建企业私有云服务:https://airlab.163.com/b2b

Airtest官方答疑Q群:1017250147

  • 2
    点赞
  • 14
    收藏
    觉得还不错? 一键收藏
  • 9
    评论
在AccessibilityService中模拟执行用户操作手势可以使用GestureDescription类,该类可以创建包含多个滑动坐标的手势操作,并将其发送到系统。 以下是一个示例代码,演示如何在AccessibilityService中模拟执行一个包含多个滑动坐标的手势: ``` Path path = new Path(); path.moveTo(startX1, startY1); path.lineTo(endX1, endY1); path.moveTo(startX2, startY2); path.lineTo(endX2, endY2); GestureDescription.Builder builder = new GestureDescription.Builder(); builder.addStroke(new GestureDescription.StrokeDescription(path, 0, 100)); GestureDescription gesture = builder.build(); dispatchGesture(gesture, null, null); ``` 在上面的代码中,我们创建了一个包含两个滑动坐标的手势操作。其中,path对象用于描述手势的路径,每个滑动坐标都由一个moveTo方法和一个lineTo方法组成,分别表示手势的起始点和终止点。GestureDescription.Builder类用于创建手势操作,我们将path对象传递给它的addStroke方法,同时还可以指定手势的开始时间和持续时间。最后,我们通过调用dispatchGesture方法手势发送到系统。 需要注意的是,在使用AccessibilityService模拟执行用户操作手势时,需要确保用户已经开启了辅助功能权限,否则手势操作可能不会生效。同时,手势操作也需要满足一定的条件才能被系统识别,例如手势的路径不能太快或太慢,手势的起始点和终止点不能太远等。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值