python游戏自动化实战--游戏辅助软件冰山后的秘密


最终脚本 github:https://github.com/tdx1997tdx/kungfu_script

前言

本文记一次用python制作win10游戏辅助制作的实践,总结一些制作辅助常用的手段。为啥做辅助去了?这要从周末打游戏的时候说起。终于升级到90级了,可以去“考古”了,然而考古的过程枯燥无味,基本上就是重复以下过程:

  1. 找到相关npc
  2. 接取任务,放弃任务,直到找到红树林地点的任务
  3. 传送到红树林,根据任务中坐标找到地图中的相关坐标
  4. 打怪,掉落宝物
  5. 重新进入1步骤

可以看到,考古的过程的固定的模式。受到工作中自动化测试的启发,为什么不能将这一过程自动化呢?经过深思熟虑,总结了一下这个过程中可能遇到的难点:

  1. 由于是3d角色扮演类游戏,并非2d平面游戏,单靠坐标定位无法自动化
  2. 对于接取任务,放弃任务,直到找到红树林地点的任务这一步,你的辅助如何判断你接到了红树林的任务呢?
  3. 打怪的过程中如何控制血量控制在健康线上呢?
  4. 辅助如何判断是否被怪物攻击?正在处于战斗模式?

面对考古出来极品神装与元宝的诱惑,面对游戏辅助背后的秘密,面对摆在面前的“业余界难题”,强烈的好奇心让我踏上探索的征程。

游戏辅助常用方法总结

经过查找资料与探索,要完成这一系列自动化操作,需要用到的技术点有:

  1. 窗口定位:定位游戏窗口,实现后台操作鼠标键盘。
  2. 鼠标事件以及键盘事件,模拟用户鼠标和键盘操作。
  3. 获取窗口内某一按钮的坐标,用于鼠标点击操作。
  4. 图像识别,获取窗口内某一图像出现的位置坐标,用于定位该图像位置从而用于鼠标点击操作或者判断该图像是否存在。
  5. 内存读取相关数值,比如血量,蓝条,从而实现某些自动化功能,比如如果血量控制在健康线下就吃药补血。

连续点击脚本

秉着业务驱动技术的思想,我们先从最简单的需求开始。

需求:已知游戏界面如下,想要实现的需求,每隔1s重复打开关闭背包。
在这里插入图片描述
红框地方是背包按钮

实现思路

要想实现以上功能,需要以下几步:

  1. 获取想要操作的窗口句柄
  2. 定位背包按钮在窗口的相对位置
  3. 编写自动化脚本

获取窗口句柄

要想实现一边浏览网页一边运行后台脚本,就需要定位游戏所在的窗口句柄,所谓窗口句柄可以理解成窗口的uuid。
要获取窗口句柄值,这边用到了《按键抓抓辅助工具》
在这里插入图片描述
将其拖动到指定窗口就可以获取到指定窗口的句柄值。

大漠插件

大漠综合插件(dm.dll)采用vc6.0编写,是一款集前后台,文字识别,图色,键鼠,窗口,内存,DX,Call等功能于一身的综合插件。主要用于按键精灵、简单游、易语言等辅助制作工具,具有识别速度超级快的特点! 采用COM接口编写,适用于所有语言调用。

在这里插入图片描述
下载后注册大漠插件,用于python调用

坐标获取

《按键抓抓辅助工具》可以获取窗口内背包的相对坐标
在这里插入图片描述

编写自动化脚本

由《按键抓抓辅助工具》得到游戏窗口句柄值为2297008
可以用以下python代码实现

import win32com.client
import time

# 窗口句柄值
hwnd = 2297008
# 准备大漠插件
dm = win32com.client.Dispatch('dm.dmsoft')
# 绑定窗口
dm.BindWindow(hwnd, "normal", "windows", "windows", 0)
# 背包坐标
x, y = 841, 751


# 封装点击事件
def click(dm, x, y):
    dm.MoveTo(x, y)
    dm.LeftClick()


while 1:
    time.sleep(1)
    click(dm, x, y)

BindWindow,MoveTo,LeftClick方法可以查询大漠文档获取使用方法。

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
至此hello world需求就已经实现,展示效果如下

最终效果

在这里插入图片描述

自动吃符咒

需求:以下是游戏界面,红框是符咒,具有双倍经验的加成,限时1小时,1小时过去后要使用f12快捷键吃符咒。

在这里插入图片描述

实现思路

要想实现以上功能,最简单的方法就是sleep 1小时,但是这么实现存在问题就是脚本启动的时候不知道是不是吃了符咒。比较优雅的实现方式是用图像识别的方式实现:

  1. 监听窗口右侧范围内符咒图标
  2. 进行图像识别,如果没有识别到符咒图标,就按f12吃符咒

符咒图像截取

《按键抓抓辅助工具》自带图像截取的功能,我们先将符咒图片截取保存下来作为基准图片。
首先需要截取指定窗口
在这里插入图片描述
获取到符咒图像后保存
在这里插入图片描述
符咒图像就保存下来了
在这里插入图片描述

编写自动化脚本

import win32com.client
import time

# 窗口句柄值
hwnd = 2297008
# 准备大漠插件
dm = win32com.client.Dispatch('dm.dmsoft')
# 绑定窗口
dm.BindWindow(hwnd, "dx2", "windows", "windows", 0)
# 识别区域
x1, y1, x2, y2 = 800, 180, 1020, 650
# 相似度
sim = 0.9
while 1:
    time.sleep(0.5)
    is_ok, x, y = dm.FindPic(x1, y1, x2, y2, 'D:\software\按键抓抓\screen\\fuzhou.bmp', "000000", sim, 0)
    if is_ok == -1:
        print("符咒失效")
        # 按f12
        dm.KeyPress(123)
        print("吃符咒")

用到的接口如下:

在这里插入图片描述
在这里插入图片描述

123是f12的虚拟键码,具体见:https://www.cnblogs.com/del/archive/2007/12/07/987364.html

最终效果

在这里插入图片描述

人物是否移动

需求:判断游戏中人物是否移动

实现思路

在这里插入图片描述
红框是坐标数值,如果该区域,在指定的时间内(秒),图像数据一直不变,就说明静止,否则就为移动

编写自动化脚本

由《按键抓抓辅助工具》得到游戏坐标区域左上角和右下角坐标为(948, 156),(1017, 169)

import win32com.client
import time

# 窗口句柄值
hwnd = 2297008
# 准备大漠插件
dm = win32com.client.Dispatch('dm.dmsoft')
# 绑定窗口
dm.BindWindow(hwnd, "dx2", "windows", "windows", 0)
# 坐标区域
x1, y1, x2, y2 = 948, 156, 1017, 169
while 1:
    time.sleep(0.1)
    is_ok = dm.IsDisplayDead(x1, y1, x2, y2, 1)
    if is_ok == 0:
        print("移动中")
    else:
        print("静止中")

用到的接口如下:
在这里插入图片描述

最终效果

在这里插入图片描述

血量低自动吃药

需求:判断游戏血量是否健康,如果不健康,自动按f1吃药

这个需求难点就是如何判断血量是否健康,这边使用这种方法实现:
看见游戏左上角血条了吗,假如血条的30%的地方颜色由红色转为灰色,那么我们认为她血量不健康。
另一种方法是使用cheat engine读取血量的内存地址,找到基地址直接读内存,这个难度较高,有兴趣的同学可以读一下这个文章:https://www.cnblogs.com/gd-luojialin/p/7789569.html

编写自动化脚本

import win32com.client
import time

# 窗口句柄值
hwnd = 2297008
# 准备大漠插件
dm = win32com.client.Dispatch('dm.dmsoft')
# 绑定窗口
dm.BindWindow(hwnd, "dx2", "windows", "windows", 0)


# 是否需要吃药,如果
def is_eat_drug(dm):
    col = dm.GetColor(107, 65)
    if col[0] != "6" or col[2] != "3" or col[4] != "3":
        return True
    return False


while 1:
    time.sleep(1)
    res = is_eat_drug(dm)
    if res:
        print("需要吃药了")
    else:
        print("血量健康")

如果血量健康,107, 65坐标返回的颜色值为,663f3f,一旦不健康,就不是这个值了。

如何获取某一点的颜色值呢,强大的《按键抓抓辅助工具》就可以解决

在这里插入图片描述

最终效果

在这里插入图片描述

总结

大漠插件还有很多好玩的功能,具体可以看看文档,这些功能配合多线程就可以弄出强大的自动化辅助工具,想体验的同学可以试试呀!

最终脚本 github:https://github.com/tdx1997tdx/kungfu_script

  • 15
    点赞
  • 151
    收藏
    觉得还不错? 一键收藏
  • 15
    评论
### 回答1: Python接口自动化中,POST请求是常见的一种请求方式。POST请求通常用于向服务器提交数据,比如表单数据、JSON数据等。在Python中,我们可以使用requests库来发送POST请求。具体步骤如下: 1. 导入requests库 ``` import requests ``` 2. 构造请求参数 POST请求通常需要传递一些参数,比如表单数据、JSON数据等。我们可以使用字典来构造请求参数。 ``` data = { 'username': 'admin', 'password': '123456' } ``` 3. 发送POST请求 使用requests库的post方法来发送POST请求,传递请求的URL和请求参数即可。 ``` url = 'http://www.example.com/login' response = requests.post(url, data=data) ``` 4. 处理响应结果 发送POST请求后,服务器会返回响应结果。我们可以通过response对象来获取响应结果。 ``` print(response.status_code) # 获取响应状态码 print(response.text) # 获取响应内容 ``` 以上就是Python接口自动化中发送POST请求的基本步骤。 ### 回答2: Python接口自动化中,Post请求是常用的一种请求方式,通常用于向服务器提交数据。Post请求与Get请求不同,它将请求参数放在请求体中,而不是放在URL的参数中。 在Python中,可以使用requests库来发送Post请求,其基本用法示例如下: ``` import requests # 构造请求参数 url = "http://www.example.com/api" data = { "username": "xxx", "password": "xxx" } # 发送Post请求 response = requests.post(url, data=data) # 解析响应数据 result = response.json() ``` 以上示例中,首先构造了请求参数,包括请求URL和请求数据。然后使用requests库发送Post请求,其中url参数传入请求URL,data参数传入请求数据。发送请求后,可以通过response.json()方法将响应数据解析为JSON格式的数据,方便后续操作。 在实际使用中,请求参数的构造可能更加复杂,包括请求头、cookies等,可以通过requests库提供的各种方法进行设置。另外,在接口自动化中,需要进行接口测试的时候,通常需要用到断言,可以使用Python自带的assert语句或其他第三方断言库来进行断言操作。 总之,在Python接口自动化中,Post请求是常见的请求方式,使用requests库可以轻松实现Post请求的发送和响应解析,同时也可以进行断言操作,方便进行接口测试。 ### 回答3: Python接口自动化中,使用POST请求是非常常见的操作。POST请求是HTTP协议中的一种请求方式,主要用于向服务器提交数据。相较于GET请求,POST请求通常用于提交表单数据、上传文件和请求创建新资源等场景。 下面我们来介绍Python中如何实现POST请求的操作。 首先需要导入requests库: ```python import requests ``` 接下来,我们可以定义一个POST请求的函数,传入URL、参数和请求头部(可选): ```python def post_request(url, data, headers=None): """ POST请求 """ response = requests.post(url=url, data=data, headers=headers) # 返回响应结果 return response ``` 以上代码中,我们使用requests.post()方法发送POST请求,传入URL、参数和请求头部。其中,URL表示请求的URL地址,data表示请求的数据,headers表示请求头部,可选。 接着,我们可以通过调用上面定义的函数,发送POST请求并获取响应结果: ```python url = "http://example.com/api/login" data = { "username": "testuser", "password": "testpass" } headers = { "User-Agent": "Mozilla/5.0" } # 发送POST请求 response = post_request(url=url, data=data, headers=headers) # 输出响应结果 print(response.text) ``` 以上代码中,我们定义了一个POST请求的URL地址和请求数据,以及一个请求头部(User-Agent)。然后,我们调用post_request()函数,传入URL、数据和请求头,发送POST请求并获取响应结果。最后,我们输出响应结果的文本内容。 除了以上的方式,我们还可以通过requests库的其他方法实现POST请求,如下所示: ```python # 使用JSON格式数据发送POST请求 response = requests.post(url=url, json=data, headers=headers) # 使用文件上传方式发送POST请求 files = {'file': open('file.png', 'rb')} response = requests.post(url=url, files=files, headers=headers) ``` 以上代码分别演示了通过JSON格式数据和文件上传方式发送POST请求的方法。 总的来说,Python实现接口自动化中的POST请求操作,其实就是通过requests库提供的post()方法或其他方法,传入请求的URL、数据和请求头部,即可实现。同时,需要注意请求参数的格式和请求头部的设置。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 15
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值