滑动和拖拽事件

滑动和拖拽事件

应用场景

有些按钮是需要滑动几次屏幕后才会出现,此时,我们需要使用代码来模拟手指的滑动

swipe滑动事件

概念

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

方法名

#参数:
#start_x:	起点X轴坐标
#start_y:	起点Y轴坐标
#end_x:	终点X轴坐标
#end_y:	终点Y轴坐标
#duration: 滑动这个操作一共持续的时间长度,单位:ms
driver.swipe(start_x, start_y, end_x, end_y, duration=None)

Demo

#模拟手指从(100,1500),滑动到(100,500)
driver.swipe(100,1500,100,500)
#模拟手指从(100,1500),滑动到(100,100)
driver.swipe(100,1500,100,100)
#模拟手指从(100,1500),滑动到(100,100),持续5秒
driver.swipe(100,1500,100,100,5000)

注意点

  • 距离相同时,持续时间越长,惯性越小
  • 持续时间相同时,手指滑动的距离越大,实际滑动的距离也就越大
  • 模拟的手指位置不能超过手机分辨率,否则无反应或报错

scroll滑动事件

概念

从一个元素滑动到另一个元素,直到页面自动停止

方法名

#参数:
#origin_el:	滑动开始的元素
#destination_el:	滑动结束的元素
driver.scroll(origin_el, destination_el)

示例

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

核心代码

button1 = driver.find_element(By.XPATH"//*[@text='通知']")

button2 = driver.find_element(By.XPATH"//*[@text='WLAN']")

driver.scroll(button1, button2)

小结

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

drag_and_drop拖拽事件

概念

从一个元素滑动到另一个元素,第二个元素替代第一个元素原本屏幕上的位置。

方法名

#参数:
#origin_el:	滑动开始的元素
#destinatfon_el: 	滑动结束的元素
driver.drag_and_drop(origin_el, destination_el)

示例

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

核心代码

button1 = driver.find_element(By.XPATH"//*[@text='通知']")

button2 = driver.find_element(By.XPATH"//*[@text='WLAN']")

driver.drag_and_drop(button1, button2)

小结

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

事件选择

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

可以分成以下四种情况

  • 有“惯性”,传入“元素”

    • scroll
  • 无“惯性”,传入“元素”

    • drag_and_drop
  • 有“惯性”,传入“坐标”

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

    • swipe,并且设置较长的duration时间
posted @   璀璨如歌  阅读(38)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· 阿里巴巴 QwQ-32B真的超越了 DeepSeek R-1吗?
· 【译】Visual Studio 中新的强大生产力特性
· 【设计模式】告别冗长if-else语句:使用策略模式优化代码结构
· 10年+ .NET Coder 心语 ── 封装的思维:从隐藏、稳定开始理解其本质意义
欢迎阅读『滑动和拖拽事件』
点击右上角即可分享
微信分享提示