概念:
用一个小图,在大图中寻找位置
原理:
- 通过匹配像素点的不同差异,得到最大(最小的)取决于算法
api: 处理算法最好用归一化的
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)
匹配多个对象
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)