http://blog.csdn.net/gisshixisheng/article/details/40540601

距离和面积的测量时GIS常见的功能,在本节,讲述的是通过GeometryService实现测量面积和距离。先看看实现后的效果:

                                

距离                                                                                         面积

首先,进行配置:

  1. //identify proxy page to use if the toJson payload to the geometry service is greater than 2000 characters.
  2. //If this null or not available the project and lengths operation will not work.  Otherwise it will do a http post to the proxy.
  3. esriConfig.defaults.io.proxyUrl = "/proxy";
  4. esriConfig.defaults.io.alwaysUseProxy = false;

接着,定义GeometryService和绘图工具:

  1. var gsvc = new GeometryService("http://localhost:6080/arcgis/rest/services/Utilities/Geometry/GeometryServer");
  1. var measureToolbar = new esri.toolbars.Draw(map);

接下来,绘图结束后将所绘制图形添加到地图上面,并返回测量结果,那么增加measureToolbar的draw-end事件:

  1. measureToolbar.on("draw-end",showMeasureResults);
  2. /**
  3. * 显示测量结果
  4. * @param evt
  5. */
  6. var showPt=null;
  7. function showMeasureResults(evt){
  8. measureToolbar.deactivate();
  9. map.setMapCursor("default");
  10. var geometry = evt.geometry;
  11. switch (geometry.type) {
  12. case "polyline":{
  13. var length = geometry.paths[0].length;
  14. showPt = new Point(geometry.paths[0][length-1],map.spatialReference);
  15. var lengthParams = new LengthsParameters();
  16. lengthParams.lengthUnit = esri.tasks.GeometryService.UNIT_KILOMETER;
  17. lengthParams.polylines = [geometry];
  18. gsvc.lengths(lengthParams);
  19. break;
  20. }
  21. case "polygon":{
  22. showPt = new Point(geometry.rings[0][0],map.spatialReference);
  23. var areasAndLengthParams = new AreasAndLengthsParameters();
  24. areasAndLengthParams.lengthUnit = esri.tasks.GeometryService.UNIT_KILOMETER;
  25. areasAndLengthParams.areaUnit = esri.tasks.GeometryService.UNIT_SQUARE_KILOMETERS;
  26. gsvc.simplify([geometry], function(simplifiedGeometries) {
  27. areasAndLengthParams.polygons = simplifiedGeometries;
  28. gsvc.areasAndLengths(areasAndLengthParams);
  29. });
  30. break;
  31. }
  32. }
  33. var graphic = new Graphic(geometry, getGeometrySymbol(geometry.type));
  34. map.graphics.add(graphic);
  35. }

根据geometry的类型,增加GeometryService的lengths-complete或者areas-and-lengths-complete事件:

  1. gsvc.on("lengths-complete",outputLength);
  2. function outputLength(evtObj){
  3. var result = evtObj.result;
  4. showmeasureInfo(showPt, result.lengths[0].toFixed(3), "千米");
  5. };
  6. gsvc.on("areas-and-lengths-complete",outputAreaAndLength);
  7. function outputAreaAndLength(evtObj){
  8. var result = evtObj.result;
  9. showmeasureInfo(showPt, result.areas[0].toFixed(3), "平方千米");
  10. };

最后,将返回的结果显示在地图上:

  1. /**
  2. * 显示测量结果
  3. * @param showPnt
  4. * @param data
  5. * @param unit
  6. */
  7. function measureInfo(showPnt,data,unit){
  8. var measureDiv=$("#measure");
  9. var isShow = false;
  10. var screenPnt=map.toScreen(showPnt);
  11. measureDiv.css("left",screenPnt.x+"px");
  12. measureDiv.css("top",screenPnt.y+"px");
  13. measureDiv.css("position","absolute");
  14. measureDiv.css("height","20px");
  15. measureDiv.css("display","block");
  16. isShow = true;
  17. measureDiv.css("z-index","999");
  18. if(unit==="千米"){
  19. measureDiv.css("width","90px");
  20. }
  21. else{
  22. measureDiv.css("width","130px");
  23. }
  24. $("#result").html(data+unit);
  25. $("#infoclose").click(function(){
  26. map.graphics.clear();
  27. measureDiv.css("display","none");
  28. isShow = false;
  29. });
  30. map.on("pan-start", function(){
  31. measureDiv.css("display","none");
  32. });
  33. map.on("pan-end", function(panend){
  34. if(isShow == true){
  35. screenPnt=map.toScreen(showPnt);
  36. measureDiv.css("left",screenPnt.x+"px");
  37. measureDiv.css("top",screenPnt.y+"px");
  38. measureDiv.css("position","absolute");
  39. measureDiv.css("height","20px");
  40. measureDiv.css("display","block");
  41. }
  42. });
  43. map.on("zoom-start", function(){
  44. measureDiv.css("display","none");
  45. });
  46. map.on("zoom-end", function(){
  47. if(isShow == true){
  48. screenPnt=map.toScreen(showPnt);
  49. measureDiv.css("left",screenPnt.x+"px");
  50. measureDiv.css("top",screenPnt.y+"px");
  51. measureDiv.css("position","absolute");
  52. measureDiv.css("height","20px");
  53. measureDiv.css("display","block");
  54. }
  55. });
  56. };

结果的显示我是通过一个div来显示的,并且做了缩放和地图移动的处理。

(转)Arcgis for Js之GeometryService实现测量距离和面积的更多相关文章

  1. Arcgis for Js之GeometryService实现测量距离和面积

    距离和面积的测量时GIS常见的功能,在本节,讲述的是通过GeometryService实现测量面积和距离.先看看实现后的效果:                                  距离 ...

  2. ArcGIS Runtime SDK for WPF之测量距离和面积

    bu不多说,上代码 using System.Windows; using ESRI.ArcGIS.Client; using ESRI.ArcGIS.Client.Tasks; using ESRI ...

  3. OpenLayers测量距离和面积

    <!DOCTYPE html> <html> <head> <title>测量距离和面积</title> <meta http-equ ...

  4. Arcgis for Js之GeometryService实现測量距离和面积

    距离和面积的測量时GIS常见的功能.在本节,讲述的是通过GeometryService实现測量面积和距离.先看看实现后的效果: watermark/2/text/aHR0cDovL2Jsb2cuY3N ...

  5. OpenLayers动态测量距离和面积,并可自定义测量的线样式

    全局操作变量 /** * @description 标注弹出框 */ HtmlPopup = null; /** * @description 临时图层类数据源 */ VectorSource = n ...

  6. CAD图在线Web测量工具代码实现(测量距离、面积、角度等)

    CAD如今在各个领域均得到了普遍的应用并大大提高了工程技术人员的工作效率.在桌面端,AutoCAD测量工具已经非常强大:然后在Web端,如何准确.快速的对CAD图在Web进行测量呢? 功能 能Web在 ...

  7. (转)Arcgis for JS之对象捕捉

    http://blog.csdn.net/gisshixisheng/article/details/44098615 在web操作,如绘制或者测量的时候,为了精确,需要捕捉到某一图层的对象,在此,讲 ...

  8. Arcgis for JS之Cluster聚类分析的实现(基于区域范围的)

    原文:Arcgis for JS之Cluster聚类分析的实现(基于区域范围的) 咱们书接上文,在上文,实现了基于距离的空间聚类的算法实现,在本文,将继续介绍空间聚类之基于区域范围的实现方式,好了,闲 ...

  9. Arcgis for JS之Cluster聚类分析的实现

    原文:Arcgis for JS之Cluster聚类分析的实现 在做项目的时候,碰见了这样一个问题:给地图上标注点对象,数据是从数据库来 的,包含XY坐标信息的,通过graphic和graphicla ...

随机推荐

  1. Sencha Touch 2.1 Chart属性中文解释

    图表的几大要素: 1.坐标:上.下.左.右. 坐标的类型,数字.分类... 坐标包含需要显示的坐标值,即绑定的字段 坐标值的样式,比如旋转.字体大小.格式 坐标的最大值.最小值.是否显示网格 坐标旁边 ...

  2. Sunnypig闯三角关

    背景 贪玩的sunnypig请Charles为他打造一个奇幻世界,Charles欣然答应了.然而一向善于出难题的Charles是决不会轻易让sunnypig轻松拥有一个奇幻世界的,于是Charles在 ...

  3. [转]十五天精通WCF——终结篇 那些你需要注意的坑

    终于一路走来,到了本系列的最后一篇了,这一篇也没什么好说的,整体知识框架已经在前面的系列文章中讲完了,wcf的配置众多,如果 不加一些指定配置,你可能会遇到一些灾难性的后果,快来一睹为快吧. 一: 第 ...

  4. HDU 4540

    简单得不能再简单的DP了. #include<iostream> const int inf=1<<30; using namespace std; int map[22][2 ...

  5. HDU 4514

    真是神奇,G++TLE,C++500MS... 判环有一个图论知识就是,m>=n时必有环.如果以m的范围建图,会MLE. 然后,利用拓扑排序再来判定是否有环,因为有些景点可能是孤立的.同时,在拓 ...

  6. 虚拟机 开发板 PC机 三者之间不能ping通的各种原因分析

    这个问题事实上也相对照较简单.可是非常多网友都给我发消息说 遇到不能ping,每一个人都得回答一次确实显得心有余而力不足.如今我对遇到这几种问题给出最完整的解决方式. (说实话基本上也仅仅要这几种可能 ...

  7. Linux:命令gedit

    首先,gedit是一个GNOME桌面环境下兼容UTF-8的文本编辑器.它使用GTK+编写而成,因此它十分的简单易用,有良好的语法高亮,对中文支持很好,支持包括gb2312.gbk在内的多种字符编码. ...

  8. 没有终结点在侦听可以接受消息的 http://192.168.1.63:8085/LoginService。这通常是由于不正确的地址或者 SOAP 操作导致的

    2016-04-08 09:15:05,581 [8] ERROR System.Threading.Thread - ErrorSystem.ServiceModel.EndpointNotFoun ...

  9. bzoj 4198 [ Noi 2015 ] 荷马史诗 —— 哈夫曼编码(k叉哈夫曼树)

    题目:https://www.lydsy.com/JudgeOnline/problem.php?id=4198 第一次写哈夫曼树!看了很多博客. 哈夫曼树 & 哈夫曼编码:https://w ...

  10. LBS(定位)的使用

    一.LBS(定位)的使用 1.使用框架Core Location 2.CLLocationManager (1)CoreLocation中使用CLLocationManager对象来做用户定位 (2) ...