这里测量长度主要分为两个方面,一个是在绘制长折线段时,不仅需要显示总线段的长度,还要在各线段的中间显示各折线段的长度;另一个则是在绘制多边形时,不仅需要显示多边形的面积,还需要在各边的中间显示线段长。
前提:在每次绘制图形的时候,都要消除图层上已有的图形,那么则需要clear()图层。此处的clear()为地图的图像清除。如下:
     this.map.graphics.clear();// 清除了地图的图像,使其无法访问到GraphicsLayer
     this._refreshGraphics;
这里我所面对的问题有两个,因为菜单栏中包括有两个工具——线、面,因此在每次绘制之后需要再次更新图层。方法如下:
   _refreshGraphics: function () {
       // 此处需要将绘制的Layer设置和面积绘制的Layer相同,不然在长度测量完之后,打开面积测量时,绘制的面无法消除
      this._regionGraphics = this.map.getLayer('regionGraphics');
      if (this._regionGraphics) {
           this._regionGraphics.clear();
      } else {
          this._regionGraphics = new GraphicsLayer({id: 'regionGraphics'});
          this.map.addLayer(this._regionGraphics);
       }
   }
1、测量折线段的长度
情况一: 如果仅仅是计算某一个线段的话(不包括内部折线段的长度),那么是比较简单的可以直接利用ArcGIS API for JavaScript中提供的方法来做,如下:
postCreate: function(){
      this._lengthMeasure();
},
_lengthMeasure: function () {
     this.toolbar.activate(Draw.POLYLINE);
     this.drawEnd = this.toolbar.on("draw-end", lang.hitch(this, this._getLengthOrArea));
     this.geometryService = esriConfig.defaults.geometryService;
     this.geometryService.on("lengths-complete", lang.hitch(this, this.outputLength));
},
outputLength: function (evtObj) {
    var result = evtObj.result;
    //设置总长度样式
   var textSymbol = new TextSymbol("距离:" + result.lengths[0] + "米").setColor(
   // 需要将setAngle中的数值设为0,才能使Font水平显示
     new Color([255, 0, 0])).setAlign(Font.ALIGN_MIDDLE).setAngle(0).setFont(
     new Font("12pt").setWeight(Font.WEIGHT_BOLD));
     var graphic = new Graphic(new Point(this.drawResult.geometry.paths[0][0][0], this.drawResult.geometry.paths[0][0][1], this.drawResult.geometry.spatialReference), textSymbol);
     this.map.graphics.add(graphic);
},
_getLengthOrArea: function (result) {
    this.drawResult = result;
    var symbol;
    symbol = new SimpleLineSymbol(SimpleLineSymbol.STYLE_SOLID, new Color([0, 0, 0]), 2);
   //设置样式
   var graphic = new Graphic(result.geometry, symbol);
   this._regionGraphics.add(graphic);
   //this.map.graphics.add(graphic);
   //如果为线类型就进行lengths距离测算
    if (result.geometry.type == "polyline") {
         if(result.geometry.paths[0].length > 2) {
            var lengthParams = new LengthsParameters();
            lengthParams.polylines = [result.geometry];
            lengthParams.lengthUnit = GeometryService.UNIT_METER;
            lengthParams.geodesic = true;
           this.geometryService.lengths(lengthParams);
          }
    this.toolbar.deactivate();
}
这样既可通过ArcGIS API for JavaScript提供的方法计算出总的长度了。那么我在现实需求中则需要显示每条线段的值,具体做法如下:
postCreate: function(){
      this._lengthMeasure();
},
_lengthMeasure: function () {
    this.toolbar.activate(Draw.POLYLINE);
    this.drawEnd = this.toolbar.on("draw-end", lang.hitch(this, this._getLengthOrArea));
    this.geometryService = esriConfig.defaults.geometryService;
    // 这里需要改成map的click事件监听,并且不能出现lengths-complete,不然无法计算各线段的长度
    this.mapClickEvent = this.map.on('click', lang.hitch(this, this._mapClick));
},
_mapClick: function (object){
    this._arrMapPoints.push(object.mapPoint);
   if(this._arrMapPoints.length >= 2 ){ 
        var i = this._arrMapPoints.length-1;
       var polylineJson = {
      "paths":[[[this._arrMapPoints[i-1].x,this._arrMapPoints[i-1].y],[this._arrMapPoints[i].x,this._arrMapPoints[i].y]]],
      "spatialReference": distMap.spatialReference
     };
    var startX = this._arrMapPoints[i].x;
    var startY = this._arrMapPoints[i].y;
    var centerPoint = new Point(startX, startY , distMap.spatialReference);
    var polyline = new esri.geometry.Polyline(polylineJson);
   /*这里为调用的计算方法,因为不在一个js文件中,我会在最下面贴出来该方法,若不想拆开,可直接在下添加计算方法,这里的数组polyline就是传到下面的函数中的geometry*/
      geoServiceUtils.geometryLength(polyline).then(lang.hitch(this, function(data){
          this.outputPartLength(data, centerPoint);
      }))
   }
},
/**
* 各折线长度格式设置
* @private
*/
outputPartLength: function(result,centerPoint){
// 长度超过一千的,单位均显示为千米,且保留小数点后两位
     if(result.lengths[0] > 1000){
     var partLength = (result.lengths[0]/1000).toFixed(2);
     //设置各长度样式
     var textSymbol = new TextSymbol(partLength + '千米').setColor(
     // 需要将setAngle中的数值设为0,才能使Font水平显示
     new Color([0, 0, 255])).setAlign(Font.ALIGN_MIDDLE).setAngle(0).setFont(
     new Font('10pt').setWeight(Font.WEIGHT_BOLD));
     var graphic = new Graphic(centerPoint, textSymbol);
     this.map.graphics.add(graphic);
} else{
    // 长度不足一千米的,单位均显示为米,且保留小数点后两位
    var smallPartLength = result.lengths[0].toFixed(2);
   //设置各长度样式
   var textSymbol = new TextSymbol(smallPartLength + '米').setColor(
   // 需要将setAngle中的数值设为0,才能使Font水平显示
   new Color([0, 0, 255])).setAlign(Font.ALIGN_MIDDLE).setAngle(0).setFont(
   new Font('10pt').setWeight(Font.WEIGHT_BOLD));
   var graphic = new Graphic(centerPoint, textSymbol);
   this.map.graphics.add(graphic);
}
},
/**
* 总长度格式设置
* @private
*/
outputLength: function (result) {
    if(result.lengths[0] > 1000){
        var allLengrh = (result.lengths[0]/1000).toFixed(2);
        //设置总长度样式
        var textSymbol = new TextSymbol('总距离:' + allLengrh + '千米').setColor(
        // 需要将setAngle中的数值设为0,才能使Font水平显示
        new Color([255, 0, 0])).setAlign(Font.ALIGN_MIDDLE).setAngle(0).setFont(
        new Font('12pt').setWeight(Font.WEIGHT_BOLD));
        var graphic = new Graphic(new Point(this.drawResult.geometry.paths[0][0][0], this.drawResult.geometry.paths[0][0][1], this.drawResult.geometry.spatialReference), textSymbol);
      this.map.graphics.add(graphic);
     } else{
         var smallAllLength = result.lengths[0].toFixed(2);
         //设置总长度样式
          var textSymbol = new TextSymbol('总距离:' + smallAllLength + '米').setColor(
          // 需要将setAngle中的数值设为0,才能使Font水平显示
          new Color([255, 0, 0])).setAlign(Font.ALIGN_MIDDLE).setAngle(0).setFont(
          new Font('12pt').setWeight(Font.WEIGHT_BOLD));
           var graphic = new Graphic(new Point(this.drawResult.geometry.paths[0][0][0], this.drawResult.geometry.paths[0][0][1], this.drawResult.geometry.spatialReference),                    textSymbol);
      this.map.graphics.add(graphic);
     }
    //设置总长度样式

this.mapClickEvent.remove();
    this.drawEnd.remove();
},
/**
* 画图完毕后计算距离或者面积
* @param result 画图完毕返回的画图对象
* @private
*/
_getLengthOrArea: function (result) {
this.drawResult = result;
var symbol;
symbol = new SimpleLineSymbol(SimpleLineSymbol.STYLE_SOLID, new Color([0, 0, 0]), 2);
//设置样式
var graphic = new Graphic(result.geometry, symbol);
this._regionGraphics.add(graphic);
//进行总距离测算
if(result.geometry.type == 'polyline'){
geoServiceUtils.geometryLength(result.geometry).then(lang.hitch(this, function (data) {
this.outputLength(data);
}))
}
this.toolbar.deactivate();
},
/**
* 长度量测方法
* @param geometry
*/
mo.geometryLength = function (geometry) {
var geoService = esriConfig.defaults.geometryService;
var def = new Deferred();
// 计算总长度的值
if (geometry.paths[0].length > 2) {
var lengthParams = new LengthsParameters();
lengthParams.polylines = [geometry];
lengthParams.lengthUnit = GeometryService.UNIT_METER;
lengthParams.geodesic = true;
geoService.lengths(lengthParams, function (data) {
def.resolve(data);
}, function (err) {
def.reject(err);
});
} else {
// 计算各折线段的值
var lengthPartParams = new LengthsParameters();
lengthPartParams.polylines = [geometry];
lengthPartParams.lengthUnit = GeometryService.UNIT_METER;
lengthPartParams.geodesic = true;
geoService.lengths(lengthPartParams, function (data) {
def.resolve(data);
}, function (err) {
def.reject(err);
});
}
return def.promise;
}

至此,计算线段的长度以及计算一个线段各折线段的长度的方法已经得出,计算面的各线段长度和该方法一样,就不再赘述。

ArcGIS API for JS 测量线长(各折线段)的更多相关文章

  1. 在IIS服务器上本地部署 ArcGIS API for js 4.15

    作为一名刚入门的小白,还没开始一个helloworld就在软件安装,环境部署时遇到了一大堆问题,简直太让人头秃了,脑壳疼.话不多说,这篇主要想分享一下自己部署ArcGIS API for js 4.1 ...

  2. arcgis api for js入门开发系列四地图查询(含源代码)

    备注:由于实现本篇功能的需求,修改了地图数据的dlsearch.mxd,然后更新了地图服务,需要的在文章最后有提供最新的mxd以及源代码下载的 上一篇实现了demo的地图工具栏,本篇新增地图查询功能, ...

  3. arcgis api for js入门开发系列一arcgis api离线部署

    在我的GIS之家QQ群里,很多都是arcgis api for js开发的新手,他们一般都是GIS专业的学生,或者从计算机专业刚刚转向来的giser,他们难免会遇到各种webgis开发的简单问题,由于 ...

  4. arcgis api for js入门开发系列十一地图统计图

    上一篇实现了demo的叠加SHP图层,本篇新增地图统计图,截图如下: 地图统计图实现的思路如下:利用拓展arcgis api的js文件(MapChartGraphic.js以及MapChartGrap ...

  5. arcgis api for js入门开发系列二十打印地图的那些事

    前面我写过关于利用arcgis api for js打印地图的,但是打印地图服务都是基于arcgis server发布的,arcgis api加载在线地图,比如天地图.百度地图.高德地图等,底图都是打 ...

  6. 转:arcgis api for js入门开发系列四地图查询

    原文地址:arcgis api for js入门开发系列四地图查询 arcgis for js的地图查询方式,一般来说,总共有三种查询方式:FindTask.IdentifyTask.QueryTas ...

  7. Arcgis API for JS——打印控件乱码

    在通过Arcgis API for JS编写打印控件进行地图下载时,总发现地图字体乱码,如下图: 解决方法: 在装有ArcGIS Server,要调用服务的电脑或服务器上找到下图文件夹

  8. ArcGIS API for js Legend(图例)

    1.说明 有关怎么把ArcGIS API for js部署到IIS上,请参考我上面的写的博客https://www.cnblogs.com/net064/p/10302660.html 2.运行效果 ...

  9. arcgis api for js 地图查询

      arcgis api for js入门开发系列四地图查询(含源代码) 上一篇实现了demo的地图工具栏,本篇新增地图查询功能,包括属性查询和空间查询两大块,截图如下: 属性查询效果图: 空间查询效 ...

随机推荐

  1. 2_PY基本数据类型

    python的数据类型和R差不多,但是需要注意的是字符访问方式与R不一样,另外,python中的“真”和“假”是True False(首字母大写). 1.字符串 字符串和R的定义差不多比如: data ...

  2. React 组件间通信介绍

    React 组件间通信方式简介 React 组件间通信主要分为以下四种情况: 父组件向子组件通信 子组件向父组件通信 跨级组件之间通信 非嵌套组件间通信 下面对这四种情况分别进行介绍:   父组件向子 ...

  3. crontab(暂存待完善)

    crontab  -e 编辑 ,(使用默认编辑器) -l  列出 第1列分钟1-59 第2列小时1-23(0表示子夜) 第3列日1-31 第4列月1-12 第5列星期0-6(0表示星期天) 第6列要运 ...

  4. Networked Graphics: Building Networked Games and Virtual Environments (Anthony Steed / Manuel Fradinho Oliveira 著)

    PART I GROUNDWORK CHAPTER 1 Introduction CHAPTER 2 One on One (101) CHAPTER 3 Overview of the Intern ...

  5. Java 序列化 返序列化

    原文: http://www.cnblogs.com/xdp-gacl/p/3777987.html   一.序列化和反序列化的概念 把对象转换为字节序列的过程称为对象的序列化. 把字节序列恢复为对象 ...

  6. LeetCode - 13. 罗马数字转整数

    1 题目描述 罗马数字包含以下七种字符: I, V, X, L,C,D 和 M. 字符 数值 I V X L C D M 例如, 罗马数字 2 写做 II ,即为两个并列的 1.12 写做 XII , ...

  7. maven项目自动创建src/main/resources等四个资源文件夹

    如何使maven项目自动创建这四个文件夹:src/main/resources.src/main/java.src/test/java.src/test/resources 网传甚广的在Config ...

  8. C# 操作redis

    下载 redis windows 版本 官网目前没有windows安装下载,下载地址为 https://github.com/MicrosoftArchive/redis/releases 直接点击安 ...

  9. 微软 workflow 工作流总结

    1.状态机工作流 (1)状态机工作流从state1 流转到 state2 到stateN (2) state中有执行状态和退出状态 (3) 在进入下一个步骤(state1 到 state2)前,首先会 ...

  10. 禅知Pro 1.6 前台任意文件读取 | 代码审计

    禅知 Pro v1.6 前台任意文件读取 | 代码审计 蝉知专业版是基于蝉知企业门户系统开源版开发,继承了蝉知本身的优秀功能.相对于蝉知开源版增强了商品的属性自定义.属性价格定制.物流跟踪.微信支付. ...