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

來源:互聯網
上載者:User

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

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

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

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


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]);        }    }}

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

閾值

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

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.