如何在ArcGIS Online中构建自己的应用程序模板初级篇-显示地图

0
分享 2015-08-05
开发ArcGIS Online应用程序模板之前,需要了解怎么使用ArcGIS API for JavaScript
在ArcGIS Online当中如何构架自己的应用程序模板,我们得先要了解ArcGIS Online如何解析这个web地图的。
做过程序开发的,都清楚,每一个item都对应着数据库的一个id值。而ArcGIS Online这个Id名称是webmap。
这就简单了,我们有了这个webmap的值,然后查询数据库或其他文件就能得到这个webmap。
第一步,我们就需要进行对这个webmap参数值解析。
var queryString = function(key) {
return (document.location.search.match(new RegExp("(?:^\\?|&)"+key+"=(.*?)(?=&|$)"))||['',null])[1];
}
function init() {
var WEBMAP_ID = queryString("webmap")||"ceac2dfaea0449119724e8b78e99013a";//默认值
}
其实ArcGIS API for JavaScript有这么一个类似的函数。
function init() {
var urlObject = esri.urlToObject(document.location.href);
if(urlObject.query && typeof (urlObject.query.webmap) != "undefined") {
var WEBMAP_ID = urlObject.query.webmap;
} else {
var WEBMAP_ID = "ceac2dfaea0449119724e8b78e99013a"
}
}

第二步,有了webmap值,我们就可以根据这个ID值,就可以来创建我们的地图。需要注意一点,使用下面的方法,webmap最好对公众开放,否则还得需要进行登录,获取token。
function init() {
var urlObject = esri.urlToObject(document.location.href);
if(urlObject.query && typeof (urlObject.query.webmap) != "undefined") {
var WEBMAP_ID = urlObject.query.webmap;
} else {
var WEBMAP_ID = "ceac2dfaea0449119724e8b78e99013a"
}
var mapDeferred = esri.arcgis.utils.createMap(WEBMAP_ID, "map", {
mapOptions : {
slider : true
},
ignorePopups : false,
bingMapsKey : ""
});
mapDeferred.addCallback(function(response) {
console.log(response);
_map = response.map;
dojo.connect(dijit.byId('map'), 'resize', _map,_map.resize);
})
} esri.arcgis.utils.createMap参数。

返回值,是一个dojo.Deferred对象,关于这个对象具体怎么使用可以观看
这篇文章。addCallback,很明显就是添加一个回调函数,等得到item对象数据之后,然后调用这些回调函数。 这样简单的,几句代码就可以很容易显示出ArcGIS Online上的web 地图。

如何在ArcGIS Online中构建自己的应用程序模板初级篇-显示地图
如何在ArcGIS Online中构建自己的应用程序模板中级篇-解析数据
如何在ArcGIS Online中构建自己的应用程序模板高级篇-利用数据


文章来源:http://blog.csdn.net/arcgis_all/article/details/8200220

0 个评论

要回复文章请先登录注册