opencv模板匹配代码
时间: 2024-05-11 13:12:55 浏览: 85
OpenCV模板匹配是一种计算机视觉技术,可以在给定图像中找到一个模板图像的位置。模板匹配的基本思想是在给定的图像中滑动一个模板图像,并计算它们之间的相似度。以下是OpenCV模板匹配的示例代码:
```
import cv2
import numpy as np
# 读取输入图像和模板图像
img = cv2.imread('input_image.jpg')
template = cv2.imread('template_image.jpg')
# 获取模板图像的高度和宽度
h, w = template.shape[:2]
# 使用cv2.matchTemplate函数进行模板匹配
res = cv2.matchTemplate(img, template, cv2.TM_CCOEFF_NORMED)
# 设置阈值,过滤掉低于阈值的匹配结果
threshold = 0.8
loc = np.where(res >= threshold)
# 绘制矩形框标记匹配位置
for pt in zip(*loc[::-1]):
cv2.rectangle(img, pt, (pt + w, pt + h), (0, 0, 255), 2)
# 显示匹配结果
cv2.imshow('Matched Image', img)
cv2.waitKey(0)
```
以上代码将读取输入图像和模板图像,然后使用`cv2.matchTemplate`函数进行模板匹配。接下来,将阈值设置为0.8,过滤掉低于阈值的匹配结果,并绘制矩形框标记匹配位置。最后,显示匹配结果。
相关问题
python opencv 模板匹配代码
模板匹配是一种在图像中查找模板图像位置的方法。OpenCV 提供了 `cv2.matchTemplate()` 函数来实现模板匹配。以下是一个简单的示例代码,展示了如何使用 OpenCV 进行模板匹配:
```python
import cv2
import numpy as np
# 读取主图像和模板图像
main_image = cv2.imread('main_image.jpg', cv2.IMREAD_COLOR)
template = cv2.imread('template.jpg', cv2.IMREAD_COLOR)
# 获取模板图像的尺寸
template_height, template_width = template.shape[:2]
# 执行模板匹配
result = cv2.matchTemplate(main_image, template, cv2.TM_CCOEFF_NORMED)
# 设置匹配阈值
threshold = 0.8
loc = np.where(result >= threshold)
# 在匹配位置绘制矩形框
for pt in zip(*loc[::-1]):
cv2.rectangle(main_image, pt, (pt[0] + template_width, pt[1] + template_height), (0, 0, 255), 2)
# 显示结果图像
cv2.imshow('Detected', main_image)
cv2.waitKey(0)
cv2.destroyAllWindows()
```
### 代码解释
1. **导入库**:
```python
import cv2
import numpy as np
```
导入 OpenCV 和 NumPy 库。
2. **读取图像**:
```python
main_image = cv2.imread('main_image.jpg', cv2.IMREAD_COLOR)
template = cv2.imread('template.jpg', cv2.IMREAD_COLOR)
```
读取主图像和模板图像。
3. **获取模板尺寸**:
```python
template_height, template_width = template.shape[:2]
```
获取模板图像的高度和宽度。
4. **执行模板匹配**:
```python
result = cv2.matchTemplate(main_image, template, cv2.TM_CCOEFF_NORMED)
```
使用 `cv2.matchTemplate()` 函数进行模板匹配。
5. **设置匹配阈值并找到匹配位置**:
```python
threshold = 0.8
loc = np.where(result >= threshold)
```
设置匹配阈值,并找到所有匹配位置。
6. **绘制矩形框**:
```python
for pt in zip(*loc[::-1]):
cv2.rectangle(main_image, pt, (pt[0] + template_width, pt[1] + template_height), (0, 0, 255), 2)
```
在匹配位置绘制红色矩形框。
7. **显示结果图像**:
```python
cv2.imshow('Detected', main_image)
cv2.waitKey(0)
cv2.destroyAllWindows()
```
显示结果图像,并等待用户按键关闭窗口。
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()
```
希望能够帮到你。
阅读全文