appium里的滑动和拖拽,滑动解锁,手机滑动接电话。

1. 滑动和拖拽
我们在做自动化测试的时候,有些按钮是需要滑动几次屏幕后才会出现,此时,我们需要使用代码来模拟手指的滑动,也就是接下来要学的滑动和拖拽了。

1.1 swipe滑动事件
从一个坐标位置滑动到另一个坐标位置,只能是两个点之间的滑动。

方法:

driver.swipe(start_x, start_y, end_x, end_y, duration=None):参数分别是起点坐标的x,y和终点坐标的x,y,以及滑动时间,滑动事件的单位是ms。

实例1:

模拟手指从(100,2000),滑动到(100,1000)的位置。

driver.swipe(100, 2000, 100, 1000)

实例2:

模拟手指从(100, 2000),滑动到(100, 100)的位置。

driver.swipe(100, 2000, 100, 100)

实例3:

模拟手指从(100, 2000),滑动到(100, 100)的位置,持续5秒。

driver.swipe(100, 2000, 100, 100, 5000)

距离相同时,持续时间越长,惯性越小。

持续时间相同时,手指滑动的距离越大,实际滑动的距离也就越大。

1.2 scroll滚动事件
从一个元素滑动到另一个元素,直到页面自动停止。

方法:

driver.scroll(origin_el, destination_el):参数分别是滑动开始的元素和滑动结束的元素。

实例:

从“存储”滑动到“更多”。

save_button = driver.find_element_by_xpath("//*[@text='存储']")
more_button = driver.find_element_by_xpath("//*[@text='更多']")
driver.scroll(save_button, more_button)
#不能设置持续时间,惯性很大。

不能设置持续时间,惯性很大。

1.3 drag_and_drop拖拽事件
从一个元素滑动到另一个元素,第二个元素代替第一个元素原本屏幕上的位置。

方法:

driver.drag_and_drop(origin_el, destination_el):参数分别是滑动开始的元素和滑动结束的元素。

将“存储”拖拽到“更多”。

save_button = driver.find_element_by_xpath("//*[@text='存储']")
more_button = driver.find_element_by_xpath("//*[@text='更多']")
driver.drag_and_drop(save_button, more_button)
#不能设置持续时间,没有惯性

不能设置持续时间,没有惯性

1.4 滑动和拖拽的选择
滑动和拖拽无非就是考虑是否具有“惯性”,以及传递的参数是“元素”还是“坐标”。

可以分为四种情况:

有 “惯性” ,传入 “元素”:scroll。

无 “惯性” ,传入 “元素”:drag_and_drop。

有 “惯性” ,传入 “坐标”:swipe,并且设置较短的duration时间。

无 “惯性” ,传入 “坐标”:swipe,并且设置较长的duration时间。

1.5手指移动操作
模拟手机的滑动操作(滑动解锁)
方法:
move_to(el=None, x=None, y=None)这里的x,y为前一个坐标的偏移量
参数:
1.el:定位的元素
2.x:相对于前一个元素的x轴偏移量
3.y:相对于前一个元素的y轴偏移量

# 定位到存储
el = driver.find_element_by_xpath("//*[contains(@text,'存储')]")
# 定位到更多
el1 = driver.find_element_by_xpath("//*[contains(@text,'更多')]")
# 元素方式滑动
TouchAction(driver).press(el).move_to(el1).release().perform()
# 坐标的方式向上滑动
# TouchAction(driver).press(x=240,y=1000).move_to(x=0,y=-400).release().perform() 
# press().move_to() 实际使用的是TouchAction方法,需要给相对坐标.
# TouchAction(driver).press(x=240,y=600).wait(100).move_to(x=240,y=100).release().perform()
# press().wait().move_to()实际调用的是swip方法,会向下拉,感觉属于bug,可在log中查询swip,不建议这么用.

业务场景2:
1.进入设置
2.向上滑动屏幕到可见"安全"选项
3.进入到安全
4.点击屏幕锁定方式
5.点击图案
6.绘制图案


 # 定位到WLAN
        el1 = driver.find_element_by_xpath("//*[contains(@text,'WLAN')]")
        # 定位到存储
        el2 = driver.find_element_by_xpath("//*[contains(@text,'存储')]")
        # 存储上滑到WLAN
        driver.drag_and_drop(el2,el1)
        # 定位到用户
        el3 = driver.find_element_by_xpath("//*[contains(@text,'用户')]")
        # 注意 这次使用drag_and_drop方法,传入的"存储定位"仍使用其原始在屏幕上的位置,所以是由存储滑动到用户才可以上滑,否则需要重新"定位存储"
        # 存储上滑倒用户位置
        driver.drag_and_drop(el2,el3)
        # 点击安全按钮
        driver.find_element_by_xpath("//*[contains(@text,'安全')]").click()
        # 点击屏幕锁定方式按钮
        driver.find_element_by_xpath("//*[contains(@text,'屏幕锁定')]").click()
        # 点击图案按钮
        driver.find_element_by_xpath("//*[contains(@text,'图案')]").click()
        # 绘制图案四个坐标 1:(244,967) 2:(723,967) 3:(723,1442) 4:(244,1916)
        TouchAction(driver).press(x=244,y=967).wait(100).move_to(x=479,y=0).wait(100)\
            .move_to(x=0,y=475).wait(100).move_to(x=-479,y=474).release().perform()

  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值