欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Python+OpenCV進(jìn)行不規(guī)則多邊形ROI區(qū)域提取

 更新時間:2022年03月22日 09:07:04   作者:Vertira  
ROI即感興趣區(qū)域。機(jī)器視覺、圖像處理中,從被處理的圖像以方框、圓、橢圓、不規(guī)則多邊形等方式勾勒出需要處理的區(qū)域,稱為感興趣區(qū)域,ROI。本文將利用Python和OpenCV實(shí)現(xiàn)不規(guī)則多邊形ROI區(qū)域提取,需要的可以參考一下

多邊形ROI,主要利用鼠標(biāo)交互進(jìn)行繪制:

1. 單擊左鍵,選擇多邊形的點(diǎn);

2. 單擊右鍵,刪除最近一次選擇的點(diǎn);

3. 單擊中鍵,確定ROI區(qū)域并可視化。

4. 按”S“鍵,將多邊形ROI區(qū)域的點(diǎn)保存到本地”config.pkl"文件中。

話不多說,以下是核心代碼

import cv2
 
import numpy as np
import joblib
 
pts = []  # 用于存放點(diǎn)
 
 
# 統(tǒng)一的:mouse callback function
def draw_roi(event, x, y, flags, param):
    img2 = img.copy()
 
    if event == cv2.EVENT_LBUTTONDOWN:  # 左鍵點(diǎn)擊,選擇點(diǎn)
        pts.append((x, y))
 
    if event == cv2.EVENT_RBUTTONDOWN:  # 右鍵點(diǎn)擊,取消最近一次選擇的點(diǎn)
        pts.pop()
 
    if event == cv2.EVENT_MBUTTONDOWN:  # 中鍵繪制輪廓
        mask = np.zeros(img.shape, np.uint8)
        points = np.array(pts, np.int32)
        points = points.reshape((-1, 1, 2))
        # 畫多邊形
        mask = cv2.polylines(mask, [points], True, (255, 255, 255), 2)
        mask2 = cv2.fillPoly(mask.copy(), [points], (255, 255, 255))  # 用于求 ROI
        mask3 = cv2.fillPoly(mask.copy(), [points], (0, 255, 0))  # 用于 顯示在桌面的圖像
 
        show_image = cv2.addWeighted(src1=img, alpha=0.8, src2=mask3, beta=0.2, gamma=0)
 
        cv2.imshow("mask", mask2)
        cv2.imshow("show_img", show_image)
 
        ROI = cv2.bitwise_and(mask2, img)
        cv2.imshow("ROI", ROI)
        cv2.waitKey(0)
 
    if len(pts) > 0:
        # 將pts中的最后一點(diǎn)畫出來
        cv2.circle(img2, pts[-1], 3, (0, 0, 255), -1)
 
    if len(pts) > 1:
        # 畫線
        for i in range(len(pts) - 1):
            cv2.circle(img2, pts[i], 5, (0, 0, 255), -1)  # x ,y 為鼠標(biāo)點(diǎn)擊地方的坐標(biāo)
            cv2.line(img=img2, pt1=pts[i], pt2=pts[i + 1], color=(255, 0, 0), thickness=2)
 
    cv2.imshow('image', img2)
 
 
# 創(chuàng)建圖像與窗口并將窗口與回調(diào)函數(shù)綁定
img = cv2.imread("111.jpg")
 
cv2.namedWindow('image')
cv2.setMouseCallback('image', draw_roi)
print("[INFO] 單擊左鍵:選擇點(diǎn),單擊右鍵:刪除上一次選擇的點(diǎn),單擊中鍵:確定ROI區(qū)域")
print("[INFO] 按‘S'確定選擇區(qū)域并保存")
print("[INFO] 按 ESC 退出")
 
while True:
    key = cv2.waitKey(1) & 0xFF
    if key == 27:
        break
    if key == ord("s"):
        saved_data = {
            "ROI": pts
        }
        joblib.dump(value=saved_data, filename="config.pkl")
        print("[INFO] ROI坐標(biāo)已保存到本地.")
        break
cv2.destroyAllWindows()

繪制不規(guī)則多邊形:

然后按鼠標(biāo)中間

補(bǔ)充

當(dāng)然Python+OpenCV還可以獲取RGB圖像規(guī)則的ROI區(qū)域

以下是實(shí)現(xiàn)代碼

import cv2 as cv2
 
img = cv2.imread('111.jpg')
# 獲取圖像尺寸和通道數(shù)
h, w, channel = img.shape
# 打印獲取的數(shù)據(jù)
print(h, w, channel)
rows = h
cols = w
roi = img[0:int(rows/2), 0:int(cols/2)]#ROI區(qū)域是行  列的一半
cv2.imshow("", roi)
cv2.waitKey()

原圖:

ROI顯示

到此這篇關(guān)于Python+OpenCV進(jìn)行不規(guī)則多邊形ROI區(qū)域提取的文章就介紹到這了,更多相關(guān)Python OpenCV ROI提取內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • python和shell實(shí)現(xiàn)的校驗(yàn)IP地址合法性腳本分享

    python和shell實(shí)現(xiàn)的校驗(yàn)IP地址合法性腳本分享

    這篇文章主要介紹了python和shell實(shí)現(xiàn)的校驗(yàn)IP地址合法性腳本分享,每個腳本配有執(zhí)行效果圖,需要的朋友可以參考下
    2014-10-10
  • 使用Python3制作TCP端口掃描器

    使用Python3制作TCP端口掃描器

    本文給大家分享的是使用Python3 實(shí)現(xiàn)TCP全連接端口掃描器的制作過程,包括思路和代碼,非常簡單易懂,推薦給大家
    2017-04-04
  • python 字典中文key處理,讀取,比較方法

    python 字典中文key處理,讀取,比較方法

    今天小編就為大家分享一篇python 字典中文key處理,讀取,比較方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-07-07
  • python pytest進(jìn)階之fixture詳解

    python pytest進(jìn)階之fixture詳解

    這篇文章主要介紹了python pytest進(jìn)階之fixture詳解,學(xué)pytest就不得不說fixture,fixture是pytest的精髓所在,就像unittest中的setup和teardown一樣,如果不學(xué)fixture那么使用pytest和使用unittest是沒什么區(qū)別的,需要的朋友可以參考下
    2019-06-06
  • python實(shí)現(xiàn)的AES雙向?qū)ΨQ加密解密與用法分析

    python實(shí)現(xiàn)的AES雙向?qū)ΨQ加密解密與用法分析

    這篇文章主要介紹了python實(shí)現(xiàn)的AES雙向?qū)ΨQ加密解密與用法,簡單分析了AES加密解密算法的基本概念并結(jié)合實(shí)例形式給出了AES加密解密算法的相關(guān)實(shí)現(xiàn)技巧與使用注意事項(xiàng),需要的朋友可以參考下
    2017-05-05
  • python實(shí)現(xiàn)凱撒密碼

    python實(shí)現(xiàn)凱撒密碼

    這篇文章主要為大家詳細(xì)介紹了python實(shí)現(xiàn)凱撒密碼,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-04-04
  • python繪圖pyecharts+pandas的使用詳解

    python繪圖pyecharts+pandas的使用詳解

    這篇文章主要介紹了python繪圖pyecharts+pandas的使用詳解,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-12-12
  • Python爬取哆啦A夢-伴我同行2豆瓣影評并生成詞云圖

    Python爬取哆啦A夢-伴我同行2豆瓣影評并生成詞云圖

    哆啦A夢系列是陪伴我,乃至陪伴了幾代人成長的故事.50年來,藤子·F·不二雄先生創(chuàng)造了竹蜻蜓,任意門,時光機(jī)器等等無數(shù)的新奇道具,讓大雄和他的小伙伴們經(jīng)歷了各種冒險(xiǎn),也經(jīng)歷了許多充滿戲劇性的啼笑皆非的日常.特意寫了這篇文章,教大家怎么繪制詞云圖,需要的朋友可以參考下
    2021-06-06
  • 對python中數(shù)組的del,remove,pop區(qū)別詳解

    對python中數(shù)組的del,remove,pop區(qū)別詳解

    今天小編就為大家分享一篇對python中數(shù)組的del,remove,pop區(qū)別詳解,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-11-11
  • 詳解Python正則表達(dá)式re模塊

    詳解Python正則表達(dá)式re模塊

    這篇文章主要介紹了Python正則表達(dá)式re模塊,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-03-03

最新評論