当前位置:   article > 正文

利用opencv计算两个轮廓相交(交集)区域的面积_c# opencv 判断两个轮廓有交集

c# opencv 判断两个轮廓有交集

1.将轮廓分别画在两个图层中,ImSrc1,ImSrc2;
2.合成两个图层到Imsrc = ImSrc1 + ImSrc2;
3.二值化(threshold )Imsrc图层;
4.findContours得到相交轮廓;
5.contourArea计算相交区域面积。

具体上代码:

cv::Mat Imsrc1,Imsrc2,Imsrc,Imdest;
Imsrc1 = cv::Mat(600, 800, CV_8U, cv::Scalar(255));
Imsrc2 = cv::Mat(600, 800, CV_8U, cv::Scalar(255));
//画实心椭圆
cv::ellipse(Imsrc1, cv::Point(0, 0), cv::Size(100,50), 0, 0, 360, cv::Scalar(200), -1);
//画实心多边形
std::vector<cv::Point > contour;
std::vector<std::vector<cv::Point >> contours;
contour.reserve(m_pntNum);
//填充多边形的顶点坐标
for (int i = 0; i < m_pntNum; ++i)
{
	cv::Point pnt(imgPnt[i].x(), imgPnt[i].y());
	contour.push_back(pnt);
}

contours.push_back(contour);
cv::fillPoly(Imsrc2, contours, cv::Scalar(200));//fillPoly函数的第二个参数是二维数组!!

Imsrc = Imsrc1 + Imsrc2;
cv::threshold(Imsrc, Imdest, 200, 255, cv::/*THRESH_BINARY*/THRESH_BINARY_INV);//THRESH_BINARY_INV不检测图片画布轮廓

cv::findContours(Imdest, contoursDest, hierarchy, cv::RETR_EXTERNAL/* RETR_TREE*/, cv::CHAIN_APPROX_SIMPLE);//RETR_EXTERNAL,内轮廓不重复计算

double dbArea = 0;
for (int c = 0; c < contoursDest.size(); ++c)
{
	dbArea += contourArea(contoursDest[c]);
}

  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23
  • 24
  • 25
  • 26
  • 27
  • 28
  • 29
  • 30
声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/繁依Fanyi0/article/detail/423053
推荐阅读
相关标签
  

闽ICP备14008679号