opencv的学习之模板匹配(8)

文章目录

  • 概念:
    • 原理:
  • api: 处理算法最好用归一化的
  • 代码演示
  • 匹配多个对象

概念:

用一个小图,在大图中寻找位置
opencv的学习之模板匹配(8)_第1张图片

原理:

  • 通过匹配像素点的不同差异,得到最大(最小的)取决于算法

api: 处理算法最好用归一化的

opencv的学习之模板匹配(8)_第2张图片
在这里插入图片描述
在这里插入图片描述

res = cv2.matchTemplate(img, template, 1) ## res (A- a +1 , B- b+ 1)
#返回每个格子匹配的数值,有最大的标准和最小的标准
min_val, max_val, min_loc, max_loc = cv2.minMaxLoc(res) # 返回最大最小的

代码演示

import cv2 
import numpy as np

template = cv2.imread('./22.png')
template.shape
img = cv2.imread('./car1.png')

res = cv2.matchTemplate(img, template, 1) ## res (A- a +1 , B- b+ 1)
print(template.shape)
min_val, max_val, min_loc, max_loc = cv2.minMaxLoc(res)
cv2.rectangle(img, min_loc, np.add(min_loc, (template.shape[1], template.shape[0])), (0, 0, 255))
cv2.imshow('h', img)
cv2.waitKey(0)

opencv的学习之模板匹配(8)_第3张图片

匹配多个对象


import cv2 
import numpy as np

template = cv2.imread('./t.png')
img = cv2.imread('./mali.png')
res = cv2.matchTemplate(img, template, cv2.TM_SQDIFF_NORMED) ## res (A- a +1 , B- b+ 1)
threshold = 0.8
loc = np.where(res >= 0.8)
for i in zip(*loc[::-1]):
    cv2.rectangle(img, i, np.add(min_loc, (template.shape[1], template.shape[0])), (0, 0, 255), 2)
cv2.imshow('h', img)
cv2.waitKey(0)

你可能感兴趣的:(opencv,python,opencv,计算机视觉,学习)