概述
在 openlayers 中面积的量测和长度的测量大同小异,都需要借助于ol/sphere
模块,不同的是长度计算是调用ol/sphere
模块的getlength
方法,而面积则需要调用getarea
方法。
如果还不清楚如何在 openlayers 中计算长度,可以参考openlayers实现长度测量
实践
效果
代码分析
同长度测量一样,监听draw
类的实例对象的drawstart
方法,然后监听当前绘制的几何对象的change
事件,在这个监听回调函数中调用ol/sphere
的getarea
方法获取经纬度
this.draw.on("drawstart", ({ feature }) => { this.listener = feature.getgeometry().on("change", (evt) => { const geom = evt.target; const area = getarea(geom); }); });
ol/sphere的getarea方法
getarea方法用于计算地球表面上几何形状的面积,并且考虑了球体的曲率,这意味着它并不是计算平面上的面积,而是计算球面上闭合路径所围成的面积。
参数
geometry (ol/geom/polygon | ol/geom/multipolygon):
- geometry 是一个几何对象,通常是 polygon(多边形)或者 multipolygon(多个多边形的集合)。
- 对于 polygon,它表示一个闭合的区域,getarea 计算的是该区域的球面面积。
- 对于 multipolygon,计算的是多个多边形的总球面面积。
返回值
getarea方法返回的是一个数值,其单位是平方米。
ol/sphere实用 api 介绍
除了已经提到的getlength、getarea和getdistance方法外,ol/sphere模块还提供了许多其它实用的 api 方法。如下介绍:
getclosestpoint
计算一点到球面上某几何形状的最近点。
sphere.getclosestpoint(geometry, point);
containscoordinate
判断一个点是否在球面上某几何形状内。
sphere.containscoordinate(geometry, point);
getbearing
计算从一个点到另一个点的方位角(即从第一个点到第二个点的航向角)。方位角是指沿着大圆航线,连接这两个点的方向。
sphere.getbearing([lon1, lat1], [lon2, lat2]);
getintersection
计算两条大圆弧(球面上的两条最短路径)之间的交点。如果相交,则返回交点,否则返回null
sphere.getintersection( [lon1, lat1], [lon2, lat2], [lon3, lat3], [lon4, lat4] );
isflat
判断一个几何对象是否为平面(即判断其是否位于球面的某个平面上)。如果几何对象包含任何曲率,isflat 返回 false;如果对象的坐标位于平面上,返回 true。
sphere.isflat(geometry);
isvalid
判断一个几何对象是否有效。这对于确保几何对象在球面坐标系中是有效的非常有用。
sphere.isvalid(geometry);
getenvelope
获取几何对象的包围盒(bounding box),即可以包围该几何对象的最小矩形框。对于球面几何,返回的是一个近似的矩形包围盒。返回几何对象的包围盒,表示为最小的经纬度矩形。
sphere.getenvelope(geometry);
到此这篇关于openlayers实现面积测量的文章就介绍到这了,更多相关openlayers面积测量内容请搜索代码网以前的文章或继续浏览下面的相关文章希望大家以后多多支持代码网!
发表评论