VC++开发GIS系统(292)计算任意多边形的面积

本文目录
  • 正文

本文封装一个用于计算任意多边形面积的函数,也就是在GIS系统中计算区的面积的函数。

算法思路

多边形可以分为凸多边形和凹多边静形,针对两种情况有不同的计算公式,具体内容可以参考《计算任意多边形的面积 - tenos

算法实现

在_malaBase.h中 malaLogic 类声明如下函数

double ComputePolygonArea(vector<malaPoint> &points);//计算任意多边形的面积

在_malaBase.cpp中实现上述的函数定义

/*
*计算任意多边形的面积,顶点按照顺时针或者逆时针方向排列
*/
double malaLogic::ComputePolygonArea(vector<malaPoint> &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);
}

详细代码可以参考:GitHub

如果本文对你有所帮助,欢迎对我们团队进行打赏捐助,让我们在传播3S的路上可以走得更远。
赞赏支持
微信捐助麻辣GIS 支付宝捐助麻辣GIS

麻辣GIS-Sailor
作者:
GIS爱好者,学GIS,更爱玩GIS。

如您有疑问,可在文末留言,或到QQ群中提问。

本站QQ群(一):291616564 麻辣GIS

本站QQ群(二):166408035 麻辣GIS(二)

本站QQ群(三):627853279 麻辣GIS(三)

微信公众号:malagis,扫描右边二维码直接关注。

发表评论