使用Python+OpenCV进行图像模板匹配(Match Template)

本篇文章介绍使用Python和OpenCV对图像进行模板匹配和识别。模板匹配是在图像中寻找和识别模板的一种简单的方法。

本篇文章介绍使用Python和OpenCV对图像进行模板匹配和识别。模板匹配是在图像中寻找和识别模板的一种简单的方法。

使用Python+OpenCV进行图像模板匹配(Match Template)

本篇文章介绍使用Python和OpenCV对图像进行模板匹配和识别。模板匹配是在图像中寻找和识别模板的一种简单的方法。以下是具体的步骤及代码。

首先导入所需库文件,numpy和cv2。

  1. #导入所需库文件
  2. importcv2
  3. importnumpyasnp

然后加载原始图像和要搜索的图像模板。OpenCV对原始图像进行处理,创建一个灰度版本,在灰度图像里进行处理和查找匹配。然后使用相同的坐标在原始图像中进行还原并输出。

  1. #加载原始RGB图像
  2. img_rgb=cv2.imread("photo.jpg")
  3. #创建一个原始图像的灰度版本,所有操作在灰度版本中处理,然后在RGB图像中使用相同坐标还原
  4. img_gray=cv2.cvtColor(img_rgb,cv2.COLOR_BGR2GRAY)
  5. #加载将要搜索的图像模板
  6. template=cv2.imread('face.jpg',0)
  7. #记录图像模板的尺寸
  8. w,h=template.shape[::-1]

这里我们分别输出并查看原始图像,原始图像的灰度版本,以及图像模板。

使用Python+OpenCV进行图像模板匹配(Match Template)

使用Python+OpenCV进行图像模板匹配(Match Template)

使用Python+OpenCV进行图像模板匹配(Match Template)

  1. #查看三组图像(图像标签名称,文件名称)
  2. cv2.imshow('rgb',img_rgb)
  3. cv2.imshow('gray',img_gray)
  4. cv2.imshow('template',template)
  5. cv2.waitKey(0)
  6. cv2.destroyAllWindows()

使用matchTemplate在原始图像中查找并匹配图像模板中的内容,并设置阈值。

  1. #使用matchTemplate对原始灰度图像和图像模板进行匹配
  2. res=cv2.matchTemplate(img_gray,template,cv2.TM_CCOEFF_NORMED)
  3. #设定阈值
  4. threshold=0.7
  5. #res大于70%
  6. loc=np.where(res>=threshold)

匹配完成后在原始图像中使用灰度图像的坐标对原始图像进行标记。

  1. #使用灰度图像中的坐标对原始RGB图像进行标记
  2. forptinzip(*loc[::-1]):
  3. cv2.rectangle(img_rgb,pt,(pt[0]+w,pt[1]+h),(7,249,151),2)
  4. #显示图像
  5. cv2.imshow('Detected',img_rgb)
  6. cv2.waitKey(0)
  7. cv2.destroyAllWindows()

使用Python+OpenCV进行图像模板匹配(Match Template)

以下为完整代码:

  1. defmathc_img(image,Target,value):
  2. importcv2
  3. importnumpyasnp
  4. img_rgb=cv2.imread(image)
  5. img_gray=cv2.cvtColor(img_rgb,cv2.COLOR_BGR2GRAY)
  6. template=cv2.imread(Target,0)
  7. w,h=template.shape[::-1]
  8. res=cv2.matchTemplate(img_gray,template,cv2.TM_CCOEFF_NORMED)
  9. threshold=value
  10. loc=np.where(res>=threshold)
  11. forptinzip(*loc[::-1]):
  12. cv2.rectangle(img_rgb,pt,(pt[0]+w,pt[1]+h),(7,249,151),2)
  13. cv2.imshow('Detected',img_rgb)
  14. cv2.waitKey(0)
  15. cv2.destroyAllWindows()
  1. image=("photo.jpg")
  2. Target=('face.jpg')
  3. value=0.9
  4. mathc_img(image,Target,value)

©本文为清一色官方代发,观点仅代表作者本人,与清一色无关。清一色对文中陈述、观点判断保持中立,不对所包含内容的准确性、可靠性或完整性提供任何明示或暗示的保证。本文不作为投资理财建议,请读者仅作参考,并请自行承担全部责任。文中部分文字/图片/视频/音频等来源于网络,如侵犯到著作权人的权利,请与我们联系(微信/QQ:1074760229)。转载请注明出处:清一色财经

(0)
打赏 微信扫码打赏 微信扫码打赏 支付宝扫码打赏 支付宝扫码打赏
清一色的头像清一色管理团队
上一篇 2023年5月6日 04:13
下一篇 2023年5月6日 04:13

相关推荐

发表评论

登录后才能评论

联系我们

在线咨询:1643011589-QQbutton

手机:13798586780

QQ/微信:1074760229

QQ群:551893940

工作时间:工作日9:00-18:00,节假日休息

关注微信