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

  • 2
    点赞
  • 14
    收藏
    觉得还不错? 一键收藏
  • 3
    评论
计算两个轮廓相交面积,可以按照以下步骤进行: 1. 读入两个轮廓的坐标点,可以使用opencv中的`cv::findContours`函数来获取轮廓的坐标点集合。 2. 使用`cv::boundingRect`函数计算两个轮廓的矩形边界框。 3. 判断两个矩形边界框是否相交,如果不相交两个轮廓相交面积,直接返回0。 4. 如果两个矩形边界框相交,则使用`cv::clipLine`函数计算两个轮廓相交的线段,然后使用`cv::contourArea`函数计算相交线段所在的面积。 下面是一个示例代码: ```c++ #include <opencv2/opencv.hpp> using namespace cv; double intersectArea(const std::vector<Point>& contour1, const std::vector<Point>& contour2) { // 计算轮廓1和轮廓2的矩形边界框 Rect rect1 = boundingRect(contour1); Rect rect2 = boundingRect(contour2); // 判断矩形边界框是否相交 if (!rect1.intersects(rect2)) return 0; // 计算相交线段的两个端点 Point pt1(std::max(rect1.x, rect2.x), std::max(rect1.y, rect2.y)); Point pt2(std::min(rect1.x + rect1.width, rect2.x + rect2.width), std::min(rect1.y + rect1.height, rect2.y + rect2.height)); // 计算相交线段所在的面积 std::vector<Point> intersectContour; intersectContour.push_back(pt1); intersectContour.push_back(Point(pt2.x, pt1.y)); intersectContour.push_back(pt2); intersectContour.push_back(Point(pt1.x, pt2.y)); double area = contourArea(intersectContour); return area; } int main() { // 读入两个轮廓的坐标点 std::vector<Point> contour1 = { Point(0, 0), Point(0, 100), Point(100, 100), Point(100, 0) }; std::vector<Point> contour2 = { Point(50, 50), Point(50, 150), Point(150, 150), Point(150, 50) }; // 计算两个轮廓相交面积 double area = intersectArea(contour1, contour2); std::cout << "Intersection area = " << area << std::endl; return 0; } ``` 这里假设两个轮廓已经读入并存储在`contour1`和`contour2`中,每个轮廓是一个由`cv::Point`组成的`std::vector`容器。
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值