文档章节

arcgis for js API 4.4 MapImageLayer加载动态图层不出现问题

JaJaCube
 JaJaCube
发布于 2017/09/01 10:58
字数 552
阅读 27
收藏 1

小白首发撒花~

初转到arcgis js 4.4,码代码的过程中遇到如下问题:

设定好MapImageLayer及其sublayer之后运行程序,发现图层不能加载出来,报错及MapImageLayer设定代码如下:

 

MapImageLayer设定代码:

 var layer1 = new MapImageLayer({
                    title: "标题_区域绿地1",
                    url: "http://192.168.1.128:6080/arcgis/rest/services/智慧园林示例数据/全示例数据源_比对测试/MapServer",
                    sublayers: [

                        {
                            id: 1,
                            visible:true
                        }, {
                            id: 4,
                            visible: true
                        }, {
                            id: 7,
                            visible: true
                        }
                    ]
                });

报错图:

图上图例不显示

尝试了多种诸如URL修改localhost,清除arcgis server缓存,根据官网Sample加入renderer,修改各种变量名,折腾了一整天也没有解决,第二天上班后简单的对这部分代码进行了重构,意外的发现问题自己解决了,图层正常显示,图例出现,F12工具里也没有之前的大段报错了,神特喵当时以为重启解决的,不甘心,尝试复现,又折腾了一个小时后发现,MapImageLayer中的sublayer的加在顺序必须是id从大到小的顺序,乱序或者从小到大均不能加载出图层并且报之前的错。正确代码如下:

 

 var layer1 = new MapImageLayer({
                    title: "标题_区域绿地1",
                    url: "http://192.168.1.128:6080/arcgis/rest/services/智慧园林示例数据/全示例数据源_比对测试/MapServer",
                    sublayers: [

                        {
                            id: 7,
                            visible:true
                        }, {
                            id: 4,
                            visible: true
                        }, {
                            id: 1,
                            visible: true
                        }
                    ]
                });

神特喵必须降序id!!!!!

然而,最值得吐槽的是,这一切并没有在官网给出的API中说明,并且API官网给出的示例也是不能成功加载的(因为也是id升序排序),你必须把sublayer的id改为降序才能正确出图。

官网API:

费了一整天时间才摸清这个规律,最终问题解决,小白留爪。

图层和图例正确显示如下:

最后,小白初从flex转到js,在大牛@洋碱(附上大牛站内链接:https://my.oschina.net/u/615762  ,多去骚扰他,他脾气特别好~) 的指引下来到本站分享开发经验,望站内众位大佬多多指教,蟹蟹~

 

© 著作权归作者所有

共有 人打赏支持
JaJaCube
粉丝 3
博文 7
码字总数 3719
作品 0
合肥
加载中

评论(2)

JaJaCube
JaJaCube

引用来自“洋碱”的评论

重点不在问题,而在问题的解决办法,小伙子向你学习了
大牛带飞:smiling_imp:
洋碱
洋碱
重点不在问题,而在问题的解决办法,小伙子向你学习了
ArcGIS Maritime Server 开发教程(九)二三维水深服务

ArcGIS Maritime Server 开发教程(九)二三维水深服务 本章导读:ArcGIS 软件体系是使用 ArcGIS Bathymetry 桌面扩展构建和管理水深数据库,并且利用 Image Server 对水深产品进行发布。本章...

liyuanxiang1984
05/24
0
0
用Tomcat8.5做Arcgis API for javascript的本地部署

step1:1从arcgis官网上下载Arcgis api for JavaScript 4.3 https://developers.arcgis.com/javascript/latest/guide/release-notes/ ps:前提是你需要有一个esri开发者账户否则不能下载。 st......

duxiuxiu
2017/05/18
0
0
ArcGIS API for Javascript 2.X 离线部署(以2.6为例)

先在官网上ArcGIS API for JavaScript download page(需要有账户)下载最新的API:arcgisjsv26_api.zip( 点击直接下载)和 SDK: arcgisjsv26_sdk.zip(直接下载); 2. 将下载下来的 arcg...

回忆在昨天
2012/10/24
0
0
2017第十五届esri用户大会观感(二)——大会整体

上文初步介绍了大会的盛况以及笔者负责的Web App Builder for ArcGIS,本篇来讲讲大会整体观感。总体来说,我觉得本次大会的两大亮点可能不在产品技术本身。而是此次宣布的两大关于产品销售的...

胖胖雕
2017/10/31
0
0
ArcGIS API for JavaScript Remove powered by ESRI logo

ArcGIS API for JavaScript 3.x map = new esri.Map("map", { extent: initExtent, logo:false }); ArcGIS API for JavaScript 4.x var view = new MapView({ ... }); view.ui._removeCompon......

神勇小白鼠
04/23
0
0

没有更多内容

加载失败,请刷新页面

加载更多

00.编译OpenJDK-8u40的整个过程

前言 历经2天的折腾总算把OpenJDK给编译成功了,要说为啥搞这个,还得从面试说起,最近出去面试经常被问到JVM的相关东西,总感觉自己以前学的太浅薄,所以回来就打算深入学习,目标把《深入理...

凌晨一点
今天
2
0
python: 一些关于元组的碎碎念

初始化元组的时候,尤其是元组里面只有一个元素的时候,会出现一些很蛋疼的情况: def checkContentAndType(obj): print(obj) print(type(obj))if __name__=="__main__": tu...

Oh_really
昨天
6
2
jvm crash分析工具

介绍一款非常好用的jvm crash分析工具,当jvm挂掉时,会产生hs_err_pid.log。里面记录了jvm当时的运行状态以及错误信息,但是内容量比较庞大,不好分析。所以我们要借助工具来帮我们。 Cras...

xpbob
昨天
113
0
Qt编写自定义控件属性设计器

以前做.NET开发中,.NET直接就集成了属性设计器,VS不愧是宇宙第一IDE,你能够想到的都给你封装好了,用起来不要太爽!因为项目需要自从全面转Qt开发已经6年有余,在工业控制领域,有一些应用...

飞扬青云
昨天
4
0
我为什么用GO语言来做区块链?

Go语言现在常常被用来做去中心化系统(decentralised system)。其他类型的公司也都把Go用在产品的核心模块中,并且它在网站开发中也占据了一席之地。 我们在决定做Karachain的时候,考量(b...

HiBlock
昨天
2
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部