ArcGIS API ForJS 3.25开发总结(持续更新)

一、关于Graphic

首先看张图:

这是整个Graphic涉及的一些类,上图中的可以进行客户端点、线、面的表示。在服务器端的进行修改时applyEdits函数传入的也是graphic,drawToolbar绘图类也涉及到graphic,总而言之,graphic可以视为一个要素元素,感觉更应该称之为图形

二、关于esriLang类的substitute(data, template?, first?)方法

返回一个字符串,data是数据,template是中占位符模板

1、模板的写法

HTML写法

              var t = "<b>${NAME}</b><hr><b>2000 人口数量: </b>${POP2000:NumberFormat}<br>"
            + "<b>2000 人口密度: </b>${POP00_SQMI:NumberFormat}<br>"
            + "<b>2007 人口密度:</b>${POP2007:NumberFormat}<br>"
            + "<b>2007 人口密度: </b>${POP07_SQMI:NumberFormat}";
              //attributes中的字段进行替换
              var content = esriLang.substitute(evt.graphic.attributes, t);

 该方法一般与infoTemplate类一块用

三、关于FeatureLayer加载服务

1、发布的要素服务无          

2、地图服务的单个图层

四、关于TiledMapServiceLayer的子类

1、ArcGISTiledMapServiceLayer:用于访问ArcGIS Server发布的地图切片服务

2、VETiledLayer:用于访问微软的Bing地图,但是其        命名空间在3.25不在layer图层下,在"esri/virtualearth/VETiledLayer"

3、OpenStreetMapLayer:用于访问开放街道地图(OSM)

4、WMTSLayer:用于访问OGC标准的WMTS服务

5、WebTiledLayer:用于访问非ArcGIS Server发布的切片服务

五、esri/config模块

ArcGIS API For JS有一些默认的配置,例如漫游动画时间、缩放持续时间、缩放刷新速度等,都可以通过该模块进行控制。

使用示例:

                esriConfig.defaults.map.panDuration = 1000;
                esriConfig.defaults.map.panRate = 50;
                esriConfig.defaults.map.zoomDuration = 1000;
                esriConfig.defaults.map.zoomRate = 50;

六、关于地图的配置(写成一个对象)

好处:开发人员容易配置,代码不乱,更改服务更容易。

示例:

/* --------------------------------地图初始信息配置-------------------------------- */
function MapConfig() { }
MapConfig.mapInitParams = {
    fullExtent: {//全图范围
        xmin: 121.29585473952106,
        ymin: 39.49550677343447,
        xmax: 123.05162192862765,
        ymax: 139.982938778863684
    },
    extent: {//初始化范围
        xmin: 120.8696333,
        ymin: 38.65953686,
        xmax: 123.6199347,
        ymax: 40.202622
    },
    spatialReference: {//地图空间参考坐标系
        wkid: 4326
    },
    lods: [//针对瓦片的地图服务的,用来控制瓦片级别的显示,有时候切片级别太多的话,可以只显示部分的级别地图
           //resolution scale这些值的获取参照发布的切片地图服务详情
           { "level": 0, "resolution": 0.00118973050291514, "scale": 500000 },
           { "level": 1, "resolution": 5.9486525145757E-4, "scale": 250000 },
           { "level": 2, "resolution": 2.3794610058302802E-4, "scale": 100000 },
           { "level": 3, "resolution": 5.710706413992673E-5, "scale": 24000 },
           { "level": 4, "resolution": 2.3794610058302804E-5, "scale": 10000 }
    ]
}
/*地图调用*/
MapConfig.vecMapUrl = "http://localhost:6080/arcgis/r ... rcGIS动态服务
MapConfig.imgMapUrl = "http://localhost:6080/arcgis/r ... rcGIS切图服务

七、Dojo类的代码声明示例

define(["dojo/_base/declare"], function (declare) {
    return declare("aClass", null, {
        mynum: 10,       //声明一个变量(在这个类里是全局的)
        constructor: function (num) {  //这个是构造函数,声明类的实例时,传的参数在这里
            console.log(num);       //我们让声明实例时,输出他传的参数
        },
        add: function (num1) {    //类方法,调用类方法时,返回值是参数+10
            return this.mynum + num1;   //必须加this.mynum才能调用类内置的变量
        },
        getMynum: function () {    //返回类内部的变量
            return this.mynum;
        },
        mynumAdd:function(){
            this.mynum++;
            return this.mynum;
        }
    })
})

八、我们在要发布模型工具(插值、缓冲区、等值线、等值面等等)之前,为什么会要把输入要素类型改成输入要素类?

当我们使用查询、地理处理和路径分析的时候我们常常将FeatureSet输入和输出参数。

FeatureSet:是要素类的轻量级的表示,相当于地理数据库的一个要素类,是Feature(要素)的集合,FeatureSet的每个Feature可能包含Geometry、符号、属性、和一个InfoTemplate。如果FeatureSet不包含Geometry,只包含属性,那么FeatureSet可以看作一个表,其中每个Feature是一个行对象。

九、两个修改要素方面的小部件

1、AttributeInspector

效果如上图,点击出现弹窗,进行要素的编辑修改,点我查看demo

2、FeatureTable

这个基本功能和上面差不多,点我查看demo

十、esri/config类

关于这个类主要设置地图的默认配置即defaults,defaults 又分为三个种类设置:

1、IO:这里面涉及一些跨域等方面的设置

2、map:这里面主要涉及一些地图状态参数设置

3、workers:AMD加载一些设置

4、kmlService:该参数默认为空,具体什么用还没看懂

5、geometryService:该参数对于一些分析类的东西虽然有时候我们无法发布我们的模型,但是我们可以用online上面的,非常方便的。

使用示例:

        esriConfig.defaults.map.panDuration = 1; // time in milliseconds, default panDuration: 350
        esriConfig.defaults.map.panRate = 1; // default panRate: 25
        esriConfig.defaults.map.zoomDuration = 100; // default zoomDuration: 500
        esriConfig.defaults.map.zoomRate = 1; // default zoomRate: 25
        esriConfig.defaults.geometryService = new GeometryService("https://utility.arcgisonline.com/ArcGIS/rest/services/Geometry/GeometryServer");

        esriConfig.defaults.io.proxyUrl = "/proxy/";
        esriConfig.defaults.io.alwaysUseProxy = false;

十一、未完待续。。。。。

 

posted @ 2018-07-25 17:10  HPUGIS  阅读(923)  评论(0编辑  收藏  举报