opencv模板匹配python代码
时间: 2023-10-09 09:11:31 浏览: 99
以下是使用OpenCV进行模板匹配的Python代码示例:
```python
import cv2
import numpy as np
# 读入原始图像和模板图像
img = cv2.imread('image.jpg')
template = cv2.imread('template.jpg')
# 获取模板图像的高度和宽度
h, w = template.shape[:2]
# 使用cv2.TM_CCOEFF_NORMED方法进行模板匹配
res = cv2.matchTemplate(img,template,cv2.TM_CCOEFF_NORMED)
# 设置匹配结果的阈值
threshold = 0.8
# 使用numpy.where函数获取匹配结果的坐标
loc = np.where(res >= threshold)
# 循环遍历所有匹配结果的坐标,并绘制矩形框
for pt in zip(*loc[::-1]):
cv2.rectangle(img, pt, (pt[0] + w, pt[1] + h), (0, 0, 255), 2)
# 显示匹配结果
cv2.imshow('Match Result', img)
cv2.waitKey(0)
cv2.destroyAllWindows()
```
其中,`cv2.imread`函数用于读入原始图像和模板图像,`cv2.matchTemplate`函数用于进行模板匹配,`np.where`函数用于获取匹配结果的坐标,`cv2.rectangle`函数用于绘制矩形框。
相关问题
opencv模板匹配python实现
OpenCV(Open Source Computer Vision Library)是一个广泛使用的计算机视觉库,它提供了丰富的功能,包括模板匹配。在Python中,你可以使用OpenCV的`cv2.matchTemplate()`函数来进行模板匹配。模板匹配主要用于查找图像中的特定模式或目标。
以下是一个简单的步骤和代码示例来说明如何在Python中使用OpenCV进行模板匹配:
```python
import cv2
import numpy as np
# 1. 加载图像和模板
img = cv2.imread('image.jpg', 0) # 读取灰度图像
template = cv2.imread('template.jpg', 0) # 读取模板
# 2. 对模板进行归一化处理(可选)
w, h = template.shape[::-1]
res = cv2.matchTemplate(img, template, cv2.TM_CCOEFF_NORMED)
# 3. 获取匹配区域
threshold = 0.8 # 可以根据需求调整这个阈值
loc = np.where(res >= threshold)
# 4. 在原图上绘制匹配结果
for pt in zip(*loc[::-1]):
cv2.rectangle(img, pt, (pt + w, pt + h), (0, 0, 255), 2)
# 5. 显示结果
cv2.imshow('Match Result', img)
cv2.waitKey(0)
cv2.destroyAllWindows()
```
在这个例子中,`cv2.TM_CCOEFF_NORMED`常用于计算归一化的相关系数,这是最常用的模板匹配方法之一。相关问题如下:
python opencv 模板匹配 代码范例
好的,下面提供一下python opencv模板匹配的代码范例:
```python
import cv2
# 读取原图和模板图
img = cv2.imread('original_image.jpg')
template = cv2.imread('template_image.jpg')
# 获取模板图的尺寸
h, w = template.shape[:2]
# 选择匹配算法,这里选择 TM_CCOEFF_NORMED
# https://docs.opencv.org/2.4/modules/imgproc/doc/object_detection.html#cv2.matchTemplate
res = cv2.matchTemplate(img, template, cv2.TM_CCOEFF_NORMED)
# 设置匹配阈值,找到所有可能的匹配位置
threshold = 0.9
locs = cv2.findNonZero(res > threshold)
# 在原图上画出匹配位置的矩形框
for loc in locs:
x, y = loc[0]
cv2.rectangle(img, (x, y), (x + w, y + h), (0, 0, 255), 2)
# 显示匹配结果
cv2.imshow('result', img)
cv2.waitKey(0)
cv2.destroyAllWindows()
```
希望能够帮到你。
阅读全文