Проблемы в поиске контуров и выпуклой оболочки в openCV - PullRequest
0 голосов
/ 05 февраля 2012

Я написал следующий код

#include"opencv2/opencv.hpp"

 #include<iostream>
 #include<math.h>
 using namespace std;
 using namespace cv;

main()
{
Mat img1,img2,sub,gray1,gray2,lab,ycbcr;
int v[3];

int row,col,i,j,t;
VideoCapture cap(0);

namedWindow("current");

cap>>img1;
sub=img1;

row=img1.rows;
col=img1.cols;

cvtColor(img1,gray1,CV_BGR2GRAY);


vector<vector<Point> > cont;

vector<Vec4i> hierarchy;

while (1) {

    cap>>img2;

    cvtColor(img2,gray2,CV_BGR2GRAY);


    for(i=0;i<row;++i)
    {
        for (j=0; j<col; ++j)
        {


            if(abs(gray1.at<uchar>(i,j) - gray2.at<uchar>(i,j))>10)
            {
                sub.at<Vec3b>(i,j)[0] = img2.at<Vec3b>(i,j)[0];
                sub.at<Vec3b>(i,j)[1] = img2.at<Vec3b>(i,j)[1];
                sub.at<Vec3b>(i,j)[2] = img2.at<Vec3b>(i,j)[2];

            }
            else
            {

                sub.at<Vec3b>(i,j)[0]=0;
                sub.at<Vec3b>(i,j)[1]=0;
                sub.at<Vec3b>(i,j)[2]=0;
            }

        }


    }


    cvtColor(sub,ycbcr,CV_BGR2YCrCb);

    inRange(ycbcr,Scalar(7,133,106),Scalar(255,178,129),ycbcr);
    findContours(ycbcr,cont,hierarchy,CV_RETR_LIST,CV_CHAIN_APPROX_SIMPLE);
    Scalar color = CV_RGB(255,0,0);
    for(int i1 = 0 ;i1 >= 0; i1 = hierarchy[i1][0] )
    drawContours( ycbcr, cont, i1, color,2, CV_AA, hierarchy );



    vector<Point2f > hullPoints;
  // convexHull(Mat(cont),hullPoints,false);
    imshow("current",ycbcr);

a if (waitKey (33) == 'q') break;img1 = img2.clone ();}

}

1.) Почему контуры не отображаются красным цветом, хотя я указал его через CV_RGB (255,0,0).2.) Когда я раскомментирую строку выпуклыйHull (Mat (продолжение), hullPoints, false);, программа показывает ошибку во время выполнения. Почему это происходит? Может кто-нибудь сказать мне точный формат функции transxHull () и значение его аргументов

Ответы [ 2 ]

2 голосов
/ 05 февраля 2012

1) Попробуйте (0,0,255) для красного цвета. OpenCV использует формат BGR.

2) Чтобы найти выпуклую оболочку, попробуйте код в OpenCV tutorial.

Также попробуйте подобный вопрос, как ваш на Convexhull. Как рассчитать площадь выпуклой оболочки с помощью функций openCV?

1 голос
/ 28 октября 2014

Ваш вектор hullPoints пуст. Если вы проверите размер вектора, вы не получите ошибку.

if(hullPoints.size() > 2) {
  convexHull(....);
 }
...