OpenCV 模板匹配


Posted in Python onJuly 10, 2019

最近小编实现一个微信小程序「跳一跳」的自动化。

主要涉及到了OpenCV的模板匹配和边缘检测技术,以及Android开发调试工具ADB。

如果放在一起说,感觉内容有些多。

所以,分三期来讲,也能多了解一些东西。

首先介绍模板匹配,然后边缘检测,最后结合ADB实现「跳一跳」自动化。

游戏虽然过时了,但是拿来练练手还是不错的。

编程就该是快乐的,哈哈。

/ 01 / 模板匹配

模板匹配,就是在整个图像区域里发现与给定子图像相匹配的小块区域。

这里需要一个模板图像(给定的子图像)和一个待检测的图像(原图像)。

在待检测图像上,从左向右,从上向下计算模板图像与重叠子图像的匹配度,匹配度越大,两者相同的可能性越大。

OpenCV 模板匹配

这里主要涉及OpenCV的cv2.matchTemplate()cv2.minMaxLoc()函数。

第一个函数作用是在模板和输入图像之间寻找匹配,获得匹配结果图像。

第二个函数的作用则是在给定的矩阵中寻找最大和最小值(包括它们的位置)。

其中模板匹配算法有以下六种。

# 第一类,利用平方差来进行匹配,最好匹配为0.匹配越差,匹配值越大
# 平方差匹配
method=CV_TM_SQDIFF
# 标准平方差匹配
method=CV_TM_SQDIFF_NORMED
# 第二类,采用模板和图像间的乘法操作,所以较大的数表示匹配程度较高,0标识最坏的匹配效果
# 相关匹配
method=CV_TM_CCORR
# 标准相关匹配
method=CV_TM_CCORR_NORMED
# 第三类,将模版对其均值的相对值与图像对其均值的相关值进行匹配,1表示完美匹配,-1表示糟糕的匹配,0表示没有任何相关性(随机序列)
# 相关系数匹配
method=CV_TM_CCOEFF
# 标准相关系数匹配
method=CV_TM_CCOEFF_NORMED

标准化意味着将数值统一到0~1。

除了平方差类型的是值越小越好,其他的都是值越大越好。

/ 02 / 图像检索

首先来看一下两张图像,都为灰度图。

import cv2
# 读取待检测图像
img = cv2.imread('game.png', 0)
# 读取模板图像
temple = cv2.imread('temple.png', 0)
# 显示灰度处理后的待检测图像
cv2.namedWindow('sample', 0)
cv2.resizeWindow('sample', 400, 600)
cv2.imshow('sample', img)
# 显示灰度处理后的模板图像
cv2.namedWindow('target', 0)
cv2.resizeWindow('target', 400, 600)
cv2.imshow('target', temple)

输出结果如下。

OpenCV 模板匹配

第一张为模板图像,第二张为待检测图像。

下面使用OpenCV的两个函数,来实现模板匹配。

# 获取模板图像的高和宽
th, tw = temple.shape[:2]
print(th, tw)
# 使用标准相关系数匹配,1表示完美匹配,-1表示糟糕的匹配,0表示没有任何相关性
result = cv2.matchTemplate(img, temple, cv2.TM_CCOEFF_NORMED)
# result为匹配结果矩阵
# print(result)
# TM_CCOEFF_NORMED方法处理后的结果图像
cv2.namedWindow('match_r', 0)
cv2.resizeWindow('match_r', 400, 600)
# 显示窗口
cv2.imshow('match_r', result)
# 使用函数minMaxLoc,确定匹配结果矩阵的最大值和最小值(val),以及它们的位置(loc)
min_val, max_val, min_loc, max_loc = cv2.minMaxLoc(result)
# 此处选取最大值的位置,为图像的左上角
tl = max_loc
# 获取图像的右下角
br = (tl[0]+tw, tl[1]+th)
# 绘制矩形框
cv2.rectangle(img, tl, br, (0, 0, 255), 2)
# 设置显示窗口
cv2.namedWindow('match', 0)
cv2.resizeWindow('match', 400, 600)
# 显示窗口
cv2.imshow('match', img)
# 结束
cv2.waitKey(0)
cv2.destroyAllWindows()

输出结果如下。

OpenCV 模板匹配

第一张图中最白的位置,即代表着最高的匹配。

第二张图中,矩形框则代表着匹配到的结果。

通过矩形框的位置参数,结合模板图像的大小,便可得到小跳棋中心点位置(底部)。

/ 03 / 总结

现在既然能检测到「跳一跳」小跳棋的位置,那么下一步就是方块的位置啦。

Python 相关文章推荐
利用Psyco提升Python运行速度
Dec 24 Python
在Python的Flask框架中使用日期和时间的教程
Apr 21 Python
Python 常用string函数详解
May 30 Python
Python中关键字global和nonlocal的区别详解
Sep 03 Python
Python脚本修改阿里云的访问控制列表的方法
Mar 08 Python
Windows系统Python直接调用C++ DLL的方法
Aug 01 Python
解决TensorFlow程序无限制占用GPU的方法
Jun 30 Python
python 遍历磁盘目录的三种方法
Apr 02 Python
利用Python多线程实现图片下载器
Mar 25 Python
利用Python将list列表写入文件并读取的方法汇总
Mar 25 Python
详解NumPy中的线性关系与数据修剪压缩
May 25 Python
深入理解pytorch库的dockerfile
Jun 10 Python
8种用Python实现线性回归的方法对比详解
Jul 10 #Python
Python实现计算对象的内存大小示例
Jul 10 #Python
Python画图高斯分布的示例
Jul 10 #Python
使用Python实现跳一跳自动跳跃功能
Jul 10 #Python
windows安装TensorFlow和Keras遇到的问题及其解决方法
Jul 10 #Python
使用python对多个txt文件中的数据进行筛选的方法
Jul 10 #Python
Python 占位符的使用方法详解
Jul 10 #Python
You might like
PHP邮件专题
2006/10/09 PHP
PHP浮点数的一个常见问题
2016/03/10 PHP
CheckBox 如何实现全选?
2006/06/23 Javascript
jQuery 加上最后自己的验证
2009/11/04 Javascript
JQuery获取文本框中字符长度的代码
2011/09/29 Javascript
javascript 10进制和62进制的相互转换
2014/07/31 Javascript
Javascript基础教程之if条件语句
2015/01/18 Javascript
jQuery实现复选框成对选择及对应取消的方法
2015/03/03 Javascript
javascript版2048小游戏
2015/03/18 Javascript
javascript实现十秒钟后注册按钮可点击的方法
2015/05/13 Javascript
js表单验证实例讲解
2016/03/31 Javascript
jQuery文件上传控件 Uploadify 详解
2016/06/20 Javascript
快速解决js中window.location.href不工作的问题
2016/11/02 Javascript
DOM事件探秘篇
2017/02/15 Javascript
Vue获取DOM元素样式和样式更改示例
2017/03/07 Javascript
令按钮悬浮在(手机)页面底部的实现方法
2017/05/02 Javascript
通过V8源码看一个关于JS数组排序的诡异问题
2017/08/14 Javascript
JS实现点击复选框变更DIV显示状态的示例代码
2017/12/18 Javascript
一个小时快速搭建微信小程序的方法步骤
2019/04/15 Javascript
了解Javascript中函数作为对象的魅力
2019/06/19 Javascript
解决vue admin element noCache设置无效的问题
2019/11/12 Javascript
vue基于v-charts封装双向条形图的实现代码
2019/12/09 Javascript
[03:27]《辉夜杯》线下训练营 导师CU和海涛指点迷津
2015/10/23 DOTA
Python中的字典与成员运算符初步探究
2015/10/13 Python
Python使用requests发送POST请求实例代码
2018/01/25 Python
Python之用户输入的实例
2018/06/22 Python
python3去掉string中的标点符号方法
2019/01/22 Python
Python爬虫爬取电影票房数据及图表展示操作示例
2020/03/27 Python
影视艺术学院毕业生自荐信
2013/11/13 职场文书
酒店办公室文员岗位职责
2013/12/18 职场文书
领导干部培训感言
2014/01/23 职场文书
司机岗位职责说明书
2014/07/29 职场文书
2014年党员评议表自我评价
2014/09/27 职场文书
班级管理经验交流材料
2015/11/02 职场文书
JavaScript实现显示和隐藏图片
2021/04/29 Javascript
Ruby处理YAML和json数据
2022/04/18 Ruby