0

每当我将图像传递给 cvStartFindContours 时,我的图像并没有找到轮廓,而是完全变黑。我完全不知道为什么。我知道这不是由代码的另一部分引起的,即使我将所有内容都注释掉,但是在对 cvStartFindContours 的函数调用中留下,我的图像仍然变黑。然而,当我注释掉对 cvStartFindContours 的调用时,我的图像仍然正常。为什么会这样?我传入的图像(skinMask)是一个 8 位、1 通道的图像(IPL_DEPTH_8U),包含数据。(它不是黑色的,上面有白色的碎片)。

为什么我的图像变黑了?谢谢

void connectedComponents ()
{
     cvMorphologyEx (skinMask, skinMask, 0, 0, CV_MOP_OPEN, 1);
     cvMorphologyEx (skinMask, skinMask, 0, 0, CV_MOP_CLOSE, 1);

     CvMemStorage *connectedCompStorage = cvCreateMemStorage (0);
     CvSeq *temp = NULL; //used to loop through contour perimeter checking
     CvSeq *connectedComp = NULL; //stores all derived connected component contours

     CvContourScanner connectedCompScanner = cvStartFindContours (skinMask, connectedCompStorage); //FUNCTION CALL CAUSING PROBLEMS

     while ((temp = cvFindNextContour (connectedCompScanner)) != NULL)
     {
         double perimeter = cvContourPerimeter (temp);

         if (perimeter < CC_PERIMETER_THRESH)
         {
             cvSubstituteContour (connectedCompScanner, NULL);
         }

         else
         {
             temp = cvApproxPoly (temp, sizeof (CvContour), connectedCompStorage, CV_POLY_APPROX_DP, 2, 0);
             cvSubstituteContour (connectedCompScanner, temp);
         }
     }

     connectedComp = cvEndFindContours (&connectedCompScanner);

     cvZero (skinMask);

     for (temp = connectedComp; temp != NULL; temp = temp -> h_next);
     {
         cvDrawContours (skinMask, temp, cvScalar (255, 255, 255), cvScalar (0, 0, 0), -1,   CV_FILLED, 8);
     }

     cvReleaseMemStorage (&connectedCompStorage);
}
4

1 回答 1

1

我也被这个咬过。来自 OpenCV 文档findContours

image – 源,8 位单通道图像。非零像素被视为 1。零像素保持为 0,因此图像被视为二进制。您可以使用compare()inRange()threshold()adaptiveThreshold()Canny()等从灰度或彩色图像中创建二值图像。该函数在提取轮廓的同时修改图像。

因此,如果您不想skinMask修改图像,则需要传入它的副本...

于 2011-10-28T15:05:47.790 回答