c# - 如何在 EmguCV 中使用 C# 中的迭代器?

标签 c# c++ opencv emgucv

在 OpenCV 中我使用 std::vector<std::vector<cv::Point>>::const_iterator喜欢这里的代码:

std::vector<std::vector<cv::Point>> contours;
cv::findContours(contour,contours,CV_RETR_TREE,CV_CHAIN_APPROX_SIMPLE);    
std::vector<std::vector<cv::Point>>::const_iterator itContours = contours.begin();

while(itContours != contours.end())
{
    if(Condition1)
        itContours = contours.erase(itContours);
    else if(Condition2)
    itContours = contours.erase(itContours);
    else if(Condition3)
        itContours = contours.erase(itContours);
    else
        ++itContours;
}

但现在我开始使用 EmguCV,但我找不到像上面的代码那样的操作方法。我该怎么做?

最佳答案

查看 EMGU.Examples 文件夹中的形状检测示例。它向您展示了如何处理轮廓。我已经复制了下面的相关代码供您引用,但是看看示例会更好。

        #region Find triangles and rectangles
        List<Triangle2DF> triangleList = new List<Triangle2DF>();
        List<MCvBox2D> boxList = new List<MCvBox2D>(); //a box is a rotated rectangle

        using (MemStorage storage = new MemStorage()) //allocate storage for contour approximation
           for (Contour<Point> contours = cannyEdges.FindContours(Emgu.CV.CvEnum.CHAIN_APPROX_METHOD.CV_CHAIN_APPROX_SIMPLE,        Emgu.CV.CvEnum.RETR_TYPE.CV_RETR_LIST, storage); contours != null; contours = contours.HNext)
           {
              Contour<Point> currentContour = contours.ApproxPoly(contours.Perimeter * 0.05, storage);

              if (currentContour.Area > 250) //only consider contours with area greater than 250
              {
                 if (currentContour.Total == 3) //The contour has 3 vertices, it is a triangle
                 {
                    Point[] pts = currentContour.ToArray();
                    triangleList.Add(new Triangle2DF(
                       pts[0],
                       pts[1],
                       pts[2]
                       ));
                 }
                 else if (currentContour.Total == 4) //The contour has 4 vertices.
                 {
                    #region determine if all the angles in the contour are within [80, 100] degree
                    bool isRectangle = true;
                    Point[] pts = currentContour.ToArray();
                    LineSegment2D[] edges = PointCollection.PolyLine(pts, true);

                    for (int i = 0; i < edges.Length; i++)
                    {
                       double angle = Math.Abs(
                          edges[(i + 1) % edges.Length].GetExteriorAngleDegree(edges[i]));
                       if (angle < 80 || angle > 100)
                       {
                          isRectangle = false;
                          break;
                       }
                    }
                    #endregion

                    if (isRectangle) boxList.Add(currentContour.GetMinAreaRect());
                 }
              }
           }
        #endregion

让我知道您是否需要任何额外的帮助,如果出现任何错误,

干杯,

克里斯

关于c# - 如何在 EmguCV 中使用 C# 中的迭代器?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/8767333/

相关文章:

c# - 任何用于 .NET/C# 的 Javascript 引擎?

c++ - boost function_input_iterator range 的快捷语法

c++ - 不同的普通可复制类型之间的 std::memcpy 是未定义的行为吗?

python - OpenCV for ARM (Beagleboard) 使用 YUYV 而不是 JPEG 压缩?

python - 如何从 OpenCV 中已标记的图像中获取区域属性?

c++ - 如何仅将光流 vector 应用于检测到的圆

c# - 如何在 Windows 上运行的自托管 ServiceStack 中获取用户名

c# - 如何从 C# 循环 USB 设备?

c# - 用户在 SqlCommand 中指定的存储过程名称

c++ - Xcode 10 更新后 CMake 找不到 stdc++11