雾看OpenCV(14)——模板匹配

前言

目标 在本节我们要学习:

  1. 使用模板匹配在一幅图像中查找目标
  2. 函数:cv2.matchTemplate(),cv2.minMaxLoc()

正文

模板匹配是用来在一副大图中搜寻查找模版图像位置的方法。OpenCV 为 我们提供了函数:cv2.matchTemplate()。和 2D 卷积一样,它也是用模 板图像在输入图像(大图)上滑动,并在每一个位置对模板图像和与其对应的 输入图像的子区域进行比较。OpenCV 提供了几种不同的比较方法(细节请看 文档)。返回的结果是一个灰度图像,每一个像素值表示了此区域与模板的匹配 程度。

如果输入图像的大小是(WxH),模板的大小是(wxh),输出的结果 的大小就是(W-w+1,H-h+1)。当你得到这幅图之后,就可以使用函数 cv2.minMaxLoc() 来找到其中的最小值和最大值的位置了。第一个值为矩 形左上角的点(位置),(w,h)为 moban 模板矩形的宽和高。这个矩形就是 找到的模板区域了。

OpenCV的模板匹配

效果图
在这里插入图片描述
流程图
在这里插入图片描述
code:

import cv2
import numpy as np
from matplotlib import pyplot as plt


src = cv2.imread("../../images/lena.jpg",0)
img2 = src.copy()
src_temp = cv2.imread("../../images/lena_face.jpg",0)

w,h = src_temp.shape[::-1]
methods = ['cv2.TM_CCOEFF', 'cv2.TM_CCOEFF_NORMED', 'cv2.TM_CCORR',
           'cv2.TM_CCORR_NORMED', 'cv2.TM_SQDIFF', 'cv2.TM_SQDIFF_NORMED']

for meth in methods:
    img = img2.copy()

    # exec 语句用来执行储存在字符串或文件中的 Python 语句。
    # 例如,我们可以在运行时生成一个包含 Python 代码的字符串,
    # 然后使用 exec 语句执行这些语句。
    # eval 语句用来计算存储在字符串中的有效 Python 表达式
    method = eval(meth)
    res = cv2.matchTemplate(img,src_temp,method)
    minVal,maxVal,minLoc,maxLoc = cv2.minMaxLoc(res)
    if method in [cv2.TM_SQDIFF, cv2.TM_SQDIFF_NORMED]:
        topLeft = minLoc
    else:
        topLeft = maxLoc
    bottom_right = (topLeft[0]+w,topLeft[1]+h)
    cv2.rectangle(img,topLeft,bottom_right,255,2)

    plt.subplot(1,2,1),plt.imshow(res,cmap='gray')
    plt.title('Match Result'),plt.xticks([]),plt.yticks([])
    plt.subplot(1,2,2),plt.imshow(img,cmap='gray')
    plt.title('Detect Point'),plt.xticks([]),plt.yticks([])
    plt.suptitle(meth)
    plt.show()
cv2.waitKey(0)  # 等有键输入或者1000ms后自动将窗口消除,0表示只用键输入结束窗口
cv2.destroyAllWindows()

多对象的模板匹配

效果图
在这里插入图片描述
流程图
在这里插入图片描述
code

import cv2 as cv
import numpy as np
from matplotlib import pyplot as plt
'
src = cv.imread("../../images/mario.png")
cv.imshow("src",src)
src_gray = cv.cvtColor(src,cv.COLOR_BGR2GRAY)
Template = cv.imread("../../images/mario_coin.png",0)
w,h = Template.shape[::-1]

res = cv.matchTemplate(src_gray,Template,cv.TM_CCOEFF_NORMED)
threshold = 0.8
loc = np.where(res>=threshold)

for pt in zip(*loc[::-1]):
    cv.rectangle(src,pt,(pt[0]+w,pt[1]+h),(255,255,0),2)
cv.namedWindow("input image",cv.WINDOW_AUTOSIZE)
cv.imshow('input image', src)
cv.waitKey(0)  # 等有键输入或者1000ms后自动将窗口消除,0表示只用键输入结束窗口

cv.destroyAllWindows()

参考

  1. OpenCV-Python-Tutorial-中文版20160814.pdf
  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值