def bezier_curve(sx, sy, ex, ey, cx, cy, part):
pointArr = []
changeX1 = (cx - sx) / part
changeY1 = (cy - sy) / part
# 控制点到结束点的 x 和 y 每次的增量
changeX2 = (ex - cx) / part
changeY2 = (ey - cy) / part
for i in range(part): # 计算两个动点的坐标
qx1 = sx + changeX1 * i
qy1 = sy + changeY1 * i
qx2 = cx + changeX2 * i
qy2 = cy + changeY2 * i
# 计算得到此时的一个贝塞尔曲线上的点坐标
bx = qx1 + (qx2 - qx1) * i / part
by = qy1 + (qy2 - qy1) * i / part
pointArr.append([bx, by])
return pointArr
window_size = driver.get_window_size()
screen_width = window_size['width']
screen_height = window_size['height']
point_list = bezier_curve(100,100, 100, 600, 200, 300, 10)
action_chains = ActionChains(driver)
action_chains.w3c_actions.pointer_action.move_to_location(point_list[0][0], point_list[0][1])
action_chains.w3c_actions.pointer_action.pointer_down()
for point in point_list[1:]:
action_chains.w3c_actions.pointer_action.move_to_location(point[0], point[1])
action_chains.w3c_actions.pointer_action.move_to_location(point_list[-1][0], point_list[-1][1])
action_chains.w3c_actions.pointer_action.pointer_up()
action_chains.w3c_actions.pointer_action._interval = 0
action_chains.perform()
time.sleep(2) # 等待几秒,便于观察曲线滑动效果
driver.quit()
如上代码实现了曲线滑动但是动作过程太慢了,请问各位前辈们有什么好的解决方法?