python微信跳一跳系列之棋子定位像素遍历


Posted in Python onFebruary 26, 2018

前言

在前几篇博客中,分别就棋子的颜色识别、模板匹配等定位方式进行了介绍和实践,这一篇博客就来验证一下github中最热门的跳一跳外挂中采用的像素遍历的方法。

方法说明

像素遍历的实质依然是颜色识别。
在github中给出的方法中,采用像素遍历的方法是:

  • 从高度的1/3处开始至高度的2/3处进行遍历;
  • 首先间隔50像素进行搜索
  • 当像素的颜色和每一行开始的像素颜色不同时,认为找到了最上面的棋盘位置,则返回上一个间隔处开始遍历(i-50);
  • 对每一行的像素都进行遍历,当满足给定的颜色范围时,记录最下面一行的y值,x值的和与个数,平均即可得到中心x值。
  • 所得到的x值和y值即为棋子最底部的中心位置;
  • 按照自己手机的分辨率调整棋子的高度(减去一个固定值)

上诉方法的代码如下(可以自行到github下载):

def find_piece_and_board(im):
 #寻找关键坐标
 w, h = im.size

 piece_x_sum = 0
 piece_x_c = 0
 piece_y_max = 0
 board_x = 0
 board_y = 0
 scan_x_border = int(w / 8) # 扫描棋子时的左右边界
 scan_start_y = 0 # 扫描的起始 y 坐标
 im_pixel = im.load()
 # 以 50px 步长,尝试探测 scan_start_y
 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 的值,准备跳出循环
  if pixel != last_pixel:
  scan_start_y = i - 50
  break
 if scan_start_y:
  break
 print('scan_start_y: {}'.format(scan_start_y))

 # 从 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]
  # 根据棋子的最低行的颜色判断,找最后一行那些点的平均值,这个颜
  # 色这样应该 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)

 if not all((piece_x_sum, piece_x_c)):
 return 0, 0, 0, 0
 piece_x = int(piece_x_sum / piece_x_c)
 piece_y = piece_y_max - piece_base_height_1_2 # 上移棋子底盘高度的一半

遍历过程动态演示

python微信跳一跳系列之棋子定位像素遍历

实际运行动画

以下是实际运行的定位动画。

python微信跳一跳系列之棋子定位像素遍历

优缺点分析

像素遍历的好处是无需额外的python库,但其速度显然明显低于我在前面用过的其它方法,这不奇怪,外接库用到的颜色识别方法其实是经过优化和集成的,像素遍历是其底层的技术方案,速度慢理所当然。

改进

其实上述方法还可以进一步优化,以大大减小遍历的面积:

  • 以50像素为间隔从1/3高度开始遍历;
  • 当首次满足给定的棋子颜色时,记录x值的和与个数,平均后得到棋子的x值;
  • 沿x值从上向下对高度进行遍历,可以得到满足棋子颜色的最大y值和最小y值;
  • 对y值进行处理,如减去一个固定高度,即可得到棋子的底部中心y值;
  • 对最高点和最低点进行平均,即可得到棋盘的中心y值。

遍历的过程如下:

python微信跳一跳系列之棋子定位像素遍历

后记

可以看到,优化后的遍历个数大大减小,速度得到极大提高。

更多内容大家可以参考专题《微信跳一跳》进行学习。

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

Python 相关文章推荐
Django中URLconf和include()的协同工作方法
Jul 20 Python
在Django的session中使用User对象的方法
Jul 23 Python
python使用matplotlib绘制折线图教程
Feb 08 Python
Python自动化运维之IP地址处理模块详解
Dec 10 Python
python机器学习理论与实战(四)逻辑回归
Jan 19 Python
Python使用matplotlib模块绘制图像并设置标题与坐标轴等信息示例
May 04 Python
python utc datetime转换为时间戳的方法
Jan 15 Python
pycharm创建scrapy项目教程及遇到的坑解析
Aug 15 Python
详解Django配置优化方法
Nov 18 Python
pytorch实现mnist分类的示例讲解
Jan 10 Python
Python 类,对象,数据分类,函数参数传递详解
Sep 25 Python
Python 第三方库 openpyxl 的安装过程
Dec 24 Python
python3.6+opencv3.4实现鼠标交互查看图片像素
Feb 26 #Python
python微信跳一跳系列之自动计算跳一跳距离
Feb 26 #Python
python微信跳一跳系列之色块轮廓定位棋盘
Feb 26 #Python
tensorflow入门之训练简单的神经网络方法
Feb 26 #Python
基于Python实现的微信好友数据分析
Feb 26 #Python
TensorFlow 实战之实现卷积神经网络的实例讲解
Feb 26 #Python
使用django-crontab实现定时任务的示例
Feb 26 #Python
You might like
PHP中str_replace函数使用小结
2008/10/11 PHP
PHP5中使用PDO连接数据库的方法
2010/08/01 PHP
解析centos中Apache、php、mysql 默认安装路径
2013/06/25 PHP
php实现图片局部打马赛克的方法
2015/02/11 PHP
cakephp打印sql语句的方法
2015/02/13 PHP
php数组键值用法实例分析
2015/02/27 PHP
PHP+ajax分页实例简析
2015/12/07 PHP
PHP单例模式数据库连接类与页面静态化实现方法
2019/03/20 PHP
JavaScript 高级语法介绍
2009/06/15 Javascript
javascript oop开发滑动(slide)菜单控件
2010/08/25 Javascript
javascript使用eval或者new Function进行语法检查
2010/10/16 Javascript
最短的IE判断代码
2011/03/13 Javascript
js内置对象 学习笔记
2011/08/01 Javascript
js中有关IE版本检测
2012/01/04 Javascript
javascript去除空格方法小结
2015/05/21 Javascript
JS排序之快速排序详解
2017/04/08 Javascript
js canvas实现简单的图像扩散效果
2020/06/28 Javascript
JS生成随机打乱数组的方法示例
2017/12/23 Javascript
jQuery+SpringMVC中的复选框选择与传值实例
2018/01/08 jQuery
[44:04]OG vs Mineski 2018国际邀请赛小组赛BO2 第一场 8.17
2018/08/18 DOTA
用Python实现服务器中只重载被修改的进程的方法
2015/04/30 Python
python模拟Django框架实例
2016/05/17 Python
python中利用Future对象异步返回结果示例代码
2017/09/07 Python
PyCharm-错误-找不到指定文件python.exe的解决方法
2019/07/01 Python
Python中Unittest框架的具体使用
2019/08/27 Python
Django中使用haystack+whoosh实现搜索功能
2019/10/08 Python
python实现通过队列完成进程间的多任务功能示例
2019/10/28 Python
Python字符串hashlib加密模块使用案例
2020/03/10 Python
澳大利亚人信任的清洁平台,您的私人管家:Jarvis
2020/12/25 全球购物
short s1 = 1; s1 = s1 + 1;有什么错? short s1 = 1; s1 += 1;有什么错?
2014/09/26 面试题
幼儿教师求职信
2014/05/24 职场文书
小学国旗下的演讲稿
2014/08/28 职场文书
节水倡议书
2015/01/19 职场文书
安全知识竞赛主持词
2015/06/30 职场文书
小学班主任教育随笔
2015/08/15 职场文书
离婚协议书范文2016
2016/03/18 职场文书