1. <strong id="7actg"></strong>
    2. <table id="7actg"></table>

    3. <address id="7actg"></address>
      <address id="7actg"></address>
      1. <object id="7actg"><tt id="7actg"></tt></object>

        OpenCV中如何提取不規(guī)則ROI區(qū)域

        共 2105字,需瀏覽 5分鐘

         ·

        2021-05-29 00:04

        什么是ROI

        ROI是英文Region Of Interest的三個首字母縮寫,很多時候我們對圖像的分析就是對圖像特定ROI的分析與理解,對細胞與醫(yī)療圖像來說,ROI提取正確才可以進行后續(xù)的分析、測量、計算密度等,而且這些ROI區(qū)域往往不是矩形區(qū)域,一般都是不規(guī)則的多邊形區(qū)域,很多OpenCV初學者都不知道如何提取這些不規(guī)則的ROI區(qū)域。其實OpenCV中有個非常方便的API函數(shù)可以快速提取各種非正常的ROI區(qū)域。

        提取ROI區(qū)域

        在做這個之前,首先來了解一下什么圖像處理中的mask(遮罩),OpenCV中是如此定義Mask的:八位單通道的Mat對象,每個像素點值為零或者非零區(qū)域。當Mask對象添加到圖像區(qū)上時,只有非零的區(qū)域是可見,Mask中所有像素值為零與圖像重疊的區(qū)域就會不可見,也就是說Mask區(qū)域的形狀與大小直接決定了你看到最終圖像的大小與形狀。一個具體的示例如下:

        可以看出,mask的作用是可以 幫助我們提取各種不規(guī)則的區(qū)域。OpenCV中完成上述步驟操作只需要簡單調用API函數(shù) bitwise_and 即可。


        于是另外一個問題也隨之而來,我們怎么生成這樣mask區(qū)域,答案是在OpenCV中有兩種方法搞定Mask區(qū)域生成。


        方法一:

        通過手動選擇,然后通過多邊形填充即可做到,代碼實現(xiàn)如下:

        import cv2 as cv
        import numpy as np

        src = cv.imread("D:/images/gc_test.png")
        cv.imshow("input", src)
        h, w, c = src.shape

        # 手工繪制ROI區(qū)域
        mask = np.zeros((h, w), dtype=np.uint8)
        x_data = np.array([124169208285307260175])
        y_data = np.array([205124135173216311309])
        pts = np.vstack((x_data, y_data)).astype(np.int32).T
        cv.fillPoly(mask, [pts], (255), 80)
        cv.imshow("mask", mask)

        # 根據(jù)mask,提取ROI區(qū)域
        result = cv.bitwise_and(src, src, mask=mask)
        cv.imshow("result", result)
        cv.waitKey(0)

        運行效果如下:

        方法二:

        這個也是OpenCV新手最迷茫的地方,如何通過程序生成mask,其實真的很簡單??创a演示吧!

        src = cv.imread("D:/images/gc_test.png")
        cv.imshow("input", src)

        # 生成mask區(qū)域
        hsv = cv.cvtColor(src, cv.COLOR_BGR2HSV)
        mask = cv.inRange(hsv, (1564346), (180255255))
        cv.imshow("mask", mask)

        # 提取ROI區(qū)域,根據(jù)mask
        result = cv.bitwise_and(src, src, mask=mask)
        cv.imshow("result", result)
        cv.waitKey(0)

        效果如下:

        主要是分為三步

        1. 提取輪廓ROI

        2. 生成Mask區(qū)域

        3. 提取指定輪廓

        特別需要注意的是->其中生成Mask可以根據(jù)輪廓、二值化連通組件分析、inRange等處理方法得到。這里基于inRange方式得到mask區(qū)域,然后提取。

        實際應用演示

        最后看兩個在實際處理會用到mask實現(xiàn)ROI提取然后重新背景融合之后生成新圖像效果:

         End 


        聲明:部分內(nèi)容來源于網(wǎng)絡,僅供讀者學術交流之目的。文章版權歸原作者所有。如有不妥,請聯(lián)系刪除。


        點「在看」的人都變好看了哦!
        瀏覽 47
        點贊
        評論
        收藏
        分享

        手機掃一掃分享

        分享
        舉報
        評論
        圖片
        表情
        推薦
        點贊
        評論
        收藏
        分享

        手機掃一掃分享

        分享
        舉報
        1. <strong id="7actg"></strong>
        2. <table id="7actg"></table>

        3. <address id="7actg"></address>
          <address id="7actg"></address>
          1. <object id="7actg"><tt id="7actg"></tt></object>
            免费观看在线无码视频 | 无码毛片一区二区三区视频免费播放 | 日韩 人妻 精品 | 欧美一级黄片免费看 | 国产一级黄色电影 | 娇妻玩4p被3个男子伺候 | 午夜免费69性视频爽爽爽 | 999精品视频在线 | 婷婷五月天综合 | 日韩中文字幕 |