亚洲免费在线-亚洲免费在线播放-亚洲免费在线观看-亚洲免费在线观看视频-亚洲免费在线看-亚洲免费在线视频

OpenCV for Ios 學習筆記(4)-標記檢測1

系統 2716 0

本文原始地址: OpenCV for Ios 學習筆記(4)-標記檢測1

簡單的標記經常是以白色塊和黑色塊構成的規則圖形。因為我們預先知道這些因素,所以我們可以很容易檢測標記。

如圖:

OpenCV for Ios 學習筆記(4)-標記檢測1

首先,我們需要找到封閉的輪廓,然后在矩形輪廓里檢查我們的標記。

下面是標記監測管道的處理流程:


1.把輸入的圖像轉化成灰度圖像。

2.進行二進制閾值操作(Perform binary threshold operation)。

3.檢測圖像輪廓。

4.搜索可能的標記。

5.檢測并解碼標記。

6.模擬出標記的三維姿態(形狀)。


首先,我們進行 圖像灰度化

cvCvtColor

?

    //灰度化

void MarkerDetector::prepareImage(const cv::Mat& bgraMat,cv::Mat& grayscale)

{

    //convert grayscale

    cv::cvtColor(bgraMat, grayscale, CV_BGR2GRAY);

}
  


其次是 圖像的二值化 (Image binarization)

?

關于二值化,參考: OpenCV二值化方法

二值化操作將把我們的圖像每個像素轉換為黑色(零強度)或白色(烈度),首先我們需要找到輪廓,目前有許多種求閥值的方法,但是多有各自的優勢和缺點。

其中既簡單又快捷的方法是絕對閥值法-結果依賴于像素強度和某些閥值,即如果像素強度大于閥值,其結果將是白(255),否則將是黑(0)。

但是這個方法有個最大的缺點-它依賴于照明和軟強度變化(soft intensity changes)。所以更加可取的方法是自適應閥值-最大的不同在于在以被檢查的像素為圓心的半徑內使用所有像素。使用平均強度來保證更加健壯的角點檢測。

OpenCV學習筆記-自適應閾值化

?

    void MarkerDetector::performThreshold(const cv::Mat& grayscale,cv::Mat& thresholdImg)

{

    //輸入圖像

    //輸出圖像

    //使用 CV_THRESH_BINARY 和 CV_THRESH_BINARY_INV 的最大值

    //自適應閾值算法使用:CV_ADAPTIVE_THRESH_MEAN_C 或 CV_ADAPTIVE_THRESH_GAUSSIAN_C 

    //取閾值類型:必須是下者之一

    //CV_THRESH_BINARY,

    //CV_THRESH_BINARY_INV

    //用來計算閾值的象素鄰域大小: 3, 5, 7, ...

    //

    cv::adaptiveThreshold(grayscale, thresholdImg, 255, cv::ADAPTIVE_THRESH_GAUSSIAN_C, cv::THRESH_BINARY_INV, 7, 7);

}
  


輪廓檢測

?

這個函數的輸出是一個一個多邊形的集合,每個多邊形多代表一個可能的輪廓。在這個方法中,我們忽略了尺寸小于minContoursPointAllowed的多邊形,因為我們認為它們要么不是有效的輪廓,要么實在太小,不值得去檢測它們。


    void MarkerDetector::findContours(const cv::Mat &thresholdImg, std::vector<std::vector<cv::Point>> &contours, int minContoursPointAllowed)

{

    //所有的輪廓

    std::vector<std::vector<cv::Point>> allContours;

    

    //輸入圖像image必須為一個2值單通道圖像

    //檢測的輪廓數組,每一個輪廓用一個point類型的vector表示

    //輪廓的檢索模式

    /*

     CV_RETR_EXTERNAL表示只檢測外輪廓

     CV_RETR_LIST檢測的輪廓不建立等級關系

     CV_RETR_CCOMP建立兩個等級的輪廓,上面的一層為外邊界,里面的一層為內孔的邊界信息。如果內孔內還有一個連通物體,這個物體的邊界也在頂層。

     CV_RETR_TREE建立一個等級樹結構的輪廓。具體參考contours.c這個demo

     */

    //輪廓的近似辦法

    /*

     CV_CHAIN_APPROX_NONE存儲所有的輪廓點,相鄰的兩個點的像素位置差不超過1,即max(abs(x1-x2),abs(y2-y1))==1

     CV_CHAIN_APPROX_SIMPLE壓縮水平方向,垂直方向,對角線方向的元素,只保留該方向的終點坐標,例如一個矩形輪廓只需4個點來保存輪廓信息

     CV_CHAIN_APPROX_TC89_L1,CV_CHAIN_APPROX_TC89_KCOS使用teh-Chinl chain 近似算法

     offset表示代表輪廓點的偏移量,可以設置為任意值。對ROI圖像中找出的輪廓,并要在整個圖像中進行分析時,這個參數還是很有用的。

     */

    cv::findContours(thresholdImg, allContours, CV_RETR_LIST, CV_CHAIN_APPROX_NONE);

    contours.clear();

    for (size_t i = 0; i < allContours.size(); i++)

    {

        int size = allContours[i].size();

        if (size > minContoursPointAllowed)

        {

            contours.push_back(allContours[i]);

        }

    }

}
  


下面是我們檢測到的輪廓:

OpenCV for Ios 學習筆記(4)-標記檢測1


閾值

閾值就是臨界值,在PS中的閾值,實際上是基于圖片亮度的一個黑白分界值,默認值是50%中性灰,即128,亮度高于128(<50%的灰)的會變白,低于128(>50%的灰)的會變黑(可以跟濾鏡中的其它――高反差保留,再用閾值效果會更好)


注:該學習筆記主要翻譯自Mastering OpenCV with Practical Computer Visi

?

?

OpenCV for Ios 學習筆記(4)-標記檢測1


更多文章、技術交流、商務合作、聯系博主

微信掃碼或搜索:z360901061

微信掃一掃加我為好友

QQ號聯系: 360901061

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點擊下面給點支持吧,站長非常感激您!手機微信長按不能支付解決辦法:請將微信支付二維碼保存到相冊,切換到微信,然后點擊微信右上角掃一掃功能,選擇支付二維碼完成支付。

【本文對您有幫助就好】

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描上面二維碼支持博主2元、5元、10元、自定義金額等您想捐的金額吧,站長會非常 感謝您的哦!!!

發表我的評論
最新評論 總共0條評論
主站蜘蛛池模板: 香蕉视频免费在线播放 | 成年女人毛片免费观看中文w | 人人天天夜夜 | 国产精品麻豆高清在线观看 | 亚洲综合欧美日韩 | 狠狠操天天爱 | 老司机毛片| 亚洲国产成人资源在线桃色 | 不卡一区二区在线 | 国产一级毛片网站 | 久久国产影院 | 97理论三级九七午夜在线观看 | 97看看| 久久99精品久久久久久牛牛影视 | 狠狠色噜狠狠狠狠色综合久 | 亚洲另类中文字幕 | 久9久9精品视频在线观看 | 青青热在线精品视频免费 | 欧美色欧美亚洲高清在线视频 | 夜夜天堂| 国产亚洲精品国产一区 | 2021精品综合久久久久 | 亚洲香蕉 | 日本中文在线 | 亚洲第一综合色 | 日本在线观看a | 亚洲一区二区三区播放在线 | 不卡网站 | 欧美日韩一区二区不卡三区 | 男人天堂视频在线 | 国产午夜成人无码免费看 | 99视频免费 | videos欧美黑白爆交 | 色综合网亚洲精品久久 | 四虎永久在线精品视频免费观看 | 四虎影院中文字幕 | 国产中文字幕视频 | 麻豆精品久久久一区二区 | 四虎永久在线精品国产馆v视影院 | 2019年国产高清情侣视频 | 久久噜噜噜久久亚洲va久 |