Python Opencv实践 - 模板匹配(Template Matching)

复制代码
import cv2 as cv
import numpy as np
import matplotlib.pyplot as plt

img_slamdunk = cv.imread("../SampleImages/slamdunk.jpg", cv.IMREAD_COLOR)
print(img_slamdunk.shape)

template_sakura = cv.imread("../SampleImages/sakura.png", cv.IMREAD_COLOR)
print(template_sakura.shape)
rows,cols,channels = template_sakura.shape

#模板匹配
#cv.matchTemplate(image,templ,method[,result[,mask]])
#image:原图
#templ:用于匹配的模板
#method:原图与模板匹配的方法
#       TM_SQDIFF:平方差匹配法
#       TM_SQDIFF_NORMED:归一化平方差匹配法 
#       TM_CCORR:相关匹配法
#       TM_CCORR_NORMED:归一化相关匹配法
#       TM_CCOEFF:系数匹配法
#       TM_CCOEFF_NORMED:归一化系数匹配法
#result:匹配结果
#mask:匹配的掩膜(遮罩)
#参考资料:https://blog.csdn.net/raychiu757374816/article/details/119609851
matchResult = cv.matchTemplate(img_slamdunk, template_sakura, cv.TM_SQDIFF_NORMED)

#找到最佳匹配的位置,对于平方差匹配法,要找到结果矩阵中最小值的位置。对于相关匹配法,要找到结果矩阵中最大值的位置。
#minVal,maxVal,minLoc,maxLoc = cv.minMaxLoc(src[,mask])
#src:输入矩阵
#mask:掩膜
#minVal:矩阵的最小值
#maxVal:矩阵的最大值
#minLoc:矩阵的最小值的位置
#maxLoc:矩阵的最大值的位置
#参考资料:https://blog.csdn.net/qq_29023939/article/details/81023062
minVal,maxVal,minLoc,maxLoc = cv.minMaxLoc(matchResult)

#用矩形标记结果位置
top_left = minLoc;
bottom_right = (top_left[0] + cols, top_left[1] + rows)
cv.rectangle(img_slamdunk, top_left, bottom_right, (0,255,0), 2)

#显示图像
fig,axes = plt.subplots(nrows=2, ncols=1, figsize=(15,15), dpi=100)
axes[0].set_title("Template")
axes[0].imshow(template_sakura[:,:,::-1])
axes[1].set_title("Result")
axes[1].imshow(img_slamdunk[:,:,::-1])
相关推荐
_Kayo_35 分钟前
JS深拷贝 浅拷贝、CSS垂直水平居中
开发语言·前端·javascript
云天徽上41 分钟前
【数据可视化-87】2023-2024年中国各省人口变化深度分析与可视化:Python + pyecharts打造炫酷暗黑主题大屏
开发语言·python·信息可视化·数据可视化·pyecharts
404未精通的狗42 分钟前
(C++)继承全解析及运用
开发语言·c++
李永奉1 小时前
C语言—数组和指针练习题合集(二)
c语言·开发语言
人工干智能1 小时前
游戏中角色持枪:玩家操控角色,角色转向时枪也要转向
python·游戏·pygame
C4程序员1 小时前
北京JAVA基础面试30天打卡08
java·开发语言·面试
cver1231 小时前
垃圾分类检测数据集-15,000 张图片 智能垃圾分类 回收站与环保设施自动化 公共区域清洁监测 环保机器人 水域与自然环境垃圾监测
人工智能·计算机视觉·分类·数据挖掘·机器人·自动化·智慧城市
桃源学社(接毕设)1 小时前
基于Django珠宝购物系统设计与实现(LW+源码+讲解+部署)
人工智能·后端·python·django·毕业设计
God-Hrh1 小时前
JVM运维
java·开发语言·jvm
weixin_448617052 小时前
疏老师-python训练营-Day43复习日
开发语言·python