先來看看今天的結果gif
-> 此篇文章的程式碼 github Day23_標記點小工具_label_points.ipynb
前言我們該來運用之前學過的所有東西了!
綜合運用篇就是來一次運用前面的所學!
(資料標註) 用 OpenCV 來製作一個標記點小工具吧!我們要製作一個標記點小工具,大致要完成三個功能:
* 主程式 (讀取圖片)
* 控制滑鼠相關的函數 (滑鼠處理)
* 依據滑鼠回傳的數值做出對應的反應函數 (主要功能處理)
主程式 (讀取圖片)img_dst = cv2.imread("./testdata/cat.jpg")
print("Click on the screen and press any key for end process")
points = get_points(img_dst)
print("\npoints list:")
print(points)
這部分就單純的讀取圖片,
我們使用我們定義的 get_points
來呼叫我們主要的功能。
控制滑鼠相關的函數 (滑鼠處理)def mouse_handler(event, x, y, flags, data):
if event == cv2.EVENT_LBUTTONDOWN:
# 標記點位置
cv2.circle(data['img'], (x,y), 3, (0,0,255), 5, 16)
# 改變顯示 window 的內容
cv2.imshow("Image", data['img'])
# 顯示 (x,y) 並儲存到 list中
print("get points: (x, y) = ({}, {})".format(x, y))
data['points'].append((x,y))
我們先定義一個控制滑鼠的函數,
OpenCV
有內建滑鼠偵測的函數 cv2.EVENT_LBUTTONDOWN
,
為了讓我們的功能更有回饋感,我們在點擊之處新增一個紅點,
作為我們真的有點下去的視覺上回饋,
我們在畫點之後更新畫面,即時顯示在畫面上,
並將這些點儲存起來,供等等分析使用。
依據滑鼠回傳的數值做出對應的反應函數 (主要功能處理)def get_points(im):
# 建立 data dict, img:存放圖片, points:存放點
data = {}
data['img'] = im.copy()
data['points'] = []
# 建立一個 window
cv2.namedWindow("Image", 0)
# 改變 window 成為適當圖片大小
h, w, dim = im.shape
print("Img height, width: ({}, {})".format(h, w))
cv2.resizeWindow("Image", w, h)
# 顯示圖片在 window 中
cv2.imshow('Image',im)
# 利用滑鼠回傳值,資料皆保存於 data dict中
cv2.setMouseCallback("Image", mouse_handler, data)
# 等待按下任意鍵,藉由 OpenCV 內建函數釋放資源
cv2.waitKey()
cv2.destroyAllWindows()
# 回傳點 list
return data['points']
這裡就是我們的主要功能區,
我們先建立一個 data dictionary,
將我們的圖片儲存在 data['img']
這個欄位,
並宣告一個 data['points']
讓我們等等來儲存點。
我們建立一個新的作業用視窗 cv2.namedWindow
,
並修改為符合圖片大小 cv2.resizeWindow
,
最後顯示圖片在視窗中 cv2.imshow
。
cv2.setMouseCallback("Image", mouse_handler, data)
,
* 第二個參數就是我們剛剛定義滑鼠功能的函數名字,
* 第三個參數我們傳入 data dictionary,讀取圖片並儲存點座標。
為求程式的穩定性,我們使用 OpenCV 的內建函數來釋放資源
cv2.waitKey(0)
,cv2.destroyAllWindows()
最後我們回傳點座標return data['points']
,
完成我們這次的功能。
本文同步發佈在: 第 12 屆 iT 邦幫忙鐵人賽
【沒錢ps,我用OpenCV!】Day 23 – 綜合運用2,(資料標註) 用 OpenCV 來製作一個標記點小工具吧! 滑鼠與視窗控制 label points
Referencehttps://zhuanlan.zhihu.com/p/143035374
https://kknews.cc/code/3oqxejy.html
https://blog.csdn.net/fanjiule/article/details/81606596
https://blog.csdn.net/yefcion/article/details/79435591
⭐Python OpenCV 相關文章整理⭐: ⭐基礎知識篇⭐: 1. 【OpenCV】1 – 安裝 python OpenCV install 電腦中圖片的基本概念總整理 (附錄:OpenCV 快速測試用程式碼) 2. 【OpenCV】2 – OpenCV 圖片的讀取、顯示、存檔 (load, show, save),附贈簡易理解「相對路徑」與「絕對路徑」 3. 【OpenCV】OpenCV 利用 python OpenCV 查詢 image 大小, img shape sample code (內附範例程式碼) ⭐基本圖像處理篇⭐: 1. 【OpenCV】OpenCV 利用 python OpenCV 縮放圖片 image 大小, cv2 resize (內附程式碼) 2. 【OpenCV】3 – python OpenCV 的剪裁、旋轉、縮放 (crop, rotate, resize) 3. 【OpenCV】4 – 運用 OpenCV 調整光線 (modify brightness, intensity) 4. 【OpenCV】5 – 運用 OpenCV 調整亮度、飽和度(透過轉移至 HLS 顏色空間) modify lightness, saturation 5. 【OpenCV】6 – 運用 OpenCV 調整色調(冷色系/暖色系)、色溫(白平衡)modify color temperature, white balance 6. 【OpenCV】7 – 運用 OpenCV 為圖片增加一些顆粒感 (增加高斯噪點) add gaussian noise 7. 【OpenCV】8 – 運用 OpenCV 改變圖片的對比度 modify contrast (內含:網路上常見錯誤調整對比度方式的分析) 8. 【OpenCV】9 – 運用 OpenCV 降低圖片的高光 reduce highlights 9. 【OpenCV】11 – OpenCV 建立新空白圖、畫點、畫圓 create new pictures, draw points and draw circle 10. 【OpenCV】12 – 運用 OpenCV 畫線、畫矩形、畫橢圓 draw lines, draw rectangle, draw ellipse 11. 【OpenCV】13 – 運用 OpenCV 在圖片上寫文字、查色碼、顯示色碼顏色 write text, get and show RGB Color Code ⭐進階圖像處理篇⭐: 1. 【OpenCV】14 – 運用 OpenCV 顯示圖片直方圖、分離與合併RGB通道 show histogram, split, merge RGB channel 2. 【OpenCV】15 – OpenCV 當然也有像 ps 圖層的功能! 什麼?圖片也能加減法?! Add, Subtract, AddWeighted 3. 【OpenCV】16 – 運用 OpenCV 幫助我們找圖片的輪廓(高斯模糊、Canny) cv2.GaussianBlur, cv2.Canny 4. 【OpenCV】17 – 運用 OpenCV 的終極圖層處理大全, 想P圖該怎麼P (bitwise_or, and, xor, not, addWeighted) 5. 【OpenCV】18 – 運用 OpenCV 做圖片二值化,產生黑白的圖片吧!cv2.threshold 各種選擇參數大全 6. 【OpenCV】19 – OpenCV 的圖片自適應二值化,產生更好效果的黑白圖片!cv2.adaptiveThreshold 7. 【OpenCV】20 – OpenCV 的各種 Threshold 方法整理,Otsu’s Threshold 大津二值化,自動計算最佳閥值,做出最好的黑白效果圖! 8. 【OpenCV】26 – 銳化圖片,將模糊的圖片變得更清晰吧! sharpen images ⭐冷門應用篇⭐: 1. 【OpenCV】python OpenCV 分析影像模糊程度 檢測圖片模糊 blur sample code (內含範例程式碼) 2. 【OpenCV】21 – OpenCV 也有 photoshop 的魔術棒工具?! 漫水填充法 cv2.floodFill (Magic Wand Tool) 3. 【OpenCV】27 – 顏色映射 – OpenCV 內建的自動配色?! auto recolor images, cv2.applyColorMap ⭐影片處理篇⭐: 1. 【OpenCV】OpenCV 利用 python OpenCV 將圖片製作成一部影片 (內附程式碼) make video from images 2. 【OpenCV】OpenCV 利用 python OpenCV 將一部影片拆成一張張圖片 sample code (內附程式碼) get images from video 3. 【OpenCV】用 OpenCV 開啟 rtsp 即時影像串流 sample code (內含範例程式碼) – python OpenCV rtsp 4. 【OpenCV】python pyinotify video player 利用 OpenCV + inotify 製作即時影片播放器 sample code (內含範例程式碼) ⭐綜合應用篇⭐: 1. 【OpenCV】10 – 日系濾鏡總集篇,運用 OpenCV 製作屬於自己的濾鏡吧 (內含可於網頁上直接完成濾鏡的 colab ) 2. 【OpenCV】22 – 綜合運用1,用 OpenCV 來P圖囉! 來運用各種之前學習的各種東西吧! merge two images 3. 【OpenCV】23 – 綜合運用2,(資料標註) 用 OpenCV 來製作一個標記點小工具吧! 滑鼠與視窗控制 label points 4. 【OpenCV】24 – 綜合運用3,(應用app) 用 OpenCV 來製作一個照片文件掃描機吧! photo scanner 透視投影 5. 【OpenCV】25 – 綜合運用4,用 OpenCV 來把圖片p到各種奇怪的地方吧! 透視投影 cv2.warpPerspective, merge two images 6. 【OpenCV】28 – Final Project v1,於是沒錢買ps的我,開發了自己的photoshop,我的天啊 My photoshop made by OpenCV 7. 【OpenCV】29 – Final Project v2,於是沒錢買ps的我,開發了自己的photoshop,我的天啊 My photoshop made by OpenCV 8. 【OpenCV】30 – Final Project v3,於是沒錢買ps的我,開發了自己的photoshop,我的天啊 My photoshop made by OpenCV 9. 【OpenCV】用 python OpenCV 計算 iou 的方法 (內附範例程式碼) sample code ⭐【喜歡我的文章嗎? 歡迎幫我按讚~ 讓基金會請創作者喝一杯咖啡! 】
如果喜歡我的文章,請幫我在下方【按五下Like 】 (Google, Facebook 免註冊 ),會由 「LikeCoin 」 贊助作者鼓勵繼續創作,讀者們「只需幫忙按讚,完全不用出錢 」哦!