python屏幕截图、图像数组、鼠标移动点击的游戏外挂应用

以程序自动完成游戏黑白块为例:

                                 

程序的逻辑是:

一、获取游戏界面屏幕截图

  hwnd = 0 # 窗口的编号,0号表示当前活跃窗口
  # 根据窗口句柄获取窗口的设备上下文DC(Divice Context)
  hwndDC = win32gui.GetWindowDC(hwnd)
  # 根据窗口的DC获取mfcDC
  mfcDC = win32ui.CreateDCFromHandle(hwndDC)
  # mfcDC创建可兼容的DC
  saveDC = mfcDC.CreateCompatibleDC()
  # 创建bigmap准备保存图片
  saveBitMap = win32ui.CreateBitmap()
  # 获取监控器信息
  MoniterDev = win32api.EnumDisplayMonitors(None, None)
  # w = MoniterDev[0][2][2]
  # h = MoniterDev[0][2][3]
  w=620
  h=1080
  #print w,h   #图片大小
  # 为bitmap开辟空间
  saveBitMap.CreateCompatibleBitmap(mfcDC, w, h)
  # 高度saveDC,将截图保存到saveBitmap中
  saveDC.SelectObject(saveBitMap)
  # 截取从左上角(0,0)长宽为(w,h)的图片
  saveDC.BitBlt((0, 0), (w, h), mfcDC, (0, 0), win32con.SRCCOPY)
  saveBitMap.SaveBitmapFile(mfcDC, filename)

前面的dc的概念还是挺复杂的,只考虑应用的话关注几个参数就可以了。这一段程序的最中将主屏幕的(0,0)到(620,1080)((横坐标,纵坐标))的矩形截图保存在python工程目录中。32位色图

二、转化为图像数组

  img = Image.open("haha.jpg")
  img_1 = img.convert('L')  # 转灰度
  img_2 = array(img_1,'f') #转数组

第一行打开图像;

第二行为 “from PIL import Image”中的图像处理

第三行转为array

PIL有九种不同模式: 1,L,P,RGB,RGBA,CMYK,YCbCr,I,F。

其中,1和L较为常用,也容易理解

        1: 非黑即白,也就是二值化,只有0和255

        L: 灰度图,为0到255之间的数

三、游戏逻辑

        太简单了不介绍了

        此外还需要延时方法,高版本python的sleep()已经支持参数为小数了

        import time
        time.sleep(0.5)#延时0.5秒

四、鼠标点击

要安装pyHook、PyMouse、PyUesrInput,安装遇到问题可自行百度。pyHook好像不支持太高版本的python,加上我的pip包也不好使,自己试了好长时间才搞定pyHook             ~WWW~

需要安装

win32gui
pyHook
PyUserInput
PyMoouse
matplotlib
numpy

02e38ef59020e2fb76572d3422e52a1e.png

鼠标点击常用的语句有:

 m = PyMouse()
 a = m.position()  # 获取当前坐标的位置
 m.click(80, 900)  # 移动并且在(x,y)位置左击

最后附上总的代码,不用谢因为:

#time:2022/1/26  18:43
#author:
#
import time
import win32gui, win32ui, win32con, win32api
from pymouse import PyMouse
import numpy as np
import matplotlib.pyplot as plt
# from ctypes import *
import os
from pylab import *
from PIL import Image

def window_capture(filename):
  hwnd = 0 # 窗口的编号,0号表示当前活跃窗口
  # 根据窗口句柄获取窗口的设备上下文DC(Divice Context)
  hwndDC = win32gui.GetWindowDC(hwnd)
  # 根据窗口的DC获取mfcDC
  mfcDC = win32ui.CreateDCFromHandle(hwndDC)
  # mfcDC创建可兼容的DC
  saveDC = mfcDC.CreateCompatibleDC()
  # 创建bigmap准备保存图片
  saveBitMap = win32ui.CreateBitmap()
  # 获取监控器信息
  MoniterDev = win32api.EnumDisplayMonitors(None, None)
  # w = MoniterDev[0][2][2]
  # h = MoniterDev[0][2][3]
  w=620
  h=1080
  #print w,h   #图片大小
  # 为bitmap开辟空间
  saveBitMap.CreateCompatibleBitmap(mfcDC, w, h)
  # 高度saveDC,将截图保存到saveBitmap中
  saveDC.SelectObject(saveBitMap)
  # 截取从左上角(0,0)长宽为(w,h)的图片
  saveDC.BitBlt((0, 0), (w, h), mfcDC, (0, 0), win32con.SRCCOPY)
  saveBitMap.SaveBitmapFile(mfcDC, filename)

  img = Image.open("haha.jpg")
  img_1 = img.convert('L')  # 转灰度
  img_2 = array(img_1,'f') #转白色

  m = PyMouse()
  a = m.position()  # 获取当前坐标的位置
  # print(img_2[780][80]+img_2[780][70]+img_2[780][90])
  hhh=720
  if img_2[hhh][80]+img_2[hhh][70]+img_2[hhh][90]<3*200:
    m.click(80, 900)  # 移动并且在(x,y)位置左击
  if img_2[hhh][240]+img_2[hhh][230]+img_2[hhh][250]<3*200:
    m.click(240, 900)  # 移动并且在(x,y)位置左击
  if img_2[hhh][400]+img_2[hhh][410]+img_2[hhh][390]<3*200:
    m.click(400, 900)  # 移动并且在(x,y)位置左击
  if img_2[hhh][560]+img_2[hhh][570]+img_2[hhh][550]<3*200:
    m.click(560, 900)  # 移动并且在(x,y)位置左击
  # # print('色块: ',aaa)
  img_1.save('h灰度.jpg')
  img.close()

used_time=0;
arrey_time=0.1
for i in range(3):
  beg = time.time()
  window_capture("haha.jpg")
  end = time.time()
  used_time=end - beg
  print('延时',used_time,'     ',i)
  if used_time<arrey_time:
    time.sleep(arrey_time+beg-end)

  • 2
    点赞
  • 15
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值