教你用Python轻巧制作半即时制手游外挂,Python制作半即时制手游外挂轻巧教程

前言

老是玩半即时制游戏的时候,三翻四复的一般性任务令人不胜其烦

玩问道的时候,大家盼望能够活动刷道,玩梦幻希望能活动做师门、捉鬼等等

先天笔者就用Python教大家做一个有关半即时制游戏的本子,该脚本只好模拟鼠标键盘操作,并不能够改改游戏数量。

作者:`Rest探路者`
源自:`

1经您须要1个不错的上学调换条件,那么您能够思考Python学习交换群:54837787五;

设若你必要一份系统的就学材质,那么您能够思量Python学习沟通群:54837787伍。

引入:

教你用Python轻巧制作半即时制手游外挂,Python制作半即时制手游外挂轻巧教程。历次玩半即时制游戏的时候,首鼠两端的日常职责令人不胜其烦

玩问道的时候,咱们希望能够活动刷道,玩梦幻希望能自行做师门、捉鬼等等

上回(Python达成电影排名榜活动网盘下载(四)库克ies免登入+抓包下载)说起,壹段时间内能拓展多少次离线下载也许受限于验证码的输入。
在此有多个缓和方案,

前言

 

说明:

该外挂只好模拟鼠标键盘操作,并不能够修改游戏数量

作者那边运用的python二.柒

开垦工具是PyCharm

  • 见招拆招 通过GUI优化验证码输入
    就算有验证码,在用户从来输入验证码的情况下也是便捷的。而且能够借此读书Python是什么样做出GUI程序的,学起来也会是很有价值的,参考
    施行楼
    给Python三爬虫做3个界面
    以后有机遇恐怕会写点类似的实行案例。
  • 行使网盘客户端
    其1消除方案的独到之处就是不曾!验!证!码!缺点就是增多的速度视能源而定,借使不合规能源较多,可能会导致频仍重启;再有实际那正是个按钮脚本,接纳模拟鼠标、键盘等操作,认为比较脑残…

教你用Python轻巧制作半即时制手游外挂,Python制作半即时制手游外挂轻巧教程。自行扫雷一般分为二种,一种是读取内部存储器数据,而另一种是经过分析图片得到数据,并透过模拟鼠标操作,那里作者用的是第二种格局。

付出情状计划

Python2.7 + Windows

模块:autopy,可pip install autopy

初期知识盘算:

第3下载autopy包,笔者这边PyCharm能够平素导入autopy包

抑或用利用pip实行安装:pip install autopy

那篇作品记录了笔者第1种艺术的尝试进程,最终测试了多少个磁力链接的丰裕速度,差不多是那样的:

一、图谋干活

鼠标移动

www.5929.com 1

 

会意识鼠标须臾间移动到坐标(一,1)的职位,笔者的Computer是1九壹八*十80的,最右下角的坐标正是(191玖,十80)。

将move换成smooth_move,会发掘鼠标渐渐地运动到钦命坐标

鼠标移动

复制如下代码,运营

#coding=utf-8import time import autopy#quick moveautopy.mouse.move(1,1) #smooth move#autopy.mouse.smooth_move(1370,120)

会意识鼠标须臾间活动到坐标的岗位,笔者的管理器是壹玖1九*十80的,最右下角的坐标便是(191陆,1080)。

将move换成smooth_move,会意识鼠标稳步地移动到钦命坐标

官方文书档案的分解:

autopy.mouse.move(x: float, y: float)

Moves the mouse to the given coordinate.

Exceptions:

ValueError is thrown if the point is out of index.

autopy.mouse.smooth_move(x: float, y: float)

Smoothly moves the mouse to the given coordinate in a straight line.

Exceptions:

ValueError is thrown if the point is out of index.

坐标抢先分辨率会报非凡

www.5929.com 2

一.扫雷游戏

鼠标点击

运维代码,发掘目前岗位发生了点击操作

www.5929.com 3

 

鼠标点击

www.5929.com,运作代码,发掘眼下任务产生了点击操作

#coding=utf-8import autopyautopy.mouse.click() # 单击

演示

本人是win10,未有暗许的扫雷,所以去扫雷网下载

键盘操作

广泛的键值码和键的应和:

www.5929.com 4

 

这里供给win3二api包

调用win32api的keybd_event方法,用过要释放按钮

www.5929.com 5

 

能够看来,实现了切换窗口的操作,也就是大家按alt+tab,然后回车进入

键盘操作

上边时部分布满的键值码和键的应和:

字母和数字键 数字小键盘的键  成效键    其余键
键 键码 键 键码 键 键码 键 键码
A 65 0 96 F1112 Backspace 8
B 66 1 97 F2113 Tab 9
C 67 2 98 F3114 Clear 12
D 68 3 99 F4115 Enter 13
E 69 4 100 F5 116 Shift 16
F 70 5 101 F6 117 Control 17
G 71 6 102 F7 118 Alt 18
H 72 7 103 F8 119 Caps Lock 20
I 73 8 104 F9 120 Esc 27
J 74 9 105 F10121 Spacebar 32
K 75 * 106 F11 122 Page Up 33
L 76 + 107 F12 123 Page Down 34
M 77 Enter 108 End 35
N 78 – 109 Home 36
O 79 . 110 Left Arrow 37
P 80 / 111 Up Arrow38
Q 81 RightArrow 39
R 82 DownArrow 40
S 83 Insert 45
T 84 Delete 46
U 85 Help 47
V 86 NumLock 144
W87
X88
Y89
Z90
048
149
250
351
4 52
553
654
755
856
9 57

复制代码,运行,那里供给win3二api包

调用win32api的keybd_event方法,用过要自由按钮

#coding=utf-8import timeimport win32api win32api.keybd_event(18,0,0,0)  #alt键位码是18win32api.keybd_event(9,0,0,0)  #tab键位码是9time.sleep(0.5)win32api.keybd_event(13,0,0,0)  #enter键位码是13 win32api.keybd_event(18,0,win32con.KEYEVENTF_KEYUP,0) #释放按键win32api.keybd_event(9,0,win32con.KEYEVENTF_KEYUP,0)win32api.keybd_event(13,0,win32con.KEYEVENTF_KEYUP,0)time.sleep(2)

可以见到,落成了切换窗口的操作,也正是大家按alt+tab,然后回车进入

www.5929.com 6

先导成立游戏脚本

此处以问道手机游戏为例(半即时制手机游戏类似)

急需夜神模拟器,并在模拟器上安装问道

自个儿试过蓝叠和MuMu模拟器,小编用autopy移动鼠标到模拟器时鼠标就流失了,无法成就后续的自行操作,后来百度了

说某些模拟器不受win窗口的决定。不管那么多,大家先用夜神模拟器吧!

www.5929.com 7

 

进去游玩,张开”活动”

www.5929.com 8

 

咱俩以”竞赛场”活动比如表明

www.5929.com 9

 

此处大家要用到截图工具,笔者用的是PicPick

个人用户免费,作者根本用它来衡量坐标

www.5929.com 10

 

记录下竞赛场前往的坐标(135八,50四)

www.5929.com 11

 

笔录下比赛场开关的坐标(133二,650)

营造半即时制脚本首先得要熟练职务流程

下一场点击竞赛场,走完那些职务流程,依次记录按键的坐标

比赛场职分1天能够做7回,大家对手续循环伍回

应战岁月我们须要和睦来计时,差异门派,土豪恐怕平民游戏发烧友时间都不一致

自家是全体公民游戏的使用者,大约耗费时间60s,点击过挑衅让代码延迟60s再继续试行

www.5929.com 12

 

起头营造外挂:

此处以问道手游为例

亟需夜神模拟器,并在模拟器上设置问道

笔者试过蓝叠和MuMu模拟器,笔者用autopy移动鼠标到模拟器时鼠标就流失了,无法成就后续的活动操作,后来百度了

说有些模拟器不受win窗口的决定。不管那么多,大家先用夜神模拟器吧!

www.5929.com 13

进去娱乐,展开“活动”

www.5929.com 14

我们以“竞赛场”活动举个例子表明

www.5929.com 15

此处大家要用到截图工具,作者用的是PicPick

个人用户无偿,小编根本用它来度量坐标

www.5929.com 16

记录下竞赛场前往的坐标

www.5929.com 17

记录下竞赛场按键的坐标

制作半即时制脚本首先得要熟练任务流程

接下来点击比赛场,走完那个职务流程,依次记录开关的坐标

比赛场任务一天能够做四次,大家对手续循环四回

应战岁月大家要求团结来计时,不一样门派,土豪可能平民游戏发烧友时间都不均等

自己是老百姓游戏发烧友,大概耗费时间60s,点击过挑衅让代码延迟60s再继续施行

www.5929.com 18

复制代码,运营

#coding=utf-8import autopyimport timeimport win32apiimport win32con#竞技场win32api.keybd_event(18,0,0,0)  #alt键位码是18win32api.keybd_event(9,0,0,0)  #tab键位码是9time.sleep(0.5)win32api.keybd_event(13,0,0,0)  #enter键位码是13 win32api.keybd_event(18,0,win32con.KEYEVENTF_KEYUP,0) #释放按键win32api.keybd_event(9,0,win32con.KEYEVENTF_KEYUP,0)win32api.keybd_event(13,0,win32con.KEYEVENTF_KEYUP,0)time.sleep(2) def mousemove_click:    autopy.mouse.smooth_move    autopy.mouse.click() mousemove_click(771, 203)  # 活动的坐标 mousemove_click(1358,504)  # 竞技场"前往"的坐标 time.sleep(20)#从天墉城城中心/其他地图走到竞技使者花费20s mousemove_click(1334, 650)  # 竞技使者对话框中的竞技场的坐标  #挑战完毕会出现对话窗口for i in range(1,6,1):    mousemove_click(664,706) #挑战试炼童子     mousemove_click(1082,578) #确认     mousemove_click(1530, 794)  # 战斗自动     time.sleep(60)#挑战试炼童子预计60s

速度大致是每分钟11个,借使再慢的话从进程上大概首先种方案会是相比好的取舍。

www.5929.com 19

代码

www.5929.com 20

 

功效如下:

www.5929.com 21

下一集将介绍怎样促成队长方式刷道(自动组成代表队,自动跑环接职务)

Pywinauto

先看看简单介绍吧。pywinauto is a set of python modules to automate the
Microsoft Windows GUI. At it’s simplest it allows you to send mouse
and keyboard actions
to windows dialogs and controls.
哦,是个Windows的自动化操作工具。
支持文书档案
要点三个按键,首先要清楚怎么找这么些开关吧?在此间她的三个示范是有关记事本的,学习了一下,大约是通过窗口类名标题来找的构件,说起这边将要用到Spy++(只怕Spy++Lite)

www.5929.com 22

百度网盘的示范

就那样拖一下就寻找来了。
哈哈,初次用那一个Pywinauto以为还挺厉害的,然则我把她用到网盘上的时候…作者就蒙蔽了-
-,这些离线下载的开关在Spy++Lite中找不到,换了其余各类找元件的工具都查不出去,Pywinauto输出这一个主窗口蕴涵的预制构件也随便用。英特网查了弹指间那是干吗,只怕是其一开关他丫的就不是个正式的按键!那该如何做呢?

2.python 3

关于开关的折磨

那1段着实是瞎折腾,最初的主见并不曾成功,最后摘取了鼠标模拟,发上来给咱们参考参考吧,大家有指正或许好的一字不苟方式快来告诉笔者哟~(之所以大概那段能够跳过了?(划掉)
网络看看别的二个方案——窗口收到了怎么着音信,就模仿怎么着音讯;收到了鼠标按下开关那么些音信,就照猫画虎这一个消息。
于是乎又在Spy++里面瞎折腾,先展开百度云主窗口,然后在Spy++里面著录它接受的新闻,找到了那般一条

www.5929.com 23

找到了按下离线下载之后的窗口的句柄

www.5929.com 24

就是以此音信用到了作者们须要的句柄

离线下载那几个按键的意义便是激活这么些新建的窗口,那大家获得那个句柄(也便是窗口的身份)来激活,不就不要管这一个开关了吗?然则本条句柄是何许产生的吗?它到底是在按下开关的一瞬发出的,照旧在按下在此之前就存的有吧?在Spy++中从按下鼠标之后收获到的音讯并未重临这么些句柄,呵呵,笔者就天真地暂定它是此前就存的有呢。尽管你存的有,那又该怎么找呢?嘿嘿,笔者想到了CheatEngine来研究。

www.5929.com 25

新建离线下载窗口的句柄

哇,那不是有规律嘛!第5位每便+一!
但是当下笔者又被打脸了…开个其他窗口再来开它,嗯……(手动再见)

www.5929.com 26

好吧…笔者低头了…就遵照开关脚本来写吧…

自己的版本是 python 三.6.壹

后台鼠标音信

好了,未来起来试着写按钮脚本…大约主见便是赢得主窗口的句柄,用坐标的措施获取按键的职位,然后模拟点击。那里恐怕用按钮精灵的抓抓会比较有利。

www.5929.com 27

拖动到窗口内“离线下载”开关上

www.5929.com 28

在按钮精灵中测试 主窗口句柄为13324八

在此间必要小心开关Smart抓出来的句柄是10进制的。
测试成功啦,看来能够用那些方式,那就一通写出来吗。

www.5929.com 29

发送文书

那边难题正是离线下载的地方填不进入!它就这么默默地望着你,寸步不移!

www.5929.com 30

按钮精灵不行,试试Pywinauto?

3.python的第一方库

移植到Python

……别试了,Pywinauto发送文书也卓越。它们用的应该都是WIN
API,所以应当换个思路了。在那边作者的主张是模拟人操作,把地方Ctrl+C一下,然后到文本框Ctrl+V一下。在此间即便Pywinauto有Ctrl+V,但却从不Ctrl+C(卧槽那是什么样操作啊啊啊)照旧用win
api吧。注意这么些SetClipboardData提到了一句,

务必用NULL停止字符串。使用此格式为ANSI文本。

为此我们在地点前面加上一句

.encode('ansi')

要不然粘贴过去就是如此的

www.5929.com 31

除此以外文本框还有二个坑,像上边那样查询链接退步以来地址就留在那里了,所以理应是Ctrl+A
Ctrl+V。而文本框发送Ctrl+A
Ctrl+V有的时候会Ctrl莫名奇妙失效,多出来三个a,粘贴过去是amagnet,所以在此处差不离都服从存在文字的图景管理,发送A
Ctrl+A Ctrl+V
下贰个窗口。

www.5929.com 32

马到成功进级!

就算如此能够依据偏移点击的不二等秘书籍消除,但与此同时笔者意识能够经过Tab Tab
Enter的方法成就下载,恐怕未来遭逢坐标偏移量是生成的时候能够尝尝那种办法?
依次用鼠标点击钦定坐标的章程到了最后二个窗口了,关掉这么些窗口,正是本子的贰个循环啦。

www.5929.com 33

关掉那些窗口

win32api,win32gui,win32con,Pillow,numpy,opencv

总结

一初阶自己并不知道Pywinauto有后台鼠标音信,于是写了贰个用winapi模拟点击的本子,也放上来吧。

from pywinauto import application
import win32api
import win32gui
import win32con
import win32ui
main_handle=win32ui.FindWindow('BaseGui','欢迎使用百度网盘').GetSafeHwnd()
client_pos=(516,118)
tmp = win32api.MAKELONG(client_pos[0], client_pos[1])
win32gui.SendMessage(main_handle, win32con.WM_ACTIVATE, win32con.WA_ACTIVE, 0)
win32api.SendMessage(main_handle, win32con.WM_LBUTTONDOWN, win32con.MK_LBUTTON, tmp)
win32api.SendMessage(main_handle, win32con.WM_LBUTTONUP, win32con.MK_LBUTTON, tmp)

本次实验依然有为数不少主题材料,包罗Python落成电影排名榜活动网盘下载(三)Selenium离线下载一致出现的太急解决不了问题,所以最终代码中进入了wait_until;还有下载一定次数之后查询磁力链接没影响,重启客户端可消除;以及各样查询败北、离线下载错误……不问可见,应对不当的逻辑还有待改正,在此处只是轻易的设定为add_task出现难点之后直接重启客户端,即查询不了下载消息就重启。还有任何意况未有拍卖,包罗下载进程为0%,那种义务多了会唤起离线下载任务过多,要求手动清理,如若违法能源较多,或者导致重启频繁,影响速度。代码的话大概要求依照实际运营状态修改超时时间。由于速度过快平常轻松查不到句柄啥的,就都用try
except括起来了,认为非常丑却很不得已,献丑啦:

import pywinauto
import time
import win32clipboard as w
import win32con
from pywinauto.timings import *
from pywinauto.application import Application
class baidudisk:

    def boot(self):
        path=r'C:\Users\Administrator\AppData\Roaming\Baidu\BaiduNetdisk\BaiduNetdisk.exe'
        #Python3 中Application要加()
        self.baiduapp=Application().start(path)
        try:
            #规定时间内等待程序启动
            wait_until(10,0.25,self.getmainui,True)
        except Exception as e:
            print('Get Main Window ')
            print(e)

    def kill(self):
        self.baiduapp.kill()
    def download(self,url):
        #剪切板函数要求数据类型为ANSI
        self.url=url.encode('ansi')
        try:
            wait_until(1,0.25,self.click_newtask,True)
        except Exception as e:
            print('Download button ')
            print(e)
        try:
            wait_until(1,0.25,self.query_newtask,True)
        except Exception as e:
            print('Query')
            print(e)
        try:
            wait_until(4,0.25,self.add_newtask,True)
        except Exception as e:
            print('Add task')
            print(e)
            print('Rebooting...')
            self.baiduapp.kill()
            self.boot()
        try:
            wait_until(3,0.25,self.close_state,True)
        except Exception as e:
            print('State Window')
            print(e)

    def click_newtask(self):
        try:
            self.main_ui.click(coords=(516,118))
            return (True)
        except Exception as e:
            print(e)
            return (False)

    def query_newtask(self):
        try:
                newtask_handle=pywinauto.findwindows.find_window(class_name="BaseGui",title= "新建离线下载任务窗口")
                newtask_ui=pywinauto.controls.hwndwrapper.DialogWrapper(newtask_handle)
                url_ui=newtask_ui.descendants()[0]
                # url_ui.set_keyboard_focus()
                w.OpenClipboard()
                w.EmptyClipboard()
                w.SetClipboardData(win32con.CF_TEXT, self.url)
                w.CloseClipboard()
                url_ui.send_keystrokes('a^a^v')
                # print(url_ui.element_info)
                # print(url_ui.get_properties())
                #添加磁力链接后下载
                newtask_ui.click(coords=(470,255))
                return (True)
        except Exception as e:
            print(e)
            return (False)


    def add_newtask(self):
        try:
            download_handle=pywinauto.findwindows.find_window(class_name="BaseGui",title= '新建离线BT任务')
            download_ui=pywinauto.controls.hwndwrapper.DialogWrapper(download_handle)
            download_ui.click(coords=(400,470))
            #可能出现离线下载错误时该窗口不会正常关闭的情况 所以使用try
            try:
                download_ui.close()
            except:
                pass
            return (True)

        except Exception as e:
            print(e)
            return (False)

    def close_state(self):
        try:
            state_handle=pywinauto.findwindows.find_window(class_name="BaseGui",title= '离线下载任务列表')
            state_ui=pywinauto.controls.hwndwrapper.DialogWrapper(state_handle)
            state_ui.close()
            return (True)
        except Exception as e:
            print(e)
            return (False)

    def getmainui(self):
        try:
            #返回窗口句柄
            self.baidudisk_handle=pywinauto.findwindows.find_window(class_name='BaseGui',title='欢迎使用百度网盘')
            #根据窗口句柄查询对话框
            self.main_ui=pywinauto.controls.hwndwrapper.DialogWrapper(self.baidudisk_handle)
            return (True)
        except Exception as e:
            print(e)
            return (False)






if __name__=='__main__':
    bdtest=baidudisk()
    bdtest.boot()
    #正常与违规的链接均进行测试
    magnets=[
        'magnet:?xt=urn:btih:583bed331c32889897f69b114191c44732bb7aa2',
        'magnet:?xt=urn:btih:FD351CACF9692E1833388B3B5A568C6A115E4672&xl=546661540&dn=[%E6%A5%9A%E9%97%A8%E7%9A%84%E4%B8%96%E7%95%8C].rmvb',
        'magnet:?xt=urn:btih:F77F5133B209D29126812CFAC9B0FE2508DC52A9&xl=584113510&dn=%E9%9C%B8%E7%8E%8B%E5%88%AB%E5%A7%AC.rmvb',
        'magnet:?xt=urn:btih:E2A87A1922139C5C44965B77F5EC21F1442C97A4&xl=1073579448&dn=#_IBW118',
        'magnet:?xt=urn:btih:CC2711AE1A5CCB8CB5FB3E6F900F404BD4792517&xl=1367609104&dn=%E9%98%BF%E7%94%98%E6%AD%A3%E4%BC%A0.[1024%E5%88%86%E8%BE%A8%E7%8E%87].rmvb'
    ]
    for i in range(20):
        bdtest.download(magnets[i%5])

关于怎么着批量到手磁力链接地址可参照往期洋洋洒洒作品:
Python落成电影排行榜活动网盘下载(四)Cookies免登录+抓包下载
Python达成电影排名榜活动网盘下载(三)Selenium离线下载
Python落成电影排行榜活动网盘下载(二)Scrapy浓厚“打包员”“快递员”
Python完毕电影排名榜活动网盘下载(一)Scrapy爬虫框架
Python达成电影排行榜活动网盘下载(0)简要介绍
和讯云音乐争执抓取实验(壹)接口获取

可透过 pip install –upgrade SomePackage 来进展安装

注意:部分版本是下载pywin3二,可是有的要把pywin3二进级到最高并自行下载了pypiwin3二,具体情状每一种python版本也许都略有分裂

小编付出作者的第三方库和版本仅供参考

www.5929.com 34 

2、关键代码组成

一.找到游戏窗口与坐标

#扫雷游戏窗口
class_name = "TMain"
title_name = "Minesweeper Arbiter "
hwnd = win32gui.FindWindow(class_name, title_name)

#窗口坐标
left = 0
top = 0
right = 0
bottom = 0

if hwnd:
 print("找到窗口")
 left, top, right, bottom = win32gui.GetWindowRect(hwnd)
 #win32gui.SetForegroundWindow(hwnd)
 print("窗口坐标:")
 print(str(left)+' '+str(right)+' '+str(top)+' '+str(bottom))
else:
 print("未找到窗口")

二.锁定并抓取雷区图像

#锁定雷区坐标#去除周围功能按钮以及多余的界面#具体的像素值是通过QQ的截图来判断的
left += 15
top += 101
right -= 15
bottom -= 42

#抓取雷区图像
rect = (left, top, right, bottom)
img = ImageGrab.grab().crop(rect)

叁.各图像的索罗德GBA值

#数字1-8 周围雷数
#0 未被打开
#ed 被打开 空白
#hongqi 红旗
#boom 普通雷#boom_red 踩中的雷
rgba_ed = [(225, (192, 192, 192)), (31, (128, 128, 128))]
rgba_hongqi = [(54, (255, 255, 255)), (17, (255, 0, 0)), (109, (192, 192, 192)), (54, (128, 128, 128)), (22, (0, 0, 0))]
rgba_0 = [(54, (255, 255, 255)), (148, (192, 192, 192)), (54, (128, 128, 128))]
rgba_1 = [(185, (192, 192, 192)), (31, (128, 128, 128)), (40, (0, 0, 255))]
rgba_2 = [(160, (192, 192, 192)), (31, (128, 128, 128)), (65, (0, 128, 0))]
rgba_3 = [(62, (255, 0, 0)), (163, (192, 192, 192)), (31, (128, 128, 128))]
rgba_4 = [(169, (192, 192, 192)), (31, (128, 128, 128)), (56, (0, 0, 128))]
rgba_5 = [(70, (128, 0, 0)), (155, (192, 192, 192)), (31, (128, 128, 128))]
rgba_6 = [(153, (192, 192, 192)), (31, (128, 128, 128)), (72, (0, 128, 128))]
rgba_8 = [(149, (192, 192, 192)), (107, (128, 128, 128))]
rgba_boom = [(4, (255, 255, 255)), (144, (192, 192, 192)), (31, (128, 128, 128)), (77, (0, 0, 0))]
rgba_boom_red = [(4, (255, 255, 255)), (144, (255, 0, 0)), (31, (128, 128, 128)), (77, (0, 0, 0))]

4.围观雷区图像保存至3个二维数组map

#扫描雷区图像
def showmap():
 img = ImageGrab.grab().crop(rect)
 for y in range(blocks_y):
 for x in range(blocks_x):
  this_image = img.crop((x * block_width, y * block_height, (x + 1) * block_width, (y + 1) * block_height))
  if this_image.getcolors() == rgba_0:
  map[y][x] = 0
  elif this_image.getcolors() == rgba_1:
  map[y][x] = 1
  elif this_image.getcolors() == rgba_2:
  map[y][x] = 2
  elif this_image.getcolors() == rgba_3:
  map[y][x] = 3
  elif this_image.getcolors() == rgba_4:
  map[y][x] = 4
  elif this_image.getcolors() == rgba_5:
  map[y][x] = 5
  elif this_image.getcolors() == rgba_6:
  map[y][x] = 6
  elif this_image.getcolors() == rgba_8:
  map[y][x] = 8
  elif this_image.getcolors() == rgba_ed:
  map[y][x] = -1
  elif this_image.getcolors() == rgba_hongqi:
  map[y][x] = -4
  elif this_image.getcolors() == rgba_boom or this_image.getcolors() == rgba_boom_red:
  global gameover
  gameover = 1
  break
  #sys.exit(0)
  else:
  print("无法识别图像")
  print("坐标")
  print((y,x))
  print("颜色")
  print(this_image.getcolors())
  sys.exit(0)
 #print(map)

5.扫雷算法

那里自身使用的最基础的算法

一.率先点出多个点

二.扫描全部数字,假如周围空白+插旗==数字,则空手均有雷,右键点击空白插旗

叁.扫描全数数字,假使周围插旗==数字,则空手均未有雷,左键点击空白

4.循环贰、三,要是未有符合条件的,则随机点击贰个白块

#插旗
def banner():
 showmap()
 for y in range(blocks_y):
 for x in range(blocks_x):
  if 1 <= map[y][x] and map[y][x] <= 5:
  boom_number = map[y][x]
  block_white = 0
  block_qi = 0
  for yy in range(y-1,y+2):
   for xx in range(x-1,x+2):
   if 0 <= yy and 0 <= xx and yy < blocks_y and xx < blocks_x:
    if not (yy == y and xx == x):if map[yy][xx] == 0:
     block_white += 1
    elif map[yy][xx] == -4:
     block_qi += 1if boom_number == block_white + block_qi:for yy in range(y - 1, y + 2):
   for xx in range(x - 1, x + 2):
    if 0 <= yy and 0 <= xx and yy < blocks_y and xx < blocks_x:
    if not (yy == y and xx == x):
     if map[yy][xx] == 0:
     win32api.SetCursorPos([left+xx*block_width, top+yy*block_height])
     win32api.mouse_event(win32con.MOUSEEVENTF_RIGHTDOWN, 0, 0, 0, 0)
     win32api.mouse_event(win32con.MOUSEEVENTF_RIGHTUP, 0, 0, 0, 0)
     showmap()

#点击白块
def dig():
 showmap()
 iscluck = 0
 for y in range(blocks_y):
 for x in range(blocks_x):
  if 1 <= map[y][x] and map[y][x] <= 5:
  boom_number = map[y][x]
  block_white = 0
  block_qi = 0
  for yy in range(y - 1, y + 2):
   for xx in range(x - 1, x + 2):
   if 0 <= yy and 0 <= xx and yy < blocks_y and xx < blocks_x:
    if not (yy == y and xx == x):
    if map[yy][xx] == 0:
     block_white += 1
    elif map[yy][xx] == -4:
     block_qi += 1if boom_number == block_qi and block_white > 0:for yy in range(y - 1, y + 2):
   for xx in range(x - 1, x + 2):
    if 0 <= yy and 0 <= xx and yy < blocks_y and xx < blocks_x:
    if not(yy == y and xx == x):
     if map[yy][xx] == 0:
     win32api.SetCursorPos([left + xx * block_width, top + yy * block_height])
     win32api.mouse_event(win32con.MOUSEEVENTF_LEFTDOWN, 0, 0, 0, 0)
     win32api.mouse_event(win32con.MOUSEEVENTF_LEFTUP, 0, 0, 0, 0)
     iscluck = 1
 if iscluck == 0:
 luck()

#随机点击
def luck():
 fl = 1
 while(fl):
 random_x = random.randint(0, blocks_x - 1)
 random_y = random.randint(0, blocks_y - 1)
 if(map[random_y][random_x] == 0):
  win32api.SetCursorPos([left + random_x * block_width, top + random_y * block_height])
  win32api.mouse_event(win32con.MOUSEEVENTF_LEFTDOWN, 0, 0, 0, 0)
  win32api.mouse_event(win32con.MOUSEEVENTF_LEFTUP, 0, 0, 0, 0)
  fl = 0

def gogo(): win32api.SetCursorPos([left, top]) win32api.mouse_event(win32con.MOUSEEVENTF_LEFTDOWN, 0, 0, 0, 0) win32api.mouse_event(win32con.MOUSEEVENTF_LEFTUP, 0, 0, 0, 0) showmap() global gameover while(1): if(gameover == 0):  banner()  banner()  dig() else:  gameover = 0  win32api.keybd_event(113, 0, 0, 0)  win32api.SetCursorPos([left, top])  win32api.mouse_event(win32con.MOUSEEVENTF_LEFTDOWN, 0, 0, 0, 0)  win32api.mouse_event(win32con.MOUSEEVENTF_LEFTUP, 0, 0, 0, 0)  showmap()

这几个算法在低档和高级中学级通过率都不利,可是在高档成功率惨不忍睹,首要是从未牵记逻辑组合以及白块是雷的可能率难题,能够对那八个点进行改良,进步成功率

总结

如上正是那篇小说的全体内容了,希望本文的始末对我们的学习或然职业具备一定的参照学习价值,假使不不奇怪大家能够留言调换,多谢大家对台本之家的支撑。

您大概感兴趣的稿子:

  • 根据Python达成的扫雷游戏实例代码
  • Python自动扫雷落成形式
  • 用python写扫雷游戏实例代码分享

Leave a Comment.