| 参数 | 取值 | 含义 |
|---|---|---|
| cv2.TM_SQDIFF | 0 | 以方差为依据进行匹配。若完全匹配,则结果为0;若不匹配,则会得到一个很大的差值 |
| cv2.TM_SQDIFF_NORMED | 1 | 标准(归一化)平方差匹配 |
| cv2.TM_CCORR | 2 | 相关匹配,这类方法将模板图像与输入图像相乘,如果乘积越大,则匹配度较高;如果乘积为0,则表示匹配效果最差 |
| cv2.TM_CCORR_NORMED | 3 | 标准(归一化)相关匹配 |
| cv2.TM_CCOEFF | 4 | 相关系统匹配,这类方法将模板图像与其均值的相对值,和输入图像与其均值的相关值进行匹配。1表示完美匹配,-1表示糟糕的匹配,0表示没有任何相关匹配(随机序列) |
| cv2.TM_CCOEFF_NORMED | 5 | 标准(归一化)相关系数匹配 |
result:返回值。它是由每个位置的比较结果组合所构成的一个结果集,类型是单通道32位浮点型。如果输入图像尺寸是WH,模板尺寸是wh,则返回值的大小为(W-w+1)*(H-h+1)。
mask:模板图像掩模。它必须与模板图像具有相同类型的大小。通常使用默认值即可。
首先,我们需要两张图片,这里我们还是选取经常用的美女照片以及截取其眼睛部分作为模板图像,如下:
import cv2
import matplotlib.pyplot as plt
img = cv2.imread("4.jpg", 0)
template = cv2.imread("4_1.jpg", 0)
th, tw = template.shape[::]
rv = cv2.matchTemplate(img, template, cv2.TM_SQDIFF)
min, max, minLoc, maxLoc = cv2.minMaxLoc(rv)
topLeft = minLoc
bottomRight = (topLeft[0] + tw, topLeft[1] + th)
cv2.rectangle(img, topLeft, bottomRight, 255, 2)
plt.subplot(121)
plt.imshow(template, cmap="gray")
plt.axis('off')
plt.subplot(122)
plt.imshow(img, cmap="gray")
plt.axis('off')
plt.show()
运行之后,效果如下:

附录:
模板图

原图

到此这篇关于OpenCV-Python模板匹配人眼的实例的文章就介绍到这了,更多相关OpenCV 模板匹配 内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!