微信跳一跳辅助的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代码实现
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持服务器之家。