接着上篇的博文,今天我们讲如何实现自动组队刷道

引入:

自动组队刷道的流程是先点击刷道按钮、再点击前往按钮、再点击便捷组队······

这些操作上篇博文已经告诉我们怎么做了,利用picpick丈量坐标,再用autopy模拟鼠标点击

但是点击过便捷组队后如何实现自动创建队伍并匹配队友呢?

这里要用到文字识别

玩过问道的都知道,没有队友或者队友数量没到4的时候,队伍会存在守护,如下

并且守护的位置是固定的,守护的优先级是从左到右,例如,匹配到一个队友,斗阙长老就会消失(不会参战);再匹配一个队友,白骨长老就会消失(不会参战)

我的思路是,隔一段时间对夜神模拟器截图,再对这张截图文字识别,判断“斗阙长老”和“白骨长老”是否存在于识别出的字符串中。当然,也可以判断长老数量是否小于等于2

因为玩过回合制的知道,队伍达到三个人就可以发车了,做任务的过程中系统会自动匹配队友,直到匹配满为止

前期准备:

利用PIL的ImageGrab截图

安装PIL

pip install pillow

(pillow包里包含了pil,pil目前已经停止维护了)

我这里是用PyCharm直接安装的依赖包

复制代码,直接运行

#coding=utf-
import time
import win32api import win32con
from PIL import ImageGrab time.sleep()
# 参数说明
# 第一个参数 开始截图的x坐标
# 第二个参数 开始截图的y坐标
# 第三个参数 结束截图的x坐标
# 第四个参数 结束截图的y坐标
bbox = (, , , )
im = ImageGrab.grab(bbox) # 参数 保存截图文件的路径
im.save('as.png')

直接运行,会发现在当前目录下有一个as.png的截图文件

官方文档对grab方法给出的解释

这里bbox = (x1,y1,x2,y2),意思是从屏幕坐标(x1,y1)到(x2,y2)的一段区域

ImageGrab.grab(bbox) ⇒ image

(New in 1.1.) Take a snapshot of the screen, and return an “RGB” image. The bounding box argument can be used to copy only a part of the screen.

利用baidu-aip进行文字识别

我尝试过pytesseract和pytesser的文字识别,经常会出现识别失败,对中文的支持也不够友好

所以我这里选用baidu-aip进行文字识别

PyCharm打开File->Settings->加号

搜索baidu-aip,再点击左下角Install Package

我们需要APPP_ID、API_KEY、SECRET_KEY,我们去百度云申请

登录百度云,百度云盘和百度贴吧账号可以直接使用,没有的话申请一个百度账号

找到文字识别

点击创建应用

完成创建,个人用户一天可以免费识别600次

需要识别文字的图片用下图

复制代码,运行

#coding=utf-
from aip import AipOcr import re #百度文字识别
APPP_ID = 'APP_ID'
API_KEY = 'APP_KEY'
SECRET_KEY = 'SECRET_KEY' client = AipOcr(APPP_ID,API_KEY,SECRET_KEY) i = open(r'E:\python_project\test\imageIdentification\helpedName1.png','rb') img = i.read() message = client.basicGeneral(img);for i in message.get('words_result'): print(i.get('words'))

可以看到结果

开始制作外挂:

和上篇博客一样,先丈量坐标,坐标根据分辨率不同而不同,我这里是1920*1080

刷道按钮的坐标是(809,222)

前往按钮的坐标是(1101,646)

便捷组队的坐标是(1449,730)

创建队伍按钮(998,799)

开始匹配(1232,794)

丈量坐标完毕后,调用文字识别,判断“斗阙长老”和“白骨长老”是否存在于识别的字符串中

如果两位长老都不存在,说明队伍里已经有三人。此时关闭刷道窗口,点击陆压真人,对话,开始刷道

设置十轮刷道时间,十轮刷道任务结束后开始新的一轮刷道

详细代码如下:

imageGrabUtil.py(截图工具)

#coding=utf-

from PIL import ImageGrab
# 参数说明
# 第一个参数 开始截图的x坐标
# 第二个参数 开始截图的y坐标
# 第三个参数 结束截图的x坐标
# 第四个参数 结束截图的y坐标
def screenshot(x1,y1,x2,y2,filename):
bbox = (x1, y1, x2, y2)
im = ImageGrab.grab(bbox) # 参数 保存截图文件的路径
im.save('E:\\python_project\\Asktao_Automation\\resource\\'+filename+'.png')

baiduAipUtil.py(文字识别工具)

我这里百度云的APPP_ID、API_KEY、SECRET_KEY保存在config.ini

#coding=utf-
from aip import AipOcr import re #百度文字识别
# !/usr/bin/env python
# -*- coding:utf- -*- import ConfigParser
import os os.chdir("E:\python_project\Asktao_Automation\util") cf = ConfigParser.ConfigParser() cf.read("config.ini") secs = cf.sections() APPP_ID = cf.get("baiduAip","APPP_ID")
API_KEY = cf.get("baiduAip","API_KEY")
SECRET_KEY = cf.get("baiduAip","SECRET_KEY") client = AipOcr(APPP_ID,API_KEY,SECRET_KEY) def characterRecognition(filePath):
i = open(filePath,'rb') img = i.read() message = client.basicGeneral(img); #print(message.get('words_result'))
string = ''; for i in message.get('words_result'): print(i.get('words'))
string += i.get('words')
return string

config.ini

[baiduAip]
APPP_ID = APPP_ID
API_KEY = API_KEY  

SECRET_KEY = SECRET_KEY 

shuaDao.py

#coding=utf-
import autopy
import time
import win32api
import win32con
from imageGrabUtil import screenshot
from baiduAipUtil import characterRecognition
import sys
defaultencoding = 'utf-8'
if sys.getdefaultencoding() != defaultencoding:
reload(sys)
sys.setdefaultencoding(defaultencoding) #刷道(队长模式)
#time.sleep()
win32api.keybd_event(,,,) #alt键位码是18
win32api.keybd_event(,,,) #tab键位码是9
time.sleep(0.5)
win32api.keybd_event(,,,) #enter键位码是13 win32api.keybd_event(,,win32con.KEYEVENTF_KEYUP,) #释放按键
win32api.keybd_event(,,win32con.KEYEVENTF_KEYUP,)
win32api.keybd_event(,,win32con.KEYEVENTF_KEYUP,)
time.sleep() def mousemove_click(x,y):
autopy.mouse.smooth_move(x, y)
autopy.mouse.click() mousemove_click(,)#移动到刷道按钮 mousemove_click(,)#点击前往 time.sleep()#从其他地图走到轩辕庙陆压真人处花费10s mousemove_click(,)#点击便捷组队 mousemove_click(,)#点击创建队伍 mousemove_click(,)#点击开始匹配 for i in range(,,):
teamFileName = 'judgeTeamCount'
time.sleep()
screenshot(, , , ,teamFileName)#截图 judgeTeamStr = characterRecognition('E:\\python_project\\Asktao_Automation\\resource\\'+teamFileName+'.png')#文字识别
#每个人守护顺序不一样,按需修改
if '斗阙长老' not in judgeTeamStr and '白骨长老' not in judgeTeamStr: #这两个守护不在,说明队伍已有三人,开始刷道
mousemove_click(,) #点击关闭按钮
mousemove_click(, ) # 移动到刷道按钮
mousemove_click(, ) # 点击前往
mousemove_click(, )#点击【伏魔】我这就去
break time.sleep()#休息十分钟后再次查看是否组到人 #刷道十轮之后的操作
for j in range(,,):
time.sleep()#平民伏魔一般780s之内,土豪伏魔有300s的,按需修改
taskFileName = 'judgeTaskAccomplish'
time.sleep()
screenshot(, , , ,taskFileName)
judgeTaskStr = characterRecognition('E:\\python_project\\Asktao_Automation\\resource\\'+taskFileName+'.png') if '【伏魔】我这就去' in judgeTaskStr:
mousemove_click(, ) # 点击【伏魔】我这就去
else:
time.sleep() #防止780s内还没有完成伏魔操作,再等60s,以防万一
mousemove_click(, ) # 点击【伏魔】我这就去

效果如下:

鉴于博客园只能上传10MB以下的GIF,所以我没有上传完整的效果图

亲测可用,大概十分钟左右可以匹配到三个人,就开始刷道

10轮刷道为一组,组数可以自己将循环数设大一点,我这里设的是10

有的时候匹配不到人,比如像白天就比较难匹配到人。可以把截图判断长老是否存在的那部分,多循环几次

再次强调,我的代码不一定在你的电脑上可以运行,我的电脑分辨率是1920*1080,模拟器的位置是默认的放在中央,模拟器移动的话丈量的坐标都不一样

制作外挂最重要的是思想方法

Python制作回合制手游外挂简单教程(中)的更多相关文章

  1. Python制作回合制手游外挂简单教程(下)

    引入: 接着上篇的博文,今天我们讲如何实现助人为乐 前期准备: 如何获取图片中指定文字的坐标? 我的思路是截取一个小区域,再根据小区域左上角的坐标获取中央坐标 例如: 获取坐上角的x和y坐标,测量x到 ...

  2. Python制作回合制手游外挂简单教程(上)

    引入: 每次玩回合制游戏的时候,反反复复的日常任务让人不胜其烦 玩问道的时候,我们希望能够自动刷道,玩梦幻希望能自动做师门.捉鬼等等 说明: 该外挂只能模拟鼠标键盘操作,并不能修改游戏数据 我这里使用 ...

  3. Android手游外挂入侵----寓攻于守,方能破敌

    欢迎访问网易云社区,了解更多网易技术产品运营经验. 手游外挂入侵 随着各种爆款手游的风靡,目前手机游戏的占比用户已经形成一个巨大的市场,市场上你争我夺,有将PC版本移植到手机中,也有新模式手游的推出. ...

  4. python制作爬虫爬取京东商品评论教程

    作者:蓝鲸 类型:转载 本文是继前2篇Python爬虫系列文章的后续篇,给大家介绍的是如何使用Python爬取京东商品评论信息的方法,并根据数据绘制成各种统计图表,非常的细致,有需要的小伙伴可以参考下 ...

  5. 【转载】QQ炫舞手游自制谱子教程(星动模式)

    第一步:计算ET和BPM: 抄送原作者部落链接:https://buluo.qq.com/p/detail.html?bid=368006&pid=981862-1529828677& ...

  6. 如何快速优化手游性能问题?从UGUI优化说起

    WeTest 导读   本文作者从自身多年的Unity项目UI开发及优化的经验出发,从UGUI,CPU,GPU以及unity特有资源等几个维度,介绍了unity手游性能优化的一些方法.   在之前的文 ...

  7. 建一座安全的“天空城” ——揭秘腾讯WeTest如何与祖龙共同挖掘手游安全漏洞

    作者:腾讯WeTest手游安全测试团队商业转载请联系腾讯WeTest获得授权,非商业转载请注明出处. WeTest导读 <九州天空城3D>上线至今,长期稳定在APP Store畅销排行的前 ...

  8. 腾讯WeTest《2017中国移动游戏质量白皮书》开放预约,再为国内手游把把脉

    产品为王,质量先行.如果说2016年是爆款手游相继崛起的一年,那么2017年则更像是打磨精品.建立生态的高手切磋之年.守住一个游戏的质量生命线,方能建立健康生态,方能在如火如荼的行业竞争中角逐到最后. ...

  9. Unity手游之路<十三>手游代码更新策略探讨

    http://blog.csdn.net/janeky/article/details/25923151 这几个月公司项目非常忙,加上家里事情也多,所以blog更新一直搁置了.最近在项目开发上线过程中 ...

随机推荐

  1. Schema validation found non-datatype errors

    Private Sub UpdateClaim(ByVal Status As String, ByVal Request As String) '======================' Im ...

  2. HTTP调用接口方法

    1.创建接口调用方法类 package cn.com.victorysoft.sjzx.Message; import java.io.BufferedReader; import java.io.I ...

  3. Ceph 的基础数据结构 [Pool, Image, Snapshot, Clone]

    原文链接:http://www.cnblogs.com/sammyliu/p/4843812.html?utm_source=tuicool&utm_medium=referral 1 Poo ...

  4. 62 不同路径 leetcode JAVA

    题目: 一个机器人位于一个 m x n 网格的左上角 (起始点在下图中标记为“Start” ). 机器人每次只能向下或者向右移动一步.机器人试图达到网格的右下角(在下图中标记为“Finish”). 问 ...

  5. shell脚本报错:-bash: xxx: /bin/bash^M: bad interpreter: No such file or directory

    当我们把文件从windows系统中编辑的文件拷贝到linux系统中,如果我们执行文件会保存如下的错: shell脚本报错:-bash: xxx: /bin/bash^M: bad interprete ...

  6. 孩子们各显神通对付 iOS 12「屏幕使用时间」的限制

    简评:2018 年秋季,苹果公司推出了 iOS 12,其中备受好评的一项改变是:增加了屏幕使用时间限制,以减轻沉迷手机的状况.三个月过去后,这项功能似乎并没有对孩子造成太多困扰,道高一尺魔高一丈,孩子 ...

  7. GCD介绍:Dispatch_source

    [转自:GCD介绍(三): Dispatch Sources] 何为Dispatch Sources 简单来说,dispatch source是一个监视某些类型事件的对象.当这些事件发生时,它自动将一 ...

  8. 钉钉机器人集成Jenkins推送消息模板自定义发送报告

    一.由于公司同样也使用了钉钉.那么在做Jenkins集成自动化部署的时候,也是可以集成钉钉的. 那种Jenkins下载钉钉插件集成,简单设置就可以完成了.我们今天要做的是,定制化的发送消息. 钉钉推送 ...

  9. Visual Studio各个版本对应关系

  10. python 异步IO(syncio) 协程

    python asyncio 网络模型有很多中,为了实现高并发也有很多方案,多线程,多进程.无论多线程和多进程,IO的调度更多取决于系统,而协程的方式,调度来自用户,用户可以在函数中yield一个状态 ...