(转)Arcgis for Js之GeometryService实现测量距离和面积
http://blog.csdn.net/gisshixisheng/article/details/40540601
距离和面积的测量时GIS常见的功能,在本节,讲述的是通过GeometryService实现测量面积和距离。先看看实现后的效果:

距离 面积
首先,进行配置:
- //identify proxy page to use if the toJson payload to the geometry service is greater than 2000 characters.
- //If this null or not available the project and lengths operation will not work. Otherwise it will do a http post to the proxy.
- esriConfig.defaults.io.proxyUrl = "/proxy";
- esriConfig.defaults.io.alwaysUseProxy = false;
接着,定义GeometryService和绘图工具:
- var gsvc = new GeometryService("http://localhost:6080/arcgis/rest/services/Utilities/Geometry/GeometryServer");
- var measureToolbar = new esri.toolbars.Draw(map);
接下来,绘图结束后将所绘制图形添加到地图上面,并返回测量结果,那么增加measureToolbar的draw-end事件:
- measureToolbar.on("draw-end",showMeasureResults);
- /**
- * 显示测量结果
- * @param evt
- */
- var showPt=null;
- function showMeasureResults(evt){
- measureToolbar.deactivate();
- map.setMapCursor("default");
- var geometry = evt.geometry;
- switch (geometry.type) {
- case "polyline":{
- var length = geometry.paths[0].length;
- showPt = new Point(geometry.paths[0][length-1],map.spatialReference);
- var lengthParams = new LengthsParameters();
- lengthParams.lengthUnit = esri.tasks.GeometryService.UNIT_KILOMETER;
- lengthParams.polylines = [geometry];
- gsvc.lengths(lengthParams);
- break;
- }
- case "polygon":{
- showPt = new Point(geometry.rings[0][0],map.spatialReference);
- var areasAndLengthParams = new AreasAndLengthsParameters();
- areasAndLengthParams.lengthUnit = esri.tasks.GeometryService.UNIT_KILOMETER;
- areasAndLengthParams.areaUnit = esri.tasks.GeometryService.UNIT_SQUARE_KILOMETERS;
- gsvc.simplify([geometry], function(simplifiedGeometries) {
- areasAndLengthParams.polygons = simplifiedGeometries;
- gsvc.areasAndLengths(areasAndLengthParams);
- });
- break;
- }
- }
- var graphic = new Graphic(geometry, getGeometrySymbol(geometry.type));
- map.graphics.add(graphic);
- }
根据geometry的类型,增加GeometryService的lengths-complete或者areas-and-lengths-complete事件:
- gsvc.on("lengths-complete",outputLength);
- function outputLength(evtObj){
- var result = evtObj.result;
- showmeasureInfo(showPt, result.lengths[0].toFixed(3), "千米");
- };
- gsvc.on("areas-and-lengths-complete",outputAreaAndLength);
- function outputAreaAndLength(evtObj){
- var result = evtObj.result;
- showmeasureInfo(showPt, result.areas[0].toFixed(3), "平方千米");
- };
最后,将返回的结果显示在地图上:
- /**
- * 显示测量结果
- * @param showPnt
- * @param data
- * @param unit
- */
- function measureInfo(showPnt,data,unit){
- var measureDiv=$("#measure");
- var isShow = false;
- var screenPnt=map.toScreen(showPnt);
- measureDiv.css("left",screenPnt.x+"px");
- measureDiv.css("top",screenPnt.y+"px");
- measureDiv.css("position","absolute");
- measureDiv.css("height","20px");
- measureDiv.css("display","block");
- isShow = true;
- measureDiv.css("z-index","999");
- if(unit==="千米"){
- measureDiv.css("width","90px");
- }
- else{
- measureDiv.css("width","130px");
- }
- $("#result").html(data+unit);
- $("#infoclose").click(function(){
- map.graphics.clear();
- measureDiv.css("display","none");
- isShow = false;
- });
- map.on("pan-start", function(){
- measureDiv.css("display","none");
- });
- map.on("pan-end", function(panend){
- if(isShow == true){
- screenPnt=map.toScreen(showPnt);
- measureDiv.css("left",screenPnt.x+"px");
- measureDiv.css("top",screenPnt.y+"px");
- measureDiv.css("position","absolute");
- measureDiv.css("height","20px");
- measureDiv.css("display","block");
- }
- });
- map.on("zoom-start", function(){
- measureDiv.css("display","none");
- });
- map.on("zoom-end", function(){
- if(isShow == true){
- screenPnt=map.toScreen(showPnt);
- measureDiv.css("left",screenPnt.x+"px");
- measureDiv.css("top",screenPnt.y+"px");
- measureDiv.css("position","absolute");
- measureDiv.css("height","20px");
- measureDiv.css("display","block");
- }
- });
- };
结果的显示我是通过一个div来显示的,并且做了缩放和地图移动的处理。
(转)Arcgis for Js之GeometryService实现测量距离和面积的更多相关文章
- Arcgis for Js之GeometryService实现测量距离和面积
距离和面积的测量时GIS常见的功能,在本节,讲述的是通过GeometryService实现测量面积和距离.先看看实现后的效果: 距离 ...
- ArcGIS Runtime SDK for WPF之测量距离和面积
bu不多说,上代码 using System.Windows; using ESRI.ArcGIS.Client; using ESRI.ArcGIS.Client.Tasks; using ESRI ...
- OpenLayers测量距离和面积
<!DOCTYPE html> <html> <head> <title>测量距离和面积</title> <meta http-equ ...
- Arcgis for Js之GeometryService实现測量距离和面积
距离和面积的測量时GIS常见的功能.在本节,讲述的是通过GeometryService实现測量面积和距离.先看看实现后的效果: watermark/2/text/aHR0cDovL2Jsb2cuY3N ...
- OpenLayers动态测量距离和面积,并可自定义测量的线样式
全局操作变量 /** * @description 标注弹出框 */ HtmlPopup = null; /** * @description 临时图层类数据源 */ VectorSource = n ...
- CAD图在线Web测量工具代码实现(测量距离、面积、角度等)
CAD如今在各个领域均得到了普遍的应用并大大提高了工程技术人员的工作效率.在桌面端,AutoCAD测量工具已经非常强大:然后在Web端,如何准确.快速的对CAD图在Web进行测量呢? 功能 能Web在 ...
- (转)Arcgis for JS之对象捕捉
http://blog.csdn.net/gisshixisheng/article/details/44098615 在web操作,如绘制或者测量的时候,为了精确,需要捕捉到某一图层的对象,在此,讲 ...
- Arcgis for JS之Cluster聚类分析的实现(基于区域范围的)
原文:Arcgis for JS之Cluster聚类分析的实现(基于区域范围的) 咱们书接上文,在上文,实现了基于距离的空间聚类的算法实现,在本文,将继续介绍空间聚类之基于区域范围的实现方式,好了,闲 ...
- Arcgis for JS之Cluster聚类分析的实现
原文:Arcgis for JS之Cluster聚类分析的实现 在做项目的时候,碰见了这样一个问题:给地图上标注点对象,数据是从数据库来 的,包含XY坐标信息的,通过graphic和graphicla ...
随机推荐
- 【codeforces 515D】Drazil and Tiles
[题目链接]:http://codeforces.com/contest/515/problem/D [题意] 给你一个n*m的格子; 然后让你用1*2的长方形去填格子的空缺; 如果有填满的方案且方案 ...
- 洛谷 P1843 奶牛晒衣服
题目背景 熊大妈决定给每个牛宝宝都穿上可爱的婴儿装 . 于是 , 为牛宝宝洗晒衣服就成了很不爽的事情. 题目描述 熊大妈请你帮助完成这个重任 . 洗完衣服后 , 你就要弄干衣服 . 衣服在自然条件下用 ...
- [Cogs727] [网络流24题#2] 太空飞行计划 [网络流,最小割]
建图:源点—(w[i])—>实验—(∞)—>仪器—(cost[i])—>汇点, 如果该实验造成收益,则仪器到汇点的边在最小割中, 如果该实验造成损失,则源点到实验的边在最小割中, 故 ...
- N天学习一个Linux命令之ln
前言有时候同一个文件想创建多个别名,这个时候可以使用链接文件代替 用途对文件或者目录创建链接,默认创建的是硬链接 硬链接Linux底层文件系统由超级数据块,目录树对象,inode索引节点对象,文件对象 ...
- Java:解决Servlet的UTF8编码问题
要让Servlet支持UTF8,需要在doGet或者doPost中添加如下一条语句: request.setCharacterEncoding("UTF-8");
- HDU 4508
祼的完全背包问题 #include <iostream> #include <cstdio> #include <cstring> #include <alg ...
- OC基础回想(十二)协议
在OC基础(十一)中我们讨论了类别和非正式协议的奇异之处.在使用非正式协议时.能够仅仅实现你想要获得响应的方法.也不必在对象中声明不论什么内容来表示该对象可用作托付对象. 全部这些任务能够用最少的代码 ...
- UI设计--->全心全意为人民服务的宗旨---->注重客户体验--->软件持久的生命力
UI即User Interface(用户界面)的简称. UI设计是指对软件的人机交互.操作逻辑.界面美观的总体设计. 好的UI设计不仅是让软件变得有个性有品味,还要让软件的操作变得舒适简单.自由.充分 ...
- ambarella H2 添加文件到ext4文件系统
方法1: ambarella/rootfs目录下有skeleton(骨架)目录,此目录下就是文件系统的各个目录, [root@jz4775dev]# ls skeleton/ bin debug de ...
- oc32--构造方法1
// // Person.h #import <Foundation/Foundation.h> @interface Person : NSObject @property int ag ...