VC++开发GIS系统(292)计算任意多边形的面积
发布时间: 2016-07-19
所属分类: VC++开发GIS系统
本文封装一个用于计算任意多边形面积的函数,也就是在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
相关阅读
声明
1.本文所分享的所有需要用户下载使用的内容(包括但不限于软件、数据、图片)来自于网络或者麻辣GIS粉丝自行分享,版权归该下载资源的合法拥有者所有,如有侵权请第一时间联系本站删除。
2.下载内容仅限个人学习使用,请切勿用作商用等其他用途,否则后果自负。
手机阅读
公众号关注
知识星球
手机阅读
最新GIS干货
私享圈子