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

长平狐 发布于 2012/11/28 15:39
阅读 1K+
收藏 0

    开发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值,就可以来创建我们的地图。
    
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 地图。
 
    
    


原文链接: http://blog.csdn.net/arcgis_all/article/details/8200220
加载中
OSCHINA
登录后可查看更多优质内容
返回顶部
顶部