安卓版本微信跳一跳自动执行代码剖析

手动版的这里不多说,图像识别,坐标计算跳跃,要想得高分会点的手疼。这里主要剖析下自动版的,这里仅介绍安卓版本。

整体的结构

脚本的整体结构还是比较简洁的,如下图所示。

  • 手机连接PC,PC通过adb命令对手机游戏界面进行截图;
  • PC通过adb命令将该截图拷贝回PC;
  • PC端通过python对图像进行处理(第一版中使用的opencv,目前使用的是直接读取像素的rgb值),获取棋子的位置,获取下一个棋盘的位置,然后计算出下一跳的距离,从而根据经验值计算出按压时间t;
  • 通过adb命令模拟按压时间t即可实现棋子的跳跃;
  • 重复1~4就可以自动化执行“跳一跳”游戏。

安卓手机屏幕坐标

代码剖析

主函数代码

def main():

  #获取设备信息
  dump_device_info()

  #检查adb
  check_adb()

  #主循环
  while True:

    #通过adb截图,并将图片拷贝回PC
    pull_screenshot()

    #将图片加载进内存
    im = Image.open('./autojump.png')

    # 获取棋子和 board 的位置
    piece_x, piece_y, board_x, board_y =   find_piece_and_board(im)

    #打印调试信息
    ts = int(time.time())
    print(ts, piece_x, piece_y, board_x, board_y)

    #将按压的位置设置为【再来一局】的位置,这样失败的时候可以自动开始
    set_button_position(im)

    #计算下一跳的距离,根据经验值转换为时间,并通过adb下发给设备模拟按压
    jump(math.sqrt((board_x - piece_x) ** 2 + (board_y - piece_y) ** 2))

    #对调试界面进行截图,方便调试。并将调试截图进行备份
    save_debug_creenshot(ts, im, piece_x, piece_y, board_x, board_y)
    backup_screenshot(ts)

    # 为了保证截图的时候应落稳了,多延迟一会儿
    time.sleep(random.uniform(1, 1.1))

通过adb下发截图命令,并将截图拷贝回PC,这里直接使用了adb命令,不多解释。

def pull_screenshot():
  os.system('del autojump.png')
  os.system('adb shell screencap -p /sdcard/autojump.png')
  os.system('adb pull /sdcard/autojump.png .')

计算坐标

find_piece_and_board函数为核心代码,这里主要做了两件事情:一是计算棋子的位置;二是计算下一个棋盘的位置。下面挑主要代码说。

1.查找棋子的位置坐标

#这里是在简单地查找下范围,其实不加也行,但是将整个屏幕遍历一遍太浪费时间,作者做了两件事情
#1.先查找屏幕1/3~2/3范围,自上而下
#2.查找与背景颜色不同的点就停止,说明从这个高度开始下面的像素点可能就是棋子或底座
for i in range(int(h / 3), int( h*2 /3 ), 50):
  last_pixel = im_pixel[0,i]
  for j in range(1, w):
   pixel=im_pixel[j,i]

   #不是纯色的线,则记录scan_start_y的值,准备跳出循环
   #pixel数组中的0 1 2分别是RGB三色值,只要存在一个不相同说明该点不是背景颜色
   if pixel[0] != last_pixel[0] or pixel[1] != last_pixel[1] or pixel[2] != last_pixel[2]:

    #向上退回50个像素,以免上面的这个高度不是最上面的不同像素点
    scan_start_y = i - 50
    break

  #跳出循环
  if scan_start_y:
   break

 #作者开始接着上面的点自上而下详细遍历
 # 从scan_start_y开始往下扫描,棋子应位于屏幕上半部分,这里暂定不超过2/3
 for i in range(scan_start_y, int(h * 2 / 3)):

  # 横坐标去除一定的边界,然后开始遍历,节省了一部分时间
  for j in range(scan_x_border, w - scan_x_border): 

   #取出该坐标上的坐标点
   pixel = im_pixel[j,i]

   #这里是查找棋子的最低一行,根据颜色进行判别,RGB的范围作者是事先取好的
   # 根据棋子的最低行的颜色判断,找最后一行那些点的平均值,这个颜色这样应该 OK,暂时不提出来
   if (50 < pixel[0] < 60) and (53 < pixel[1] < 63) and (95 < pixel[2] < 110):

    #像素点的横坐标值之和,因为棋子是对称的,这些横坐标的平均值就是棋子的中心位置
    piece_x_sum += j
    piece_x_c += 1

    #棋子最低点所处的位置
    piece_y_max = max(i, piece_y_max)

 #如果其中有一个为0,则直接返回异常
 if not all((piece_x_sum, piece_x_c)):
  return 0, 0, 0, 0

 #平均得到棋子的横坐标
 piece_x = piece_x_sum / piece_x_c

 #棋子的最低点并不是棋子所在的中心位置,需要补偿一定的值,这个值就是棋子底盘的高度一半
 piece_y = piece_y_max - piece_base_height_1_2

2.查找下一跳底盘的坐标

 #同样,查找缩小查找范围,只查找屏幕1/3~2/3范围之内的
 for i in range(int(h / 3), int(h * 2 / 3)):

 #取边界上的坐标作为上一次坐标初始值。该变量的作用是判断像素是否变化,如果变化则进入了底座像素
 last_pixel = im_pixel[0, i]

 #如果计算得到了坐标,跳出循环
 if board_x or board_y:
 break

 #与查找棋子类型,底座也是对称的,则像素点横坐标的平均值就是底座的中心点
 board_x_sum = 0
 board_x_c = 0

 #开始查找底座,横向扫描
 for j in range(w):

 #取出一个像素点
 pixel = im_pixel[j,i]

 # 修掉脑袋比下一个小格子还高的情况的 bug
 if abs(j - piece_x) < piece_body_width:
 continue

 #像素点的RGB值发生了变化,则说明进入了底座像素区域
 # 修掉圆顶的时候一条线导致的小 bug,这个颜色判断应该 OK,暂时不提出来
 if abs(pixel[0] - last_pixel[0]) + abs(pixel[1] - last_pixel[1]) + abs(pixel[2] - last_pixel[2]) > 10:
 board_x_sum += j
 board_x_c += 1

 #计算底座的横坐标
 if board_x_sum:
 board_x = board_x_sum / board_x_c

 #下一个底座是在当前底座的30度方向,所以根据上面计算出的横坐标可以计算出底座的纵坐标
 # 按实际的角度来算,找到接近下一个 board 中心的坐标 这里的角度应该是30°,值应该是tan 30°, math.sqrt(3) / 3
 board_y = piece_y - abs(board_x - piece_x) * math.sqrt(3) / 3

 #如果有一个值为空,返回异常
 if not all((board_x, board_y)):
 return 0, 0, 0, 0

进行跳跃

知道当前坐标和下一跳的坐标,则可以计算出两点间的距离。

math.sqrt((board_x - piece_x) ** 2 + (board_y - piece_y) ** 2)

然后将该值传给跳跃函数即可

#该函数由距离根据经验值计算出按压时间
def jump(distance):
 press_time = distance * press_coefficient
 press_time = max(press_time, 200) # 设置 200 ms 是最小的按压时间
 press_time = int(press_time)

 #通过adb传输模拟按压命令
 cmd = 'adb shell input swipe {x1} {y1} {x2} {y2} {duration}'.format(
 x1=swipe['x1'],
 y1=swipe['y1'],
 x2=swipe['x2'],
 y2=swipe['y2'],
 duration=press_time
 )
 print(cmd)
 os.system(cmd)

总而言之,代码很简洁易读,感谢原作者的无私奉献,https://github.com/wangshub/wechat_jump_game

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持我们。

(0)

相关推荐

  • 微信跳一跳辅助Java代码实现

    微信跳一跳辅助的Java具体实现代码,供大家参考,具体内容如下 1.参考知乎教你用Python来玩微信跳一跳,鉴于本人Python一直都是半吊子水平,之前打算用python刷分,可无奈安装python环境各种模块缺失,报错不停,于是乎,使用Java重新实现了一下. 2.环境配置及相关说明: 1).Windows系统,本人win10 2).AVA环境安装,JDK7以上即可 3).安卓手机一部.数据线一条 4).电脑安装ADB驱动,连接安卓手机,同时打开USB调试模式 5).打开微信小程序的跳一跳游

  • 利用Kotlin实现破解Android版的微信小游戏--跳一跳

    前言 昨天下午,微信小程序开放了游戏接口,朋友圈瞬间炸开了锅,尤其是"跳一跳"这款游戏的成绩单,在朋友圈刷了一波又一波. 下面就来给大家介绍了关于Kotlin破解Android版的微信小游戏跳一跳的相关内容,让大家可以好好炫耀一番. 成果 跳一跳 微信小程序可以玩游戏了,我们来破解一下<跳一跳>这个官方出品的小游戏吧. 思路 用usb调试安卓手机,用adb截图并用鼠标测量距离,然后计算按压时间后模拟按压. $ adb shell input swipe <x1>

  • Android版微信跳一跳小游戏利用技术手段达到高分的操作方法

    本文主要来讲个个好玩的东西,近来微信刚出的跳一跳微信小程序的游戏很火,看到很多人都达到了二三百分就各种刷朋友圈了. 甩手一个表情 最终我们达到的分数却是这样的: 羡慕吧 一定会有人拍手叫好,"黄金右手"!说真的,我已经不用右手好多年,而且我玩这个游戏压根就没用手,而是意念!哈哈,别喷我,开个玩笑而已,肯定是利用技术手段啦,什么技术?python喽-哈哈,不过不是我写的,我自己是做Android开发的,我对于python从来没有接触,只是恰好在蛋哥公众号看到关于这个游戏的文章,觉得有意思

  • 安卓版本微信跳一跳自动执行代码剖析

    手动版的这里不多说,图像识别,坐标计算跳跃,要想得高分会点的手疼.这里主要剖析下自动版的,这里仅介绍安卓版本. 整体的结构 脚本的整体结构还是比较简洁的,如下图所示. 手机连接PC,PC通过adb命令对手机游戏界面进行截图: PC通过adb命令将该截图拷贝回PC: PC端通过python对图像进行处理(第一版中使用的opencv,目前使用的是直接读取像素的rgb值),获取棋子的位置,获取下一个棋盘的位置,然后计算出下一跳的距离,从而根据经验值计算出按压时间t: 通过adb命令模拟按压时间t即可实

  • 安卓版微信跳一跳辅助 跳一跳辅助Java代码

    安卓版微信跳一跳辅助,java实现,具体内容如下 已经看到网上有大神用各种方式实现了,我这是属于简易版ADB命令式实现. 操作方法 1.光标移动到起始点,点击FORM 2.光标移动到目标点,点击TO 3.小人已经跳过去了 原理说明 安装APP,通过设置起点和目标点位置,获得弹跳的毫秒数,发送请求到连接手机的电脑中,电脑执行adb命令起跳. 具体实现 本人的测试设备是Mate9,android版本为7.0,由于在非Root环境下,普通安卓应用并不能通过Runtime.getRuntime().ex

  • python微信跳一跳游戏辅助代码解析

    这个代码实现的是   手动点击起点 和 终点  ,程序自动判断距离.触屏时间  完成跳跃 原理(摘自项目说明页面): 1. 将手机点击到"跳一跳"小程序界面: 2. 用Adb 工具获取当前手机截图,并用adb将截图pull上来: adb shell screencap -p /sdcard/1.png adb pull /sdcard/1.png . 3. 用matplot显示截图: 4. 用鼠标点击起始点和目标位置,计算像素距离: 5. 根据像素距离,计算按压时间: 6. 用Adb工

  • 微信跳一跳辅助python代码实现

    微信跳一跳辅助的python具体实现代码,供大家参考,具体内容如下 这是一个 2.5D 插画风格的益智游戏,玩家可以通过按压屏幕时间的长短来控制这个「小人」跳跃的距离.可能刚开始上手的时候,因为时间距离之间的关系把握不恰当,只能跳出几个就掉到了台子下面. 玩法类似于<flappy bird> 下载github的一个程序,但是在windows10下不能运行,原因是windows10下没有copy命令了,修改为Python自带的复制方法,即可完成.今天运行好像一开始不能正确跳第一次,人工辅助后,后

  • 微信跳一跳自动脚本C#代码实现

    前言 CSDN前阵子推送了篇文章,讲的是微信跳一跳的技术实现,大致浏览,发现难度不高,很适合练手. 思路 ADB得到屏幕截图,转换成bitmap逐像素分析图像,得到跳跃起点和终点坐标,最后ADB按压屏幕进行跳跃 相关知识 ADB创建 ·在https://adb.clockworkmod.com提前下载ADB ·通过 Process类 创建进程运行ADB Process p = new Process(); p.StartInfo = new ProcessStartInfo() { FileNa

  • 微信跳一跳刷分java代码实现

    朋友圈晒跳一跳成绩好久了,今天无意中看到以前一个同事小妞晒用代码刷分的视频,百度了一下果然看到了代码(代码在最后),几经波折,终于成功运行,刷了一点分数. 首先大概说一下步骤: 1.百度下载刷分代码 2.安装adb 3.找个手机使用USB调试模式连接电脑 4.启动跳一跳微信小程序 5.在eclipse中运行代码(此处要不断调试根据手机屏幕大小修改参数) 结果就是你的手机屏幕会自动按压然后让棋子跳. 再说下问题: 一.安装adb问题集: 下载adb工具地址 在此处的设备管理器中,如果没有安装在其他

  • 微信跳一跳自动运行python脚本

    本文实例为大家分享了微信小程序跳一跳自动运行脚本,供大家参考,具体内容如下 1.压缩包带了adb等必须工具,配置一下环境变量即可 2.Python 直接运行即可 (Python3.6) 代码: wechat_jump_auto.py # coding: utf-8 ''' # === 思路 === # 核心:每次落稳之后截图,根据截图算出棋子的坐标和下一个块顶面的中点坐标, # 根据两个点的距离乘以一个时间系数获得长按的时间 # 识别棋子:靠棋子的颜色来识别位置,通过截图发现最下面一行大概是一条

  • 微信跳一跳python自动代码解读1.0

    微信跳一跳自动代码,具体内容如下 那个跳一跳python"外挂",有几个python文件,其中有一个是得到截图,然后鼠标在图片上点击两次,python窗口上会打印两次鼠标的位置,并且会跟上一行这两个点之间的距离. 这个功能我先给除去获取截屏,就说怎么在某张图片上算出两次点击的距离. 首先,需要用到图形模块,PIL: from PIL import Image img = Image.open('0.jpg') 然后用图形绘制模块matplotlib来给出一个plot对象: import

  • 微信跳一跳python代码实现

    本文实例为大家分享了python微信跳一跳的具体代码,供大家参考,具体内容如下 部分代码分享: wechat_jump.py from __future__ import print_function import numpy as np import matplotlib.pyplot as plt import matplotlib.animation as animation import math import time import os import cv2 import datet

随机推荐