77 geometry process

0 引言

记录几何方面的一些处理技术。

1 任意多边形面积计算:包含凸多边形和凹多边形

转载了JustDoIT 

https://www.cnblogs.com/TenosDoIt/p/4047211.html

附上代码

struct Point2d
{
    double x;
    double y;
    Point2d(double xx, double yy): x(xx), y(yy){}
};
 
//计算任意多边形的面积,顶点按照顺时针或者逆时针方向排列
double ComputePolygonArea(const vector<Point2d> &points)
{
    int point_num = points.size();
    if(point_num < 3)return 0.0;
    double s = points[0].y * (points[point_num-1].x - points[1].x);
    for(int i = 1; i < point_num; ++i)
        s += points[i].y * (points[i-1].x - points[(i+1)%point_num].x);
    return fabs(s/2.0);
}

猜你喜欢

转载自www.cnblogs.com/ghjnwk/p/11280695.html
77