2017年9月22日 BY 蓝鲸 LEAVE A COMMENT

本篇文章介绍使用Python和OpenCV对图像进行模板匹配和识别。模板匹配是在图像中寻找和识别模板的一种简单的方法。以下是具体的步骤及代码。

首先导入所需库文件,numpy和cv2。

Source code    
  1. #导入所需库文件
  2. import cv2
  3. import numpy as np

然后加载原始图像和要搜索的图像模板。OpenCV对原始图像进行处理,创建一个灰度版本,在灰度图像里进行处理和查找匹配。然后使用相同的坐标在原始图像中进行还原并输出。

Source code    
  1. #加载原始RGB图像
  2. img_rgb = cv2.imread("photo.jpg")
  3. #创建一个原始图像的灰度版本,所有操作在灰度版本中处理,然后在RGB图像中使用相同坐标还原
  4. img_gray = cv2.cvtColor(img_rgb, cv2.COLOR_BGR2GRAY)
  5.  
  6. #加载将要搜索的图像模板
  7. template = cv2.imread('face.jpg',0)
  8. #记录图像模板的尺寸
  9. w, h = template.shape[::-1]

这里我们分别输出并查看原始图像,原始图像的灰度版本,以及图像模板。

Source code    
  1. #查看三组图像(图像标签名称,文件名称)
  2. cv2.imshow('rgb',img_rgb)
  3. cv2.imshow('gray',img_gray)
  4. cv2.imshow('template',template)
  5. cv2.waitKey(0)
  6. cv2.destroyAllWindows()

使用matchTemplate在原始图像中查找并匹配图像模板中的内容,并设置阈值。

Source code    
  1. #使用matchTemplate对原始灰度图像和图像模板进行匹配
  2. res = cv2.matchTemplate(img_gray,template,cv2.TM_CCOEFF_NORMED)
  3. #设定阈值
  4. threshold = 0.7
  5. #res大于70%
  6. loc = np.where( res >= threshold)

匹配完成后在原始图像中使用灰度图像的坐标对原始图像进行标记。

Source code    
  1. #使用灰度图像中的坐标对原始RGB图像进行标记
  2. for pt in zip(*loc[::-1]):
  3. cv2.rectangle(img_rgb, pt, (pt[0] + w, pt[1] + h), (7,249,151), 2)
  4. #显示图像
  5. cv2.imshow('Detected',img_rgb)
  6. cv2.waitKey(0)
  7. cv2.destroyAllWindows()

以下为完整代码:

Source code    
  1. def mathc_img(image,Target,value):
  2. import cv2
  3. import numpy as np
  4. img_rgb = cv2.imread(image)
  5. img_gray = cv2.cvtColor(img_rgb, cv2.COLOR_BGR2GRAY)
  6. template = cv2.imread(Target,0)
  7. w, h = template.shape[::-1]
  8. res = cv2.matchTemplate(img_gray,template,cv2.TM_CCOEFF_NORMED)
  9. threshold = value
  10. loc = np.where( res >= threshold)
  11. for pt in zip(*loc[::-1]):
  12. cv2.rectangle(img_rgb, pt, (pt[0] + w, pt[1] + h), (7,249,151), 2)
  13. cv2.imshow('Detected',img_rgb)
  14. cv2.waitKey(0)
  15. cv2.destroyAllWindows()
Source code    
  1. image=("photo.jpg")
  2. Target=('face.jpg')
  3. value=0.9
  4. mathc_img(image,Target,value)

Read more: http://bluewhale.cc/2017-09-22/use-python-opencv-for-image-template-matching-match-template.html#ixzz5HwAZaIKb

使用Python+OpenCV进行图像模板匹配(Match Template)的更多相关文章

  1. 十一 模板匹配match template

    一.介绍 1.模板匹配 通俗讲就是以图找图,通过图中的一部分来找它在图中的位置(模板匹配就是在整个图像区域发现与给定子图像匹配的小块区域). 模板匹配是一种最原始.最基本的模式识别方法,研究某一特定对 ...

  2. OpenCV中的模板匹配/Filter2d

    1.模板匹配 模板匹配是在图像中寻找目标的方法之一.Come On, Boy.我们一起来看看模板匹配到底是怎么回事. 参考链接:http://www.opencv.org.cn/opencvdoc/2 ...

  3. 使用Opencv中matchTemplate模板匹配方法跟踪移动目标

    模板匹配是一种在图像中定位目标的方法,通过把输入图像在实际图像上逐像素点滑动,计算特征相似性,以此来判断当前滑块图像所在位置是目标图像的概率. 在Opencv中,模板匹配定义了6种相似性对比方式: C ...

  4. 使用OpenCV&&C++进行模板匹配.

    一:课程介绍 1.1:学习目标 学会用imread载入图像,和imshow输出图像. 用nameWindow创建窗口,用createTrackbar加入滚动条和其回调函数的写法. 熟悉OpenCV函数 ...

  5. opencv如何用模板匹配寻找目标

    首先使用: MatchTemplate 比较模板和重叠的图像区域 void cvMatchTemplate( const CvArr* image, const CvArr* templ, CvArr ...

  6. Opencv for android 模板匹配

    因为有这方面的需要所以,对模板查找搜寻了相关资料,只是对于算法的东西很难看得动,特别是opencv涉及的很多的数学方法. 所以只为了实现这个功能,因为需求比较简单,在网上也搜寻到了相关代码,就直接拿来 ...

  7. opencv 单目标模板匹配(只适用于模板与目标尺度相同)

    #include <iostream> #include "opencv/cv.h" #include "opencv/cxcore.h" #inc ...

  8. python+opencv实现图像缩放

    x, y = img_.shape[0:2] img_ = cv2.resize(img_, (int(y/2), int(x/2))) 实现图像长宽缩小为原来的一半

  9. python+opencv实现图像自适应阈值的均衡化

    内容涉及:列表遍历,图像均衡化,图像通道分离与合并 import cv2 import numpy as np import os for path in open("org_junheng ...

随机推荐

  1. Spring、Springboot常用注解:@Qualifier(不定时更新)

    1.@Qualifier 出现场景: 老项目中有多个实现类实现同一个接口时,或者一个项目中有多个数据源时,spring容器不知道该注入哪个实现类或者使用哪个数据源,该注解就派上用场. 1)多实现类实现 ...

  2. java使用POI进行Excel读写

    1 jar包下载 参考链接:http://www.cnblogs.com/gmq/archive/0001/01/01/1521496.html poi-3.7-20101029.jar和源码下载地址 ...

  3. Excel另存为_有些Excel打开时会出现一些提示

    using System;using System.Collections.Generic;using System.ComponentModel;using System.Data;using Sy ...

  4. 奶牛易物-Alpha版本测试报告

    1.在测试过程中总共发现了多少Bug?每个类别的Bug分别为多少个? a. 修复的bug: 1.mapper接口与mapper.xml文件绑定的问题; 2..配置逆向工程的配置文件的问题; 3.在编码 ...

  5. nodejs中yield的用法?

    nodejs中yield的用法? https://www.zhihu.com/question/32752866?sort=created

  6. Luogu 4725 【模板】多项式对数函数

    继续补全模板. 要求 $$g(x) = ln f(x)$$ 两边求导, $$g'(x) = \frac{f'(x)}{f(x)}$$ 然后左转去把多项式求导和多项式求逆的模板复制过来,就可以计算出$g ...

  7. excel判断新增使用字典作为页面级数据库,减少io

    前提:该机构录入的都是和该机构有关的数据,机构下的funmental(idcard唯一)和creditinfo(funmentalid唯一)不能重复所以推出以下结论:1.根据userid(机构)=&g ...

  8. Oracle 用户验证日志

    1.sysdba/sysoper 权限用户验证日志;2.非sysdba/sysoper 权限用户验证日志;3.关于sqlcode; 1.sysdba/sysoper 权限用户验证日志:在数据库设置了参 ...

  9. js中的函数参数问题

    js函数没有Java中的重载现象.js函数的参数是放在arguments的容器里面的. <script  type="text/javascript"> functio ...

  10. Sql的行列转换

    创建表scores 一.传统的行列转换 纵表转横表 我们要转成的横表是这样子的: pivot是sql server 2005 提供的运算符,所以只要数据库在05版本以上的都可以使用.主要用于行和列的转 ...