在OpenCV中,可以使用cv2.matchTemplate()函数来应用模板匹配技术。以下是一个简单的示例代码,演示如何在一张图片中寻找另一张模板图片的位置:
import cv2
import numpy as np
# 读取图像和模板图片
img = cv2.imread('image.jpg')
template = cv2.imread('template.jpg')
# 获取模板图片的宽度和高度
w, h = template.shape[:-1]
# 应用模板匹配技术
res = cv2.matchTemplate(img, template, cv2.TM_CCOEFF_NORMED)
# 获取匹配结果中的最大值和坐标
min_val, max_val, min_loc, max_loc = cv2.minMaxLoc(res)
# 在原图上绘制矩形框标记出模板匹配的位置
top_left = max_loc
bottom_right = (top_left[0] + w, top_left[1] + h)
cv2.rectangle(img, top_left, bottom_right, (0, 255, 0), 2)
# 显示结果图像
cv2.imshow('Result', img)
cv2.waitKey(0)
cv2.destroyAllWindows()
在上面的代码中,首先读取了原图和模板图片,然后使用cv2.matchTemplate()函数对原图进行模板匹配。最后在原图上绘制出匹配位置的矩形框并显示结果图像。通过调整模板匹配方法(比如cv2.TM_CCOEFF_NORMED)和阈值等参数,可以得到不同的匹配结果。