做地理信息系统(GIS)项目,除了实现功能用户体验度要好之外,最重要的是地图渲染效果更要好。很多时候苦于数据的完整性和对于配图的审美观,程序猿们都很难配出好看的地图效果。基于上述一般直接调用google的地图服务,包括矢量地图,地形地图和影像地图。这样就不用花大力气关注于数据的问题,只需要把地图的操作功能实现就行。下面来说说如何基于arcgis js api 调用google的地图服务。

首先我们需要知道google地图服务的地址:

http://mt.google.cn/vt/lyrs=s@112&hl=zh-CN&gl=cn  //卫星地图服务

http://mt.google.cn/vt/lyrs=h@177000000&hl=zh-CN&gl=cn    //地区名称矢量地图服务

http://mt.google.cn/vt/lyrs=m@112&hl=zh-CN&gl=cn    //矢量地图服务

jsapi 初始化google地图服务实现代码:

initGoogleMapLayer:function(){
dojo.declare("GoogleMapLayer", esri.layers.TiledMapServiceLayer, { // create WMTSLayer by extending esri.layers.TiledMapServiceLayer
constructor: function(){
this.spatialReference = new esri.SpatialReference({
wkid: 102113
});
this.initialExtent = new esri.geometry.Extent(-20037508.342787, -20037508.342787, 20037508.342787, 20037508.342787, this.spatialReference);
this.fullExtent = new esri.geometry.Extent(-20037508.342787, -20037508.342787, 20037508.342787, 20037508.342787, this.spatialReference);
//
this.tileInfo = new esri.layers.TileInfo({
"dpi": "90.71428571427429",
"format": "image/png",
"compressionQuality": 0,
"spatialReference": {
"wkid": "3857"
},
"rows": 256,
"cols": 256,
"origin": {
"x": -20037508.342787,
"y": 20037508.342787
}, // Scales in DPI 96
"lods": [{"level": 0,"scale": 591657527.591555,"resolution": 156543.033928
}, {"level": 1,"scale": 295828763.795777,"resolution": 78271.5169639999
}, {"level": 2,"scale": 147914381.897889,"resolution": 39135.7584820001
}, {"level": 3,"scale": 73957190.948944,"resolution": 19567.8792409999
}, {"level": 4,"scale": 36978595.474472,"resolution": 9783.93962049996
}, {"level": 5,"scale": 18489297.737236,"resolution": 4891.96981024998
}, {"level": 6,"scale": 9244648.868618,"resolution": 2445.98490512499
}, {"level": 7,"scale": 4622324.434309,"resolution": 1222.99245256249
}, {"level": 8,"scale": 2311162.217155,"resolution": 611.49622628138
}, {"level": 9,"scale": 1155581.108577,"resolution": 305.748113140558
}, {"level": 10,"scale": 577790.554289,"resolution": 152.874056570411
}, {"level": 11,"scale": 288895.277144,"resolution": 76.4370282850732
}, {"level": 12,"scale": 144447.638572,"resolution": 38.2185141425366
}, {"level": 13,"scale": 72223.819286,"resolution": 19.1092570712683
}, {"level": 14,"scale": 36111.909643,"resolution": 9.55462853563415
}, {"level": 15,"scale": 18055.954822,"resolution": 4.77731426794937
}, {"level": 16,"scale": 9027.977411,"resolution": 2.38865713397468
}, {"level": 17,"scale": 4513.988705,"resolution": 1.19432856685505
}, {"level": 18,"scale": 2256.994353,"resolution": 0.597164283559817
}, {"level": 19,"scale": 1128.497176,"resolution": 0.298582141647617
}]
});
this.loaded = true;
this.onLoad(this);
},
getTileUrl: function(level, row, col){
return "http://mt" + (col % 4) + ".google.cn/vt/lyrs=s@112&hl=zh-CN&gl=cn&" + "x=" + col + "&" +
"y=" +
row +
"&" +
"z=" +
level +
"&s=";
}
}); dojo.declare("GoogleMapAnooLayer", esri.layers.TiledMapServiceLayer, { // create WMTSLayer by extending esri.layers.TiledMapServiceLayer
constructor: function(){
this.spatialReference = new esri.SpatialReference({
wkid: 102113
});
this.initialExtent = new esri.geometry.Extent(-20037508.342787, -20037508.342787, 20037508.342787, 20037508.342787, this.spatialReference);
this.fullExtent = new esri.geometry.Extent(-20037508.342787, -20037508.342787, 20037508.342787, 20037508.342787, this.spatialReference);
//
this.tileInfo = new esri.layers.TileInfo({
"dpi": "90.71428571427429",
"format": "image/png",
"compressionQuality": 0,
"spatialReference": {
"wkid": "3857"
},
"rows": 256,
"cols": 256,
"origin": {
"x": -20037508.342787,
"y": 20037508.342787
}, // Scales in DPI 96
"lods": [{"level": 0,"scale": 591657527.591555,"resolution": 156543.033928
}, {"level": 1,"scale": 295828763.795777,"resolution": 78271.5169639999
}, {"level": 2,"scale": 147914381.897889,"resolution": 39135.7584820001
}, {"level": 3,"scale": 73957190.948944,"resolution": 19567.8792409999
}, {"level": 4,"scale": 36978595.474472,"resolution": 9783.93962049996
}, {"level": 5,"scale": 18489297.737236,"resolution": 4891.96981024998
}, {"level": 6,"scale": 9244648.868618,"resolution": 2445.98490512499
}, {"level": 7,"scale": 4622324.434309,"resolution": 1222.99245256249
}, {"level": 8,"scale": 2311162.217155,"resolution": 611.49622628138
}, {"level": 9,"scale": 1155581.108577,"resolution": 305.748113140558
}, {"level": 10,"scale": 577790.554289,"resolution": 152.874056570411
}, {"level": 11,"scale": 288895.277144,"resolution": 76.4370282850732
}, {"level": 12,"scale": 144447.638572,"resolution": 38.2185141425366
}, {"level": 13,"scale": 72223.819286,"resolution": 19.1092570712683
}, {"level": 14,"scale": 36111.909643,"resolution": 9.55462853563415
}, {"level": 15,"scale": 18055.954822,"resolution": 4.77731426794937
}, {"level": 16,"scale": 9027.977411,"resolution": 2.38865713397468
}, {"level": 17,"scale": 4513.988705,"resolution": 1.19432856685505
}, {"level": 18,"scale": 2256.994353,"resolution": 0.597164283559817
}, {"level": 19,"scale": 1128.497176,"resolution": 0.298582141647617
}]
});
this.loaded = true;
this.onLoad(this);
},
getTileUrl: function(level, row, col){
return "http://mt" + (col % 4) + ".google.cn/vt/lyrs=h@177000000&hl=zh-CN&gl=cn&" + "x=" + col + "&" +
"y=" +
row +
"&" +
"z=" +
level +
"&s=";
}
});
}

arcgis jsapi调用初始化的google地图服务:

var googleMapLayer = new GoogleMapLayer();
map.addLayer(googleMapLayer);

通过上面的代码实现就能把google地图服务,添加到自己的项目中。

arcgis jsapi 调用google地区服务的更多相关文章

  1. OpenLayers调用arcgis server发布的地图服务

    有两种方式可以调用arcgis server发布的地图服务,一种是rest,一种是wms.  地图的投影为900913,arcgis server为10.0版本,地图服务的空间参考为3857.   与 ...

  2. arcgis engine 调用arcgis server服务

    首先需要添加两个引用: using ESRI.ArcGIS.GISClient;using ESRI.ArcGIS.DataSourcesRaster; /// <summary> /// ...

  3. OpenLayers调用ArcGIS Server发布的WFS服务

    OpenLayers调用ArcGIS Server发布的WFS服务 原创: 蔡建良 2013-08-20 一. 开发环境 1) Openlayers2.13+arcgis server9.3 2) W ...

  4. 怎样用Google APIs和Google的应用系统进行集成(3)----调用Google 发现(Discovery)API的RESTful服务

    说了这么多,那么首先同意我以Google Discovery RESTful服务为例,给大家演示怎样用最普通的Java代码调用Google Discovery RESTful服务. 引言: 在&quo ...

  5. ArcGIS API for JavaScript(2)-ArcGIS Server发布要素图层服务

    1.前言 上一篇该系列的文章我们主要讲了一下基础Web地图搭建,这篇我们主要讲一下ArcGIS Server发布服务,并且如何调用服务.将自己的数据加载到Web地图当中来,实现Web端浏览数据. 2. ...

  6. arcgis jsapi接口入门系列(3):各种类型的图层添加

    这里说的tomcat切片,是指arcgis server切片后,把切片图片文件用tomcat发布(其他任意web服务器发布都行) //添加tomcat切片图层 addTomcatTileLayer: ...

  7. c#两种方式调用google地球,调用COM API以及调用GEPLUGIN 与js交互,加载kml文件,dae文件。将二维高德地图覆盖到到三维谷歌地球表面。

    网络上资源很多不全面,自己在开发的时候走了不少弯路,在这里整理了最全面的google全套开发,COM交互,web端交互.封装好了各种模块功能. 直接就可以调用. 第一种方式:调用COMAPI实现调用g ...

  8. Salesforce Apex页面中调用远端网络服务

    本文介绍了Salesforce Apex页面中调用远端网络服务的实现过程. ### 注册远端网络服务 在使用Apex代码调用远端网络服务之前,首先需要在Salesforce中注册远端网络服务地址, 本 ...

  9. Android按需添加Google Play服务

    以前无论使用何种Google Play服务,都是直接在gradle文件中引用一个库. compile 'com.google.android.gms:play-services:9.4.0' 这直接导 ...

随机推荐

  1. WM_PAINT与WM_ERASEBKGND(用户操作和API这两种情况产生消息的顺序有所不同)

    1)当WM_PAINT不是由InvalidateRect产生时,即由最大化,最小化等产生时,或者移动产生(移动有时只会产生WM_ERASEBKGND消息)系统先发送WM_ERASEBKGND消息,再发 ...

  2. 【Java数据结构】Java数据结构之链表反转

    我们都知道用C可以很简单的实现单链表反转,今天来学习下,在Java中如何实现链表反转. 思路很简单,定义一个类,这个类分成2块,一块是表示自身的标志,另外一个存储指向下一个元素的引用.通过互换相邻两个 ...

  3. 判断指定进程是否为x64的方法(在ntdll判断某个x64函数是否存在)

    BOOL IsWow64ProcessEx(HANDLE hProcess) { // 如果系统是x86的,那么进程就不可能有x64 bool isX86 = false; #ifndef _WIN6 ...

  4. grep、sed、awk、perl、js、vim等对正则表达式的支持的差别

    grep.sed.awk.perl等对正则表达式的支持的差别 grep 2.5.1 egrep 2.5.1 sed 3.02 sed 4.07 awk 3.1.1 perl 5.8.0 vim 6.1 ...

  5. Redis intset

    Redis intset也非常简单.它是一个有序整数集合,实际上是一个有序数组,查找时二分查找,添加时可能需要内存挪动.唯一不同的是,它的整数类型是变动的,可以支持int16,int32,int64三 ...

  6. leetcode第一刷_Sqrt(x)

    这道题乍看下来很easy,实际上要注意的问题许多. 注意看给出来的函数的接口,返回的是int值,也就是计算结果是个近似值.如何求呢?难道是从2開始往上算?直到某个值正好接近x?当然不行,肯定超时了.再 ...

  7. tmd123.com

    赞!完胜百度的搜索!比baidu.com好多了! 搜索用!非常像!比baidu.com好多了! mark一下 发现有人录制了101集swift视频教程好像持续更新中......

  8. nmap -- write a nmap script

    漏洞扫描 --编写Nmap脚本 2006年12月份,Nmap4.21 ALPHA1版增加脚本引擎,并将其作为主线代码的一部分.NSE脚本库现在已经有400多个脚本.覆盖了各种不同的网络机制(从SMB漏 ...

  9. hao947 : Mybatis resultMap配置插入和主键自增返回 : 好947

    映射配置文件  好947  <!-- type:映射实体类的数据类型 id:resultMap的唯一标识 -->  <resultMap type="person" ...

  10. SilkTest Q&A 5

    Q41.VerifyBitmap的问题. 我正在使用函数VerifyBitmap比较位置,边,颜色等,例如: Window.VerifyBitmap("Position.bmp", ...