opencv的学习之模板匹配(8)

概念:

用一个小图,在大图中寻找位置
在这里插入图片描述

原理:

  • 通过匹配像素点的不同差异,得到最大(最小的)取决于算法

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)
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

东哥爱编程

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值