自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

使用Python+OpenCV進行圖像模板匹配(Match Template)

大數(shù)據(jù)
本篇文章介紹使用Python和OpenCV對圖像進行模板匹配和識別。模板匹配是在圖像中尋找和識別模板的一種簡單的方法。

本篇文章介紹使用Python和OpenCV對圖像進行模板匹配和識別。模板匹配是在圖像中尋找和識別模板的一種簡單的方法。以下是具體的步驟及代碼。

首先導入所需庫文件,numpy和cv2。

  1. #導入所需庫文件 
  2. import cv2 
  3. import numpy as np 

然后加載原始圖像和要搜索的圖像模板。OpenCV對原始圖像進行處理,創(chuàng)建一個灰度版本,在灰度圖像里進行處理和查找匹配。然后使用相同的坐標在原始圖像中進行還原并輸出。

  1. #加載原始RGB圖像 
  2. img_rgb = cv2.imread("photo.jpg"
  3. #創(chuàng)建一個原始圖像的灰度版本,所有操作在灰度版本中處理,然后在RGB圖像中使用相同坐標還原 
  4. img_gray = cv2.cvtColor(img_rgb, cv2.COLOR_BGR2GRAY) 
  5.   
  6. #加載將要搜索的圖像模板 
  7. template = cv2.imread('face.jpg',0) 
  8. #記錄圖像模板的尺寸 
  9. w, h = template.shape[::-1] 

這里我們分別輸出并查看原始圖像,原始圖像的灰度版本,以及圖像模板。

  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. for pt in zip(*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() 

 

以下為完整代碼:

  1. def mathc_img(image,Target,value): 
  2.     import cv2 
  3.     import numpy as np 
  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.     for pt in zip(*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) 
責任編輯:武曉燕 來源: 36大數(shù)據(jù)
相關推薦

2024-01-09 08:20:23

OpenCV二值化灰度化

2018-06-29 10:15:20

PythonOpenCV人臉識別

2025-02-17 12:00:00

PythonOpenCV提取圖像

2013-09-22 15:43:27

扁平化UI設計

2018-08-30 17:50:30

圖像數(shù)據(jù)分析通道

2025-02-10 16:00:00

OpenCVYOLOv8計算機視覺

2025-02-10 12:00:00

圖像分類OpenCVPython

2023-10-12 09:21:41

Java圖像

2012-07-11 08:51:51

設計模式

2017-02-16 08:41:09

數(shù)據(jù)Vlookup匹配

2022-08-02 11:31:46

Python語法代碼

2011-11-15 13:34:22

蘋果iTunes Matc

2020-08-25 18:30:57

PythonOpenCV圖像處理

2021-04-09 20:49:44

PythonOCR圖像

2021-12-30 10:55:54

Python游戲腳本

2022-01-27 14:12:49

Python游戲腳本

2022-02-23 09:10:48

JavaScript標簽模板前端

2018-06-19 11:00:33

OpenCVPythonC++

2010-02-02 17:18:16

Python圖像處理

2021-01-11 13:20:06

Python圖像大小編程語言
點贊
收藏

51CTO技術棧公眾號