2024年Python最全用Python做一个游戏辅助脚本,完整编程思路分享(1)

学习这样一个游戏辅助脚本,对于个人培养编程兴趣也是有很多帮助的,在工作之余不失为一个好的消遣方式,以后会多向这些方向研究学习。本案例仅仅是截图、比较图片和模拟鼠标点击,我觉得还可以更加强大,而且还不局限于游戏这样一个领域,相信大家应该见过自动发QQ消息的软件吧,我觉得这完全可以做。还有很多模拟操作可以实现:鼠标滚轮,左右键、键盘输入等。

六、附件-源码

注意:源码仅供学习

1 # -- coding:utf-8 --

2

3 import win32gui

4 import time

5 from PIL import ImageGrab, Image

6 import numpy as np

7 import operator

8 from pymouse import PyMouse

9

10

11 class GameAssist:

12

13 def init(self, wdname):

14 “”“初始化”“”

15

16 # 取得窗口句柄

17 self.hwnd = win32gui.FindWindow(0, wdname)

18 if not self.hwnd:

19 print(“窗口找不到,请确认窗口句柄名称:【%s】” % wdname )

20 exit()

21

22 # 窗口显示最前面

23 win32gui.SetForegroundWindow(self.hwnd)

24

25 # 小图标编号矩阵

26 self.im2num_arr = []

27

28 # 主截图的左上角坐标和右下角坐标

29 self.scree_left_and_right_point = (299, 251, 768, 564)

30 # 小图标宽高

31 self.im_width = 39

32

33 # PyMouse对象,鼠标点击

34 self.mouse = PyMouse()

35

36 def screenshot(self):

37 “”“屏幕截图”“”

38

39 # 1、用grab函数截图,参数为左上角和右下角左标

40 # image = ImageGrab.grab((417, 257, 885, 569))

41 image = ImageGrab.grab(self.scree_left_and_right_point)

42

43 # 2、分切小图

44 # exit()

45 image_list = {}

46 offset = self.im_width # 39

47

48 # 8行12列

49 for x in range(8):

50 image_list[x] = {}

51 for y in range(12):

52 # print(“show”,x, y)

53 # exit()

54 top = x * offset

55 left = y * offset

56 right = (y + 1) * offset

57 bottom = (x + 1) * offset

58

59 # 用crop函数切割成小图标,参数为图标的左上角和右下角左边

60 im = image.crop((left, top, right, bottom))

61 # 将切割好的图标存入对应的位置

62 image_list[x][y] = im

63

64 return image_list

65

66 def image2num(self, image_list):

67 “”“将图标矩阵转换成数字矩阵”“”

68

69 # 1、创建全零矩阵和空的一维数组

70 arr = np.zeros((10, 14), dtype=np.int32) # 以数字代替图片

71 image_type_list = []

72

73 # 2、识别出不同的图片,将图片矩阵转换成数字矩阵

74 for i in range(len(image_list)):

75 for j in range(len(image_list[0])):

76 im = image_list[i][j]

77

78 # 验证当前图标是否已存入

79 index = self.getIndex(im, image_type_list)

80

81 # 不存在image_type_list

82 if index < 0:

83 image_type_list.append(im)

84 arr[i + 1][j + 1] = len(image_type_list)

85 else:

86 arr[i + 1][j + 1] = index + 1

87

88 print(“图标数:”, len(image_type_list))

89

90 self.im2num_arr = arr

91 return arr

92

93 # 检查数组中是否有图标,如果有则返回索引下表

94 def getIndex(self,im, im_list):

95 for i in range(len(im_list)):

96 if self.isMatch(im, im_list[i]):

97 return i

98

99 return -1

100

101 # 汉明距离判断两个图标是否一样

102 def isMatch(self, im1, im2):

103

104 # 缩小图标,转成灰度

105 image1 = im1.resize((20, 20), Image.ANTIALIAS).convert(“L”)

106 image2 = im2.resize((20, 20), Image.ANTIALIAS).convert(“L”)

107

108 # 将灰度图标转成01串,即系二进制数据

109 pixels1 = list(image1.getdata())

110 pixels2 = list(image2.getdata())

111

112 avg1 = sum(pixels1) / len(pixels1)

113 avg2 = sum(pixels2) / len(pixels2)

114 hash1 = “”.join(map(lambda p: “1” if p > avg1 else “0”, pixels1))

115 hash2 = “”.join(map(lambda p: “1” if p > avg2 else “0”, pixels2))

116

117 # 统计两个01串不同数字的个数

118 match = sum(map(operator.ne, hash1, hash2))

119

120 # 阀值设为10

121 return match < 10

122

123 # 判断矩阵是否全为0

124 def isAllZero(self, arr):

125 for i in range(1, 9):

126 for j in range(1, 13):

127 if arr[i][j] != 0:

128 return False

129 return True

130

131 # 是否为同行或同列且可连

132 def isReachable(self, x1, y1, x2, y2):

133 # 1、先判断值是否相同

134 if self.im2num_arr[x1][y1] != self.im2num_arr[x2][y2]:

135 return False

136

137 # 1、分别获取两个坐标同行或同列可连的坐标数组

138 list1 = self.getDirectConnectList(x1, y1)

139 list2 = self.getDirectConnectList(x2, y2)

140 # print(x1, y1, list1)

141 # print(x2, y2, list2)

142

143 # exit()

144

145 # 2、比较坐标数组中是否可连

146 for x1, y1 in list1:

147 for x2, y2 in list2:

148 if self.isDirectConnect(x1, y1, x2, y2):

149 return True

150 return False

151

152 # 获取同行或同列可连的坐标数组

153 def getDirectConnectList(self, x, y):

154

155 plist = []

156 for px in range(0, 10):

157 for py in range(0, 14):

158 # 获取同行或同列且为0的坐标

159 if self.im2num_arr[px][py] == 0 and self.isDirectConnect(x, y, px, py):

160 plist.append([px, py])

161

162 return plist

163

164 # 是否为同行或同列且可连

165 def isDirectConnect(self, x1, y1, x2, y2):

166 # 1、位置完全相同

167 if x1 == x2 and y1 == y2:

168 return False

169

170 # 2、行列都不同的

171 if x1 != x2 and y1 != y2:

172 return False

173

174 # 3、同行

175 if x1 == x2 and self.isRowConnect(x1, y1, y2):

176 return True

177

178 # 4、同列

179 if y1 == y2 and self.isColConnect(y1, x1, x2):

180 return True

181

182 return False

183

184 # 判断同行是否可连

185 def isRowConnect(self, x, y1, y2):

186 minminY = min(y1, y2)

187 maxmaxY = max(y1, y2)

188

189 # 相邻直接可连

190 if maxY - minY == 1:

191 return True

192

193 # 判断两个坐标之间是否全为0

194 for y0 in range(minY + 1, maxY):

195 if self.im2num_arr[x][y0] != 0:

196 return False

197 return True

198

199 # 判断同列是否可连

做了那么多年开发,自学了很多门编程语言,我很明白学习资源对于学一门新语言的重要性,这些年也收藏了不少的Python干货,对我来说这些东西确实已经用不到了,但对于准备自学Python的人来说,或许它就是一个宝藏,可以给你省去很多的时间和精力。

别在网上瞎学了,我最近也做了一些资源的更新,只要你是我的粉丝,这期福利你都可拿走。

我先来介绍一下这些东西怎么用,文末抱走。


(1)Python所有方向的学习路线(新版)

这是我花了几天的时间去把Python所有方向的技术点做的整理,形成各个领域的知识点汇总,它的用处就在于,你可以按照上面的知识点去找对应的学习资源,保证自己学得较为全面。

最近我才对这些路线做了一下新的更新,知识体系更全面了。

在这里插入图片描述

(2)Python学习视频

包含了Python入门、爬虫、数据分析和web开发的学习视频,总共100多个,虽然没有那么全面,但是对于入门来说是没问题的,学完这些之后,你可以按照我上面的学习路线去网上找其他的知识资源进行进阶。

在这里插入图片描述

(3)100多个练手项目

我们在看视频学习的时候,不能光动眼动脑不动手,比较科学的学习方法是在理解之后运用它们,这时候练手项目就很适合了,只是里面的项目比较多,水平也是参差不齐,大家可以挑自己能做的项目去练练。

在这里插入图片描述

(4)200多本电子书

这些年我也收藏了很多电子书,大概200多本,有时候带实体书不方便的话,我就会去打开电子书看看,书籍可不一定比视频教程差,尤其是权威的技术书籍。

基本上主流的和经典的都有,这里我就不放图了,版权问题,个人看看是没有问题的。

(5)Python知识点汇总

知识点汇总有点像学习路线,但与学习路线不同的点就在于,知识点汇总更为细致,里面包含了对具体知识点的简单说明,而我们的学习路线则更为抽象和简单,只是为了方便大家只是某个领域你应该学习哪些技术栈。

在这里插入图片描述

(6)其他资料

还有其他的一些东西,比如说我自己出的Python入门图文类教程,没有电脑的时候用手机也可以学习知识,学会了理论之后再去敲代码实践验证,还有Python中文版的库资料、MySQL和HTML标签大全等等,这些都是可以送给粉丝们的东西。

在这里插入图片描述

这些都不是什么非常值钱的东西,但对于没有资源或者资源不是很好的学习者来说确实很不错,你要是用得到的话都可以直接抱走,关注过我的人都知道,这些都是可以拿到的。

网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。

需要这份系统化学习资料的朋友,可以戳这里无偿获取

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值