(三)ArcGIS API For Javascript之调用动态地图服务
文章目录
- 1.引言
- 2.调用动态地图服务
- 3.需求
- 3.1.根据需求隐藏服务中的某一个图层
- 3.1.1代码解释:
- 3.2.通过属性查询地图服务中的信息
- 3.2.1.代码实现
- 3.2.2代码解释
- 3.3通过空间查询地图服务中的信息
- 3.3.1代码实现
- 3.3.2代码解释
- 3.4补充
- 4.数据下载地址
1.引言
在本篇博客中主要记录一下在ArcGIS API如何调用自己发布的动态地图服务,利用动态地图服务我们可以完成哪一些需求等等。
注:(如何利用ArcGIS Server发布动态地图服务请看博客ArcGIS Server发布动态地图服务),
2.调用动态地图服务
在ArcGIS API 中给我们提供了一个类叫做ArcGISDynamicMapServiceLayer
利用这个类,我们可以获得发布的地图服务。调用动态地图服务一般只需要两步:
- 通过地图服务的URL创建一个
ArcGISDynamicMapServiceLayer
对象 - 将动态地图服务的对象添加到地图容器中
代码如下:
<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><title>Hello World</title><link rel="stylesheet" type="text/css" href="http://localhost/arcgis_js_api/library/3.17/3.17/dijit/themes/tundra/tundra.css"/><link rel="stylesheet" type="text/css" href="http://localhost/arcgis_js_api/library/3.17/3.17/esri/css/esri.css" /><script type="text/javascript" src="http://localhost/arcgis_js_api/library/3.17/3.17/init.js"></script><script>require(["esri/map","esri/layers/ArcGISDynamicMapServiceLayer","dojo/domReady!"],function(Map,ArcGISDynamicMapServiceLayer){var map = new Map("mapDiv");//利用url创建一个动态地图服务对象var layer=new ArcGISDynamicMapServiceLayer("http://localhost:6080/arcgis/rest/services/Test/MyServer/MapServer");//将地图服务对象添加到地图容器中map.addLayer(layer);})</script>
</head>
<body class="tundra">
<div id="mapDiv" style="width:900px; height:600px; border:1px solid #000;"></div>
</body>
</html>
点击运行,运行之后如图所示:
注:
- 在ArcGIS API中与ArcMap不同的是:一个服务图层相当于一组图层的集合(即多个图层)。
3.需求
在真实开发过程中,动态地图服务可以帮助我们完成很多的功能需求,例如:
- 根据需求隐藏服务中的某一个图层(动态地图服务可以实现,但是切片地图服务就不能实现)
- 通过属性查询地图服务中的信息
- 通过空间查询地图服务中的信息(包括点查询,线查询,面查询等等)
3.1.根据需求隐藏服务中的某一个图层
我们发布的地图服务中有四个图层
在本需求中。我们主要是给页面添加一个按钮,然后将地图服务中的road2隐藏
代码为:
require(["esri/map","dojo/dom","dojo/on","esri/layers/ArcGISDynamicMapServiceLayer","dojo/domReady!"],function(Map,dom,on,ArcGISDynamicMapServiceLayer){var map = new Map("mapDiv");var layer=new ArcGISDynamicMapServiceLayer("http://localhost:6080/arcgis/rest/services/Test/MyServer/MapServer");map.addLayer(layer);//给id为btn的按钮绑定click事件on(dom.byId("btn"),"click",function(){layer.setVisibleLayers([1,2,3]);})})
3.1.1代码解释:
- 此代码功能的实现非常简单,只利用了
setVisibleLayers
方法,告诉服务,我要显示图层编号为1,2,3
的图层。 - 在
require
中加载了一个新的模块dojo/dom
模块,此模块给我们提供了一个方法dom.byId(id)
,我们可以通过id获得dom对象,类似于document.getElementById()
方法。 - 在
require
中加载了一个新的模块dojo/on
模块,在dojo中on
是用来绑定事件的,on(target,type,listener)
的第一个参数是给哪一个对象绑定事件,第二个参数是事件的类型,第三个是参数是回调函数。
3.2.通过属性查询地图服务中的信息
在开发过程中,经常有这样的需求:
- 根据属性查询出我们想要的要素图形,然后将该图形高亮(在本事例中查询教学楼的信息,例如根据教学楼的名称将该楼层成高亮)
教学楼图层的属性表信息:
在实现这个功能的时候我们分几步开始考虑:
- 在网页上新建一个文本框
- 将文本框中的教学楼名称获取,并创建属性查询对象
- 将查询到的楼层信息(几何信息)获取,利用
graphics
高亮显示
3.2.1.代码实现
- 创建一个文本框
Name:<input class="nm" type="text">
<input type="button" value="查询">
- 将文本框中的教学楼名称获取,并创建属性查询对象
query("#btn").on("click",function(){//获得教学楼的名称var name=query(".nm")[0].value;//实例化查询参数var findParams = new esri.tasks.FindParameters();findParams.returnGeometry = true;findParams.layerIds = [3];findParams.searchFields = ["name"];findParams.searchText = name;//实例化查询对象var FindTask = new esri.tasks.FindTask("http://localhost:6080/arcgis/rest/services/Test/MyServer/MapServer");//进行查询FindTask.execute(findParams,ShowFindResult)})
- 将查询到的楼层信息(几何信息)获取,利用
graphics
高亮显示
function showFindResult(queryResult){if (queryResult.length == 0) {alert("没有该元素");return;}for (var i = 0; i < queryResult.length; i++) {//获得该图形的形状var graphic = queryResult[i].feature;var geometry = graphic.geometry;//定义高亮图形的符号//1.定义面的边界线符号var outline= new SimpleLineSymbol(SimpleLineSymbol.STYLE_DASHDOT,new Color([255, 0, 0]), 1);//2.定义面符号var PolygonSymbol = new SimpleFillSymbol(SimpleFillSymbol.STYLE_SOLID, outline,new Color([0, 255, 0, 1]));//创建客户端图形var graphic = new Graphic(geometry, PolygonSymbol);//将客户端图形添加到map中map.graphics.add(graphic);}}
- 查看结果
属性查询前:
属性查询后:
完整代码:
<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><title>Hello World</title><link rel="stylesheet" type="text/css" href="http://localhost/arcgis_js_api/library/3.17/3.17/dijit/themes/tundra/tundra.css"/><link rel="stylesheet" type="text/css" href="http://localhost/arcgis_js_api/library/3.17/3.17/esri/css/esri.css" /><script type="text/javascript" src="http://localhost/arcgis_js_api/library/3.17/3.17/init.js"></script><script>require(["esri/map","dojo/query","dojo/on","esri/layers/ArcGISDynamicMapServiceLayer","esri/tasks/FindTask","esri/tasks/FindParameters","esri/symbols/SimpleLineSymbol","esri/symbols/SimpleFillSymbol","esri/Color","esri/graphic","dojo/domReady!"],function(Map,query,on,ArcGISDynamicMapServiceLayer,FindTask,FindParameters,SimpleLineSymbol,SimpleFillSymbol,Color,Graphic){var map = new Map("mapDiv");var layer=new ArcGISDynamicMapServiceLayer("http://localhost:6080/arcgis/rest/services/Test/MyServer/MapServer");map.addLayer(layer);query("#btn").on("click",function(){//获得教学楼的名称var name=query(".nm")[0].value;//实例化查询参数var findParams = new FindParameters();findParams.returnGeometry = true;findParams.layerIds = [3];findParams.searchFields = ["name"];findParams.searchText = name;//实例化查询对象var findTask = new FindTask("http://localhost:6080/arcgis/rest/services/Test/MyServer/MapServer");//进行查询findTask.execute(findParams,showFindResult)});function showFindResult(queryResult){if (queryResult.length == 0) {alert("没有该元素");return;}for (var i = 0; i < queryResult.length; i++) {//获得该图形的形状var feature= queryResult[i].feature;var geometry = feature.geometry;//定义高亮图形的符号//1.定义面的边界线符号var outline= new SimpleLineSymbol(SimpleLineSymbol.STYLE_DASHDOT,new Color([255, 0, 0]), 1);//2.定义面符号var PolygonSymbol = new SimpleFillSymbol(SimpleFillSymbol.STYLE_SOLID, outline,new Color([0, 255, 0, 1]));//创建客户端图形var graphic = new Graphic(geometry, PolygonSymbol);//将客户端图形添加到map中map.graphics.add(graphic);}}})</script>
</head>
<body class="tundra">
<div id="mapDiv" style="width:900px; height:580px; border:1px solid #000;"></div>Name:<input class="nm" type="text"><input id="btn" type="button" value="查询">
</body>
</html>
3.2.2代码解释
FindTask
是Esri提供的一个属性查询的类,他所对应的参数为:FindParameters
,FindTask
只能用于属性查询,不能用于空间查询FindTask
类中有一个方法叫做execute
,execute
的第一个参数是属性查询的参数,第二个参数是一个回调函数(即是一个异步函数),当服务器返回数据时,此函数才会被触发。dojo/query
是dojo
提供的一个DOM选择器,他的功能非常强大,与JQuery
中的$
符一样强大,可以根据id选择query("#id")
,也可以根据类名选择query(".classname")
,query
方法还有很多强大的地方,具体可以参考官方文档query("#btn").on()
是dojo提供给我们第二种绑定事件的方式。graphic
esri提供给我们使用的客户端图层,利用graphic
,我们可以完成很多操作,graphic
具体的使用,将在Draw
工具时说明。
3.3通过空间查询地图服务中的信息
相信大家都遇到过这种问题,当我点击地图时,将我点击的图形进行高亮显示,此时就用到了空间查询。为了实现该功能我们可以分为以下几步:
- 因为要点击地图,所以首先我们给地图绑定点击事件
- 获得点击的地图坐标(点坐标),并创建空间查询参数对象
- 将教学楼与点相交的楼层查询出来,然后利用
graphic
进行高亮显示
注:此事例查询是教学楼图层
3.3.1代码实现
- 给地图绑定点击事件
map.on("click",mapClick);
- 获得点击的地图坐标(点坐标),并创建空间查询参数对象
function mapClick(e){//获得用户点击的地图坐标var point=e.mapPoint;//实例化查询参数query=new Query();query.geometry = point;query.outFields = ["*"];query.outSpatialReference = map.spatialReference;query.spatialRelationship = Query.SPATIAL_REL_INTERSECTS;query.returnGeometry = true;//实例化查询对象var queryTask = new QueryTask("http://localhost:6080/arcgis/rest/services/Test/MyServer/MapServer/3");//进行查询queryTask.execute(query,showFindResult)}
- 将教学楼与点相交的楼层查询出来,然后利用
graphic
进行高亮显示
function showFindResult(queryResult){if (queryResult.features == 0) {alert("没有该元素");return;}for (var i = 0; i < queryResult.features.length; i++) {//获得该图形的形状var feature = queryResult.features[i];var geometry = feature.geometry;//定义高亮图形的符号//1.定义面的边界线符号var outline= new SimpleLineSymbol(SimpleLineSymbol.STYLE_DASHDOT,new Color([255, 0, 0]), 1);//2.定义面符号var PolygonSymbol = new SimpleFillSymbol(SimpleFillSymbol.STYLE_SOLID, outline,new Color([0, 255, 0, 1]));//创建客户端图形var graphic = new Graphic(geometry, PolygonSymbol);//将客户端图形添加到map中map.graphics.add(graphic);}}
- 查看结果
鼠标点击前:
鼠标点击后:
- 完整代码
<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><title>Hello World</title><link rel="stylesheet" type="text/css" href="http://localhost/arcgis_js_api/library/3.17/3.17/dijit/themes/tundra/tundra.css"/><link rel="stylesheet" type="text/css" href="http://localhost/arcgis_js_api/library/3.17/3.17/esri/css/esri.css" /><script type="text/javascript" src="http://localhost/arcgis_js_api/library/3.17/3.17/init.js"></script><script>require(["esri/map","dojo/query","dojo/on","esri/layers/ArcGISDynamicMapServiceLayer","esri/tasks/QueryTask","esri/tasks/query","esri/symbols/SimpleLineSymbol","esri/symbols/SimpleFillSymbol","esri/Color","esri/graphic","dojo/domReady!"],function(Map,query,on,ArcGISDynamicMapServiceLayer,QueryTask,Query,SimpleLineSymbol,SimpleFillSymbol,Color,Graphic){var map = new Map("mapDiv");var layer=new ArcGISDynamicMapServiceLayer("http://localhost:6080/arcgis/rest/services/Test/MyServer/MapServer");map.addLayer(layer);map.on("click",mapClick);function mapClick(e){//获得用户点击的地图坐标var point=e.mapPoint;//实例化查询参数query=new Query();query.geometry = point;query.outFields = ["*"];query.outSpatialReference = map.spatialReference;query.spatialRelationship = Query.SPATIAL_REL_INTERSECTS;query.returnGeometry = true;//实例化查询对象var queryTask = new QueryTask("http://localhost:6080/arcgis/rest/services/Test/MyServer/MapServer/3");//进行查询queryTask.execute(query,showFindResult)}function showFindResult(queryResult){if (queryResult.features == 0) {alert("没有该元素");return;}for (var i = 0; i < queryResult.features.length; i++) {//获得该图形的形状var feature = queryResult.features[i];var geometry = feature.geometry;//定义高亮图形的符号//1.定义面的边界线符号var outline= new SimpleLineSymbol(SimpleLineSymbol.STYLE_DASHDOT,new Color([255, 0, 0]), 1);//2.定义面符号var PolygonSymbol = new SimpleFillSymbol(SimpleFillSymbol.STYLE_SOLID, outline,new Color([0, 255, 0, 1]));//创建客户端图形var graphic = new Graphic(geometry, PolygonSymbol);//将客户端图形添加到map中map.graphics.add(graphic);}}})</script>
</head>
<body class="tundra">
<div id="mapDiv" style="width:900px; height:580px; border:1px solid #000;"></div>
</body>
</html>
3.3.2代码解释
QueryTask
是esri提供给我们的一个工具类,可用于属性查询,也可用于空间查询,QueryTask
只能作用于地图服务的某一个图层,而不能作用于一整个地图服务(IdentifyTask
类可作用于一整个地图服务)Query
类是QueryTask
参数类,用于设定空间查询的参数。QueryTask
类中有一个方法叫做execute
,execute
的第一个参数是查询的参数,第二个参数是一个回调函数(即是一个异步函数),当服务器返回数据时,此函数才会被触发
3.4补充
绑定事件之后,在某些情况下也解除事件的绑定,下面提供几种方法解除事件绑定
- 直接通过事件句柄解除(dojo新版本)
//绑定事件
var handle=map.on("click",mapClick);
//解除事件
handle.remove();
- 通过老版本的方法解除
//绑定事件
var handle=map.on("click",mapClick);
//解除事件
dojo.disconnect(handle)
4.数据下载地址
- GitHub的数据及代码下载地址为:GitHub的数据及代码下载链接(如果从GitHub下载代码,麻烦给小
Demo
一个Star
,您的支持是我最大的动力)
(三)ArcGIS API For Javascript之调用动态地图服务相关推荐
- ArcGIS API For Javascript之调用动态地图服务+属性、空间查询
引言 调用动态地图服务 需求 1根据需求隐藏服务中的某一个图层 11代码解释 2通过属性查询地图服务中的信息 21代码实现 22代码解释 3通过空间查询地图服务中的信息 31代码实现 32代码解释 4 ...
- arcgis pro发布矢量切片服务及利用arcgis api for javascript进行调用
该文章已迁移至微信公众号,地址见: https://mp.weixin.qq.com/s/IDhD0JctuZUgOLMOJIoYew
- ArcGIS API For JavaScript学习笔记
之前学习ArcGIS API For JavaScript的一些记录,有些是转载的,不过转载的自己有重新做过一遍,这里做个总结,方便后面来学习回顾. 1.ArcGIS API For JavaScri ...
- ArcGIS API for JavaScript——地图展示
ArcGIS API for JavaScript 能够实现的最基本功能就是地图展示,包括地图缩放.平移.定位.实时显示坐标.展示地图要素(指北针.比例尺.图例).切换地图等.本文将详细介绍地图展示的 ...
- 视频教程-主流前端框架下ArcGIS API for JavaScript的开发-其他
主流前端框架下ArcGIS API for JavaScript的开发 毕业于中国矿业大学地理信息科学专业.现就任于全球领先的GIS公司,主要担任地理平台研发工作,日常工作任务是ArcGIS JS A ...
- ArcGis API for JavaScript学习——加载地图
ArcGis API for JavaScript开发笔记--加载地图 在这个例子中使用的离线部署的API(请参见 http://note.youdao.com/noteshare?id=f42865 ...
- 缓冲区分析—ArcGIS API for JavaScript
缓冲区分析是地理信息系统中的空间分析基本功能之一,是众多空间分析方法的基础.缓冲区分析是指为了识别某地理实体或空间物体对其周围的邻近性或影响度而在其周围建立的一定宽度的带状区. 缓冲区介绍 缓冲区分析 ...
- ArcGIS API for JavaScript之基础篇(二)
ArcGIS API for JavaScript之基础篇(二) 上一篇文章介绍了Map MapView SceneView的基本知识以及简单的demo.最近几天学习了WebMap WebScene ...
- 地理信息系统(GIS)系列——ArcGIS API for JavaScript 3.9(1)
Visual Studio 智能提示配置:将以下 JavaScript 文件引入项目中 arcgis_js_v39_sdk\arcgis_js_api\sdk\jshelp\jsapi_vsdoc12 ...
最新文章
- 剑指offer_第10题_矩形覆盖
- Django生命周期
- git reset --hard 恢复
- Visual Studio 2005中文版
- JS正则表达式验证数字非常全
- 怎么tp玩家_DNF:被误制裁玩家痛苦下跪,求TP为其复查:我只是在家搬个砖!...
- cartographer探秘之文章索引
- WSO2 ESB 5.0.0 的一些控制台显示配置
- 【阿里巴巴Java编程规范学习 二】Java基本编程规约(下)
- 不要重新发明轮子_重新发明轮子
- ram与flash你知道多少?
- 解决ffmpeg合成的视频格式浏览器无法播放问题
- 橡胶密封圈的作用和优点
- 理海大学计算机专业好申吗,美国留学选工科就来了解一下理海大学~
- java实现头像上传 前后端
- unknown类型的使用
- 护肤品买了这么多还是不见好转,钱都去哪里了?
- 特征值分解与奇异值分解原理与计算
- Linux I2C驱动框架(超详细)
- Synopsys Sentaurus TCAD系列教程之-- Svisual《一》看图工具
热门文章
- 【java学习】String字符串
- 【HDU】1862 EXCEL排序(结构体排序)
- 天线工程手册_相控阵天线方向图第3部分:旁瓣和锥削
- JS判断选择的时间是否大于当前时间
- 京东区块链(智臻链):1. 应用场景
- Python-docx生成word文档
- C++时间日期的处理ctime
- 91sp.vido.ws index.php_Vidows
- 解决Attribute 'transaction-manager' is not allowed to appear
- 系统集成项目管理|十大管理