微信跳一跳辅助的python具体实现代码,供大家参考,具体内容如下
这是一个 2.5D 插画风格的益智游戏,玩家可以通过按压屏幕时间的长短来控制这个「小人」跳跃的距离。可能刚开始上手的时候,因为时间距离之间的关系把握不恰当,只能跳出几个就掉到了台子下面。
玩法类似于《flappy bird》
下载github的一个程序,但是在windows10下不能运行,原因是windows10下没有copy命令了,修改为Python自带的复制方法,即可完成。今天运行好像一开始不能正确跳第一次,人工辅助后,后续的跳的很好。
部分代码:
wechat_jump_iOS_py3.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
|
import wda
import numpy as np
import matplotlib.pyplot as plt
import matplotlib.animation as animation
from PIL import Image
import math
import time
import os
# 截图距离 * time_coefficient = 按键时长
# 此数据是 iPhoneX 的推荐系数,可根据手机型号进行调整
time_coefficient = 0.00125
c = wda.Client()
s = c.session()
def pull_screenshot():
c.screenshot( '1.png' )
def jump(distance):
press_time = distance * time_coefficient
press_time = press_time
print (press_time)
s.tap_hold( 200 , 200 ,press_time)
fig = plt.figure()
index = 0
cor = [ 0 , 0 ]
pull_screenshot()
img = np.array(Image. open ( '1.png' ))
update = True
click_count = 0
cor = []
def update_data():
return np.array(Image. open ( '1.png' ))
im = plt.imshow(img, animated = True )
def updatefig( * args):
global update
if update:
time.sleep( 1 )
pull_screenshot()
im.set_array(update_data())
update = False
return im,
def onClick(event):
global update
global ix, iy
global click_count
global cor
# next screenshot
ix, iy = event.xdata, event.ydata
coords = []
coords.append((ix, iy))
print ( 'now = ' , coords)
cor.append(coords)
click_count + = 1
if click_count > 1 :
click_count = 0
cor1 = cor.pop()
cor2 = cor.pop()
distance = (cor1[ 0 ][ 0 ] - cor2[ 0 ][ 0 ]) * * 2 + (cor1[ 0 ][ 1 ] - cor2[ 0 ][ 1 ]) * * 2
distance = distance * * 0.5
print ( 'distance = ' , distance)
jump(distance)
update = True
fig.canvas.mpl_connect( 'button_press_event' , onClick)
ani = animation.FuncAnimation(fig, updatefig, interval = 50 , blit = True )
plt.show()
|
wechat_jump_py3.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
|
import numpy as np
import matplotlib.pyplot as plt
import matplotlib.animation as animation
from PIL import Image
import math
import time
import os
def pull_screenshot():
os.system( 'adb shell screencap -p /sdcard/1.png' )
os.system( 'adb pull /sdcard/1.png .' )
def jump(distance):
press_time = distance * 1.35
press_time = int (press_time)
cmd = 'adb shell input swipe 320 410 320 410 ' + str (press_time)
print (cmd)
os.system(cmd)
fig = plt.figure()
index = 0
cor = [ 0 , 0 ]
pull_screenshot()
img = np.array(Image. open ( '1.png' ))
update = True
click_count = 0
cor = []
def update_data():
return np.array(Image. open ( '1.png' ))
im = plt.imshow(img, animated = True )
def updatefig( * args):
global update
if update:
time.sleep( 1.5 )
pull_screenshot()
im.set_array(update_data())
update = False
return im,
def onClick(event):
global update
global ix, iy
global click_count
global cor
# next screenshot
ix, iy = event.xdata, event.ydata
coords = []
coords.append((ix, iy))
print ( 'now = ' , coords)
cor.append(coords)
click_count + = 1
if click_count > 1 :
click_count = 0
cor1 = cor.pop()
cor2 = cor.pop()
distance = (cor1[ 0 ][ 0 ] - cor2[ 0 ][ 0 ]) * * 2 + (cor1[ 0 ][ 1 ] - cor2[ 0 ][ 1 ]) * * 2
distance = distance * * 0.5
print ( 'distance = ' , distance)
jump(distance)
update = True
fig.canvas.mpl_connect( 'button_press_event' , onClick)
ani = animation.FuncAnimation(fig, updatefig, interval = 50 , blit = True )
plt.show()
|
原理说明
1. 将手机点击到《跳一跳》小程序界面;
2. 用Adb 工具获取当前手机截图,并用adb将截图pull上来
```shell
adb shell screencap -p /sdcard/1.png
adb pull /sdcard/1.png .
```
3. 用matplot显示截图;
4. 用鼠标点击起始点和目标位置,计算像素距离;
5. 根据像素距离,计算按压时间;
6. 用Adb工具点击屏幕蓄力一跳;
代码较多,直接为大家分享源码下载链接,很详细:微信跳一跳辅助python代码实现
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持服务器之家。