【ArcGis for javascript从零开始】之一 ArcGis加载天地图
最近做项目需要用到ArcGis来进行数据展示和数据分析。以前从来没有接触过与Gis有关的东西,一切需要从头开始学。没有时间从头系统地学习了,只能用到哪个学习哪里了,本系列只是对学习的路径进行记录。ArcGis在网上没有找到中文的API,只有官网的英文API和Demo,而且用到了大量dojo的API,dojo也没有接触过,这方面也是需要学习的……
一、ArcGis加载
引入css 和js
- <link rel= "stylesheet" href ="https://js.arcgis.com/3.15/esri/css/esri.css">
- <script src= "https://js.arcgis.com/3.15/" ></script>
html
- <div id= "map" ></div>
初始化地图
- require(["esri/map", "dojo/domReady!" ], function(Map) {
- <span style="white-space:pre"> </span>var map = new Map("map" , {
- <span style="white-space:pre"> </span>center: [-118, 34.5],
- <span style="white-space:pre"> </span>zoom: 8,
- <span style="white-space:pre"> </span>basemap: "topo"
- <span style="white-space:pre"> </span>});
- });

二、加载天地图
- //加载天地图
- var baseMap = new WebTiledLayer("http://\${subDomain}.tianditu.com/DataServer?T=vec_c&X=\${col}&Y=\${row}&L=\${level}" , {
- <span style="white-space:pre"> </span>"copyright" : "Tianditu",
- <span style="white-space:pre"> </span>"id": "Tianditu" ,
- <span style="white-space:pre"> </span>"subDomains" : ["t0", "t1", "t2" ]
- });
- map.addLayer(baseMap);
- <span style="white-space:pre"> </span>var tileInfo = new esri.layers.TileInfo({
- "rows" : 256,
- "cols" : 256,
- "compressionQuality" : 0,
- "origin" : {
- "x" : -180,
- "y" : 90
- },
- "spatialReference" : {
- "wkid" : 4326
- },
- "lods" : [
- {
- "level" : 2,
- "resolution" : 0.3515625,
- "scale" : 147748796.52937502
- },
- {
- "level" : 3,
- "resolution" : 0.17578125,
- "scale" : 73874398.264687508
- },
- {
- "level" : 4,
- "resolution" : 0.087890625,
- "scale" : 36937199.132343754
- },
- {
- "level" : 5,
- "resolution" : 0.0439453125,
- "scale" : 18468599.566171877
- },
- {
- "level" : 6,
- "resolution" : 0.02197265625,
- "scale" : 9234299.7830859385
- },
- {
- "level" : 7,
- "resolution" : 0.010986328125,
- "scale" : 4617149.8915429693
- },
- {
- "level" : 8,
- "resolution" : 0.0054931640625,
- "scale" : 2308574.9457714846
- },
- {
- "level" : 9,
- "resolution" : 0.00274658203125,
- "scale" : 1154287.4728857423
- },
- {
- "level" : 10,
- "resolution" : 0.001373291015625,
- "scale" : 577143.73644287116
- },
- {
- "level" : 11,
- "resolution" : 0.0006866455078125,
- "scale" : 288571.86822143558
- },
- {
- "level" : 12,
- "resolution" : 0.00034332275390625,
- "scale" : 144285.93411071779
- },
- {
- "level" : 13,
- "resolution" : 0.000171661376953125,
- "scale" : 72142.967055358895
- },
- {
- "level" : 14,
- "resolution" : 8.58306884765625e-005,
- "scale" : 36071.483527679447
- },
- {
- "level" : 15,
- "resolution" : 4.291534423828125e-005,
- "scale" : 18035.741763839724
- },
- {
- "level" : 16,
- "resolution" : 2.1457672119140625e-005,
- "scale" : 9017.8708819198619
- },
- {
- "level" : 17,
- "resolution" : 1.0728836059570313e-005,
- "scale" : 4508.9354409599309
- },
- {
- "level" : 18,
- "resolution" : 5.3644180297851563e-006,
- "scale" : 2254.4677204799655
- }
- ]
- });
- <span style="white-space:pre"> </span>var baseMap = new WebTiledLayer("http://\${subDomain}.tianditu.com/DataServer?T=vec_c&X=\${col}&Y=\${row}&L=\${level}" , {
- "copyright" : "Tianditu",
- "id": "Tianditu" ,
- "subDomains" : ["t0", "t1", "t2" ],
- <strong>"tileInfo" :tileInfo</strong>
- });
这样显示出来是下面的样子,好一片蔚蓝的大海。
我们把地图缩小一下再看:

- //底图标注
- var baseMapMarker = new WebTiledLayer("http://\${subDomain}.tianditu.com/DataServer?T=cva_c&X=\${col}&Y=\${row}&L=\${level}" , {
- "copyright" : "Tianditu",
- "id": "Tianditu2" ,
- "subDomains" : ["t0", "t1", "t2" ],
- "tileInfo" :tileInfo
- });
- map.addLayer(baseMapMarker);
显示效果变成这个样子:

- <span style="white-space:pre"> </span>map.centerAndZoom(new esri.geometry.Point({
- "x": 116.40969,
- "y": 39.89945,
- "spatialReference": {
- "wkid": 4326
- }
- }),12);
最终效果,至于显示div的样式,铺满全屏什么的,这就是CSS的问题了,不多说了,上一张完工图:

我写的demo,html版的,可以稍微借鉴一下吧 ^_^ 点我下载
【ArcGis for javascript从零开始】之一 ArcGis加载天地图的更多相关文章
- ArcGis Javascript API (V3.6)加载天地图
Arcgis的Javascript api开发很活跃,不知不觉都发布了3.6的版本了.该版本基于dojo 1.8.3开发的. 从dojo 1.8开始,AMD机制用得越来越多了,而且require([& ...
- 18 ArcGIS API for JavaScript4.X 系列加载天地图(经纬度)
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...
- 使用ArcGIS JavaScript API 3.18 加载天地图
对于中国开发者在创建GIS应用的时候,往往比较头疼的是底图资源的缺乏.其实国家测绘地信局就提供一个很好的免费资源:天地图.使用ArcGIS API的开发人员可以直接利用该资源作为地图应用的底图. Ar ...
- ArcGIS API for Javascript 加载天地图(经纬度投影)
<!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title> ...
- ArcGIS API for Javascript 加载天地图(墨卡托投影)
<!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title> ...
- (转)Arcgis for js加载天地图
http://blog.csdn.net/gisshixisheng/article/details/44494715 综述:本节讲述的是用Arcgis for js加载天地图的切片资源. 天地图的切 ...
- arcgis api for javascipt 加载天地图、百度地图
写在前面的话: 1.百度地图是自己定义的坐标系统,wkid=102100.百度地图数据是加密的产物.下文将附上百度坐标与WGS84,谷歌等坐标系统转换方法(地理-地理),此方法并未亲测,据说准 2.百 ...
- (转载)arcgis for js - 解决加载天地图和WMTS服务,WMTS服务不显示的问题,以及wmts服务密钥。
1 arcgis加载天地图和wmts服务 arcgis for js加载天地图的例子网上有很多,这里先不写了,后期有空再贴代码,这里主要分析下WMTS服务为什么不显示,怎么解决. 条件:这里的WMTS ...
- arcgis api 4.x for js 结合 react 入门开发系列react全家桶实现加载天地图(附源码下载)
基于两篇react+arcgis的文章介绍,相信大家也能体会两者的开发区别了.在“初探篇”中作者也讲述了自己的选择,故废话不多说,本篇带大家体验在@arcgis/webpack-plugin环境下,使 ...
随机推荐
- C++语法 初始化列表 数组引用
只能在初始化列表initilizationlist中初始化的有: 1.const修饰的数据成员或者reference参考 2.基类的构造函数 注意,数组不能引用,亦即以下代码是不对的 void fun ...
- Maven简介
转载地址:http://www.cnblogs.com/itech/archive/2011/11/01/2231837.html Ant是软件构建工具,Maven的定位是软件项目管理和理解工具.Ma ...
- javascript ASCII和Hex互转
<script> var symbols = " !\"#$%&'()*+,-./0123456789:;<=>?@"; var loAZ ...
- C++C++中构造函数与析构函数的调用顺序
http://blog.csdn.net/xw13106209/article/details/6899370 1.参考文献 参考1: C++继承中构造函数.析构函数调用顺序及虚函数的动态绑定 参考2 ...
- IntelliJ IDEA快捷键和常用设置
一 快捷键的使用 1.文本编辑删除 ctr + y复制 ctr + D2.智能提示提示 ctr + space智能提示 ctr + shift + space完成当前语句 ctr + ...
- nginx增加ssl服务方法
1.将申请到的ssl加密证书文件拷贝到nginx的conf目录下 如:server.pem.server.key 2.vim nginx.conf 例子: server { listen 443 ss ...
- java web开发问题集合
前台和后台的交流到底是借助什么?servlet?xml? 我们能感觉到用servlet,但是我们是如何使用servlet的?不是现在web.xml部署后,才能触发吗?所以其实我们是本质是借助XML文件 ...
- matlab练习程序(三角形内切圆)
三角形两角的角平分线就能确定内切圆. 结果如下: matlab代码如下: clear all;close all;clc; p=rand(,); %(x,y) v12=(p(,:)-p(,:))/no ...
- [转载]GMM的EM算法实现
在聚类算法K-Means, K-Medoids, GMM, Spectral clustering,Ncut一文中我们给出了GMM算法的基本模型与似然函数,在EM算法原理中对EM算法的实现与收敛性证明 ...
- 在Windows下利用MinGW编译FFmpeg
目录 [隐藏] 1 环境与软件 2 第一步:安装MinGW 3 第二步:配置编译环境 4 第三步:配置SDL 5 第四步:编译 5.1 编译faac 5.2 编译fdk-aac 5.3 编译x264 ...