GEOS库的学习之二:简单几何图形的创建
学习 简单 创建 之二
2023-09-11 14:17:15 时间
几何图形(Geometry)是geos里面基本的操作对象,因此Geometry类就是最重要的一个类
几何图形中主要有三个要素:点,线,面。横纵坐标构成点,多个点构成线,环线构成面,点线面混合构成几何集合。对应的几个类为
坐标:Coordinate
点:Point、MultiPoint
线:LineString、MultiLineString(多条线)、LinearRing(环线)
面:Polygon、MultiPolygon
集合:GeometryCollection
在geos中,最小的组成单位是坐标,由Coordinate类来创建,如:Coordinate(2,3),表示一个点,横坐标是2,纵坐标是3.
所有的几何图形的创建,都是由类GeometryFactory来完成。因此,在创建几何图形前,可以先创建一个全局的GeometryFactory对象;
GeometryFactory factory; //全局对象,所有的图形都由此对象创建
1、点的创建
Point* createGeosPoint(double x,double y) { Coordinate pt(x,y); Point* p=factory.createPoint(pt); return p; }
2、非闭合线条的创建
LineString* createGeosLine(double x,double y, double offset) { CoordinateArraySequence *cas=new CoordinateArraySequence(); //构建点序列 cas->add(Coordinate(x,y)); cas->add(Coordinate(x,y+offset)); cas->add(Coordinate(x+offset,y+offset)); cas->add(Coordinate(x+offset,y+2*offset)); cas->add(Coordinate(x+2*offset,y+2*offset)); LineString *ls=factory.createLineString(cas); return ls; }
3、闭合线条的创建
//创建一条环线,与线的区别就是环线是闭合的。即第一个点和最后一点重合 LinearRing* createGeosRing(double x,double y,double offset) { CoordinateArraySequence *cas=new CoordinateArraySequence(); //构建点序列 cas->add(Coordinate(x,y)); cas->add(Coordinate(x,y+offset)); cas->add(Coordinate(x+offset,y+offset)); cas->add(Coordinate(x+offset,y+2*offset)); cas->add(Coordinate(x+2*offset,y+2*offset)); cas->add(Coordinate(x+2*offset,y)); cas->add(Coordinate(x,y)); //与第一个点相等 LinearRing *lr=factory.createLinearRing(cas); return lr; }
除了用add的方法来构建点序列,也可以用另外一种方法setAt
LinearRing* createGeosRing(double x,double y,double offset) { CoordinateArraySequenceFactory csf; CoordinateSequence* cs = csf.create(7,2); cs->setAt(Coordinate(x,y),0); cs->setAt(Coordinate(x,y+offset),1); cs->setAt(Coordinate(x+offset,y+offset),2); cs->setAt(Coordinate(x+offset,y+2*offset),3); cs->setAt(Coordinate(x+2*offset,y+2*offset),4); cs->setAt(Coordinate(x+2*offset,y),5); cs->setAt(Coordinate(x,y),6); //与第一个点相等 LinearRing *lr=factory.createLinearRing(cs); return lr; }
4、多边形的创建
//创建一个多边形,如果多边形内部没有孔洞实际上与环线是一样的 Polygon* createGeosPolygon(double x,double y,double offset) { LinearRing *lr=createGeosRing(x,y,offset); Polygon *poly=factory.createPolygon(lr,NULL); //如果多边形中间没有孔洞,第二个参数设为NULL return poly; }
测试:
#include "geos.h" int main() { LineString *ls=createGeosRing(10,10,5); cout<<"线条点数:"<<ls->getNumPoints()<<" 线条长度:"<<ls->getLength()<<endl; Polygon *poly=createGeosPolygon(10,10,5); cout<<"多边形面积:"<<poly->getArea()<<endl; system("pause"); return 1; }
相关文章
- [Python学习] 简单爬取CSDN下载资源信息
- 超简单的网上打印方法,在家学习办公也能打印资料
- 简单易学的机器学习算法—基于密度的聚类算法DBSCAN
- zeromq学习笔记2——简单的客户端和服务端测试程序
- 简单易学的机器学习算法—SVD奇异值分解
- 简单易学的机器学习算法—基于密度的聚类算法DBSCAN
- java struts2入门学习--基于xml文件的声明式验证
- 【学习总结】《大话数据结构》- 总
- GitHub学习笔记
- 通过一个简单的例子学习Angular Injection Token工作原理
- 【阶段三】Python机器学习01篇:机器学习概念、机器学习类别、机器学习应用场景与机器学习基本技术:特征、标签、模型
- mongo数据库命令简单学习
- iOS学习笔记---简单的学习总结
- JAVA学习Swing章节流布局管理器简单学习
- JAVA学习Swing绝对局部简单学习
- 机器学习——特征工程
- 猫猫学iOS 之第一次打开Xcode_git配置,git简单学习
- 【机器学习】简单解释贝叶斯公式和朴素贝叶斯分类?(面试回答)
- 从入门到精通,大厂内部整理Android学习路线
- 动手学深度学习——数据操作和数据预处理
- 【黑马程序员新版Linux学习笔记】Linux 小技巧快捷键
- 【深度学习】MLP/LeNet/AlexNet/GoogLeNet/ResNet在三个不同数据集上的分类效果实践
- 学习经验分享【24】全网最简单标注数据集方法
- 【redis源码学习】simple dynamic strings(简单动态字符串 sds)