- import cv2 as cv
- import numpy as np
- def template():
- #模板图片
- tpl=cv.imread('12tem.jpg')
- #目标图片
- target=cv.imread('12.jpg')
- cv.imshow('template',tpl)
- cv.imshow('target',target)
- methods=[cv.TM_SQDIFF_NORMED,cv.TM_CCORR_NORMED,cv.TM_CCOEFF_NORMED]
- #获得模板的高宽
- th,tw=tpl.shape[:2]
- for md in methods:
- #执行模板匹配
- #target:目标图片
- #tpl:模板图片
- #匹配模式
- result=cv.matchTemplate(target,tpl,md)
- #寻找矩阵(一维数组当作向量,用Mat定义) 中最小值和最大值的位置
- min_val,max_val,min_loc,max_loc=cv.minMaxLoc(result)
- if md==cv.TM_SQDIFF_NORMED:
- tl=min_loc
- else:
- tl=max_loc
- br=(tl[0]+tw,tl[1]+th)
- #绘制矩形边框,将匹配区域标注出来
- #target:目标图像
- #tl:矩形定点
- #br:举行的宽高
- #(0,0,255):矩形边框颜色
- #2:矩形边框大小
- cv.rectangle(target,tl,br,(0,0,255),2)
- cv.imshow('match-'+np.str(md),target)
- template();
- cv.waitKey(0)
- cv.destroyAllWindows()