博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
arcgis js api前端完成面积测算
阅读量:7296 次
发布时间:2019-06-30

本文共 1141 字,大约阅读时间需要 3 分钟。

想找一个不依赖GeometryService量算面积的方法,经过别人的帮助,终于在js帮助页上找到了。就是esri/geometry/geodesicUtils中的geodesicAreas方法,该方法通过Geometry获取其面积,在geodesicUtils还有一个获取几何要素长度的方法,geodesicLengths,可以用来获取长度。

当然,在使用这些方法之前,有些需要将Geometry转换一下投影,可以使用Geometry下的webMercatorUtils,在其中有webMercatorToGeographic(geometry)和geographicToWebMercator(geometry)这两个方法。不然,转出来的面积长度有可能是不对的。
 
下面是我做的一个例子,结合了draw这个方法:
画线和画面:
function measureLenght() {
            toolbar.activate(esri.toolbars.Draw.POLYLINE);
        }
        function measureArea() {
            toolbar.activate(esri.toolbars.Draw.POLYGON);
        }
在地图初始化的时候添加监听画图的事件:
            dojo.connect(toolbar, "onDrawEnd", GetLenthorArea);
 
量算面积和长度方法:
function GetLenthorArea(geometry) {//画图完毕后计算距离或者面积
            if (geometry.type == "polyline") {
                var geo = esri.geometry.webMercatorToGeographic(geometry);
                var Length = esri.geometry.geodesicLengths([geo], esri.Units.METERS);
 
                Map.infoWindow.setContent("距离:" + Length+ "米");
                Map.infoWindow.show();
            }
            else if(geometry.type == "polygon") {
                var geo = esri.geometry.webMercatorToGeographic(geometry);
                var Area = esri.geometry.geodesicAreas([geo], esri.Units.SQUARE_METERS);
                Map.infoWindow.setContent("面积:" + Area + "平方米");
                Map.infoWindow.show();
            }
        }
 
最后,别忘了添加引用

转载地址:http://seynm.baihongyu.com/

你可能感兴趣的文章
STL training (uva上一些比较好的用来熟悉STL)
查看>>
[未完成]关于CSS的总结
查看>>
陈皓一起写Makefile 概述
查看>>
linux下安装启动rpc服务
查看>>
Software Testing, Lab 1
查看>>
World发布博客测试
查看>>
IIS 提高连接的并发数,和CPU的使用率。
查看>>
修改Sysvol复制方式
查看>>
python3.x中如何使用base64、base32、base16编码解码
查看>>
HDOJ 1084 排序 水
查看>>
深度拷贝一个链表
查看>>
POJ3229
查看>>
用promise封装ajax
查看>>
git创建工程
查看>>
UIScrollView的contentSize、contentOffset和contentInset属性
查看>>
IOS开发之自定义UITabBarController
查看>>
关于UI设计中的交互软件Axure7.0运用
查看>>
将网站项目转为 Web form应用程序(转)
查看>>
泛型简要原理
查看>>
poj 1254 Hansel and Grethel
查看>>