`
cjnetwork
  • 浏览: 179534 次
  • 性别: Icon_minigender_1
  • 来自: 重庆
社区版块
存档分类
最新评论

googleMap本地化(离线)

阅读更多
在web开发中可能遇到这样的需求:需要一个地图系统,选择google map来完成地图的展示,但是该web系统由于特殊性而不允许与外网链接,还有就是现在对google的访问越来越不稳定(国家网络限制),因此希望将google map移植到内网中使用。
可以将google map api分为3个部分来看待:
1、负责与服务器交互的js文件
2、google提供的技术支持,例如查找路径、周边搜索
3、google提供的地图数据

如果需要开发的功能中包含第2部分的需求,那么可能比较复杂。因为路径算法在google服务器上实现,只是对外提供了接口,如果无法连接google网络则无法实现。
但如果开发的web中对map的使用比较简单,例如只是加载地图,有简单的地图移动等功能,那么这样的需求是可以将google map移植到内网来处理的。这种方法也适用于自定义周边搜索,例如需要完成的web功能就是通过查询,获取指定范围内的建筑物、获取自定的标记(开发本地商户搜索系统的时候,地图上商户数据的维护肯定是有web自己维护,而并非google提供的数据,这种场景正好适合)。

下来来说如何将google map本地化,可以分为两个步骤:
1、将google map使用的与服务器交互的js文件本地化
这个当然是根据google map加载时候,所需要的js下载到本地,以后再应用程序开发的时候,不引用google站点上的js,而是换成本地的js文件。具体有些什么js需要下载的,这里就不做详细介绍了,可以通过firefox的firebug插件,或是google chrome等工具查看到http请求,分析并下载有效的js文件,可能还需要分析各个js之间在使用过程中加载外链js的地址,并予以修改、替换问对本地js的调用。google map api中需要使用到的js本地化,网络上一个叫做rover.tang的朋友已经做得很好,提供了google map api v3.8的本地化js,可以在网络上找到。
2、将google map的地图数据(tiles:瓦片)下载到本地,以及应用的开发
说到地图数据,需要了解google map的一点基础知识。google把在浏览器中显示的地图,分割成一块一块的图片,称之为tile,在浏览其中显示地图的部分,从google下载各个tile,然后拼接在一起,就能够看到完整的一幅地图。每一个tile的大小都是256*256的png图片,因为存在缩放(缩放级别为0-19),每个缩放级别中,浏览器中显示地图的区域被划分为多个tile,每个tile会根据去google站点下载对应的地图数据,其实就是一张png图片,在浏览器分别请求以获取tile地图图片数据的时候,会传递给google 三个重要的参数,1、tile的x坐标;2、tile的y坐标;3、当前浏览器中显示的地图的缩放级别。
google map可以自定义地图类型(MapType),详细的可以参考https://developers.google.com/maps/documentation/javascript/maptypes
下面说说如何通过自定义方式加载地图(地图数据本地化)
//js代码
<script type="text/javascript">
var map;
var myCenter = new google.maps.LatLng(29.568381,106.552219);//重庆  
function CoordMapType() {
}
CoordMapType.prototype.tileSize = new google.maps.Size(256,256);
CoordMapType.prototype.maxZoom = 19;
CoordMapType.prototype.getTile = function(coord, zoom, ownerDocument) {
  var div = ownerDocument.createElement('div');
  div.innerHTML = '<img name="" src="./tiles/zoom_10/x_814-y_424-z_10.png"/>';
  //div.innerHTML = '<img name="" src="./tiles/zoom_' + zoom + '/x_' + coord.x + '-y_' + coord.y + '-z_' + zoom + '.png"/>'; 
  div.style.width = this.tileSize.width + 'px';
  div.style.height = this.tileSize.height + 'px';
  div.style.fontSize = '10';
  div.style.borderStyle = 'solid';
  div.style.borderWidth = '1px';
  div.style.borderColor = '#AAAAAA';
  return div;
};

var coordinateMapType = new CoordMapType();

function initialize() {
  var mapOptions = {
    zoom: 10,
    center: myCenter,
	mapTypeId: "coordinate"
  };
  map = new google.maps.Map(document.getElementById("map_canvas"),mapOptions);
  map.mapTypes.set('coordinate',coordinateMapType);
}
google.setOnLoadCallback(initialize);
</script>

//html代码
<div id="map_canvas"></div>

重点是代码div.innerHTML = '<img name="" src="./tiles/zoom_10/x_814-y_424-z_10.png"/>',该代码定义了自定义地图到哪里加载地图数据(tile),我们需要本地化google map,因此将google map对应的tile下载到本地,按照自己的意愿命名存放在服务器上,因此我们需要根据自己存储google map的地图数据,代码示例中,统统只加载一个固定的图片,仅作为测试,实际情况可以修改这里的规则。这样,在加载地图的时候,或是在移动地图的时候,就会加载本地(本地服务器)的地图的地图数据。

完成到这一步,就差google 地图数据下载了,通过在线google地图的移动,可以看出google map会去类似这样的地址http://mt0.googleapis.com/vt?src=apiv3&x=814&y=423&z=10下载地图数据,x即tile的x坐标,y即tile的y坐标,z即缩放级别。因此采用任意的开发语言,或脚本,到google的服务器上下载对应需要区域的地图数据,存放到本地即可。java实现网络下载当然有很多可以使用的东西了,这个就随意发挥了。:)
分享到:
评论
12 楼 way_super 2018-01-08  
请问楼主,地图都可以下载了,就是你这里面没有的添加标记的功能,网上说都是使用marker = new google.maps.Marker添加标记,但是在你这个基础上去做却没有效果~~~
11 楼 way_super 2018-01-03  
gaoxiangky 写道
你好,这个经纬度我解决了,但是我将这个地图嵌入到MFC对话框中的时候,每次调用的时候只是闪一下就没有了,这个lz有没有遇到过


请问你咋解决的?我咋下载不了?
10 楼 gaoxiangky 2014-05-01  
你好,这个经纬度我解决了,但是我将这个地图嵌入到MFC对话框中的时候,每次调用的时候只是闪一下就没有了,这个lz有没有遇到过
9 楼 gaoxiangky 2014-05-01  
你好,怎么样由经纬度转变为下载的图片,我的意思是我输入一个缩放级别和经纬度,怎么确定对应的图片?
8 楼 kingking2100 2014-01-03  
大哥,很好用,感激不尽。 
7 楼 commanderhyk 2013-10-17  
您好,非常感谢您提供的程序,想问下配置文件中的
#download size per thread round
roundCount=50
说的是什么意思如何理解这个round???谢谢
6 楼 supergis12 2013-06-18  
除了换地理范围,还需要配其他的吗?只换左上右下点,下载不了
5 楼 cjnetwork 2013-02-01  
laiahu 写道
重庆的经纬度为(106.552219,29.568381);,那怎么计算出conf.properties的
leftTopLnglat=105.812987, 30.334954
#rightBottomLnglat   (107.827147, 28.613459)
rightBottomLnglat=107.827147, 28.613459


左上角和右下角的经纬度坐标是怎么计算出来的,谢谢



这个,你直接打开google地图,在地图上邮件,选择“这是什么?”,就可以看到你点击的地方的经纬度。
4 楼 laiahu 2013-01-31  
重庆的经纬度为(106.552219,29.568381);,那怎么计算出conf.properties的
leftTopLnglat=105.812987, 30.334954
#rightBottomLnglat   (107.827147, 28.613459)
rightBottomLnglat=107.827147, 28.613459


左上角和右下角的经纬度坐标是怎么计算出来的,谢谢
3 楼 cjnetwork 2012-11-07  
jurnzhou 写道
大哥,leftTopLnglat和rightBottomLnglat 怎么定义的?

我把经纬放进去下载不了吖


左上角和右下角的经纬度坐标,可以再conf.properties中配置。
这个你可以参看压缩文件里面的文件。
2 楼 jurnzhou 2012-11-07  
大哥,leftTopLnglat和rightBottomLnglat 怎么定义的?

我把经纬放进去下载不了吖
1 楼 lihao6833 2012-06-15  
可以在上面画轨迹线吗?

相关推荐

    Google map 离线调试

    首先,离线调试Google Map需要处理的关键是资源的本地化。描述中的文件列表揭示了可能的离线资源:`example2_my.htm`、`example_my.htm`、`index_my.htm`可能是包含Google Map API调用的HTML文件,它们可能用于显示...

    Google离线地图,通过demo.html可以直接打开

    这些本地存储机制可以在浏览器端持久化数据,即使在离线状态下也能访问。 4. **构建离线地图应用**:在"demo.html"中,你需要编写JavaScript代码来处理地图显示。当检测到网络不可用时,应用应从本地存储读取地图...

    google离线地图API包 + 地图数据

    `GoogleMapAPIV3`文件夹很可能包含了Google Map API V3的本地副本,这使得开发者可以在离线状态下引用API。这个文件夹可能包含JavaScript文件,这些文件需要在HTML中引入以启用地图功能。此外,API可能已经经过了...

    Google Map api V3 (3.9.12)的离线开发包

    2. **初始化地图**:创建一个HTML元素作为地图容器,然后使用`google.maps.Map()`构造函数实例化地图对象。需要指定容器ID和地图选项,如中心点、缩放级别等。 ```javascript var map = new google.maps.Map...

    GoogleMapAPIV3离线demo

    这个离线示例可能包含了一整套无需互联网连接即可运行的代码和资源,帮助开发者了解和学习如何在自己的应用程序中使用Google Map API V3。 在Google Map API V3中,有以下几个重要的知识点: 1. **初始化地图**: ...

    VC/MFC加载google map

    在VC++环境中,MFC(Microsoft Foundation Classes)是一个C++库,用于构建Windows...总的来说,将Google Map整合到VC/MFC应用中,既能让用户在本地环境中享受地图服务,也能为开发者提供丰富的地图功能和定制空间。

    Google Map地图下载小工具

    同时,对于开发者而言,这种工具也能够帮助他们获取地图数据,用于开发本地化的地图应用或进行数据分析。 值得注意的是,使用此类工具时需要遵守Google的服务条款,确保不违反任何版权规定。此外,由于地图数据更新...

    Google离线地图

    总之,利用Google Maps离线功能进行开发调试是一项技术性较强的任务,需要对Google Maps API有深入理解,并具备良好的本地数据管理和应用优化能力。通过合理的策略和技巧,开发者可以为用户提供流畅的离线地图体验,...

    全世界googleMap瓦片(1-6)级

    例如,你可以通过这些瓦片构建一个本地化的地图服务,或者结合其他数据进行地理信息分析。同时,这些瓦片也可以作为教学素材,帮助人们了解地图服务的内部运作机制。 总的来说,“全世界googleMap瓦片(1-6)级”...

    基于SuperMap Objects写的GoogleMap地图切割程序

    标题中的“基于SuperMap Objects写的GoogleMap地图切割程序”指的是使用SuperMap Objects这一GIS(地理信息系统)开发组件来实现对Google Map地图数据的处理和切割功能。SuperMap Objects是SuperMap公司提供的一套...

    GoogleMapsAPIv3(3.16.2)离线开发

    本篇文章将深入探讨Google Maps API v3.16.2的离线开发,以及如何利用离线包进行开发。 1. **Google Maps API v3的概述**:Google Maps API v3是Google Maps API的重大更新,它引入了更轻量级的JavaScript库,减少...

    离线地图的实现

    总结来说,离线地图的实现涉及地图数据的瓦片化处理、本地存储和客户端应用的瓦片加载机制。通过这种方式,即使在没有网络的情况下,用户也能顺畅地查看和使用地图服务。而对于内网环境,离线地图更是解决了无法访问...

    谷歌离线地图范例之修改瓦片地图

    离线地图技术在移动设备和网络不稳定的情况下显得尤为重要,它允许用户在无网络连接时仍然...通过以上步骤,你可以创建一个完全个性化的离线地图,无论是在户外探险还是在没有网络的环境下,都能提供可靠的导航服务。

    离线地图制作工具

    加载本地数据时,可以使用离线版的 Google Map API。在HTML中,你需要引用API的本地副本(如 `mapapi3.8.6.js`),并创建一个新的自定义地图类型(`LocalMapType`)。`LocalMapType` 类定义了地图的基本属性,如瓦片...

    Map1.zip google map 公交车

    如果包含的是公交数据,可能可以用于开发本地化的公交查询应用或者进行数据分析,如公交线路优化、客流预测等。不过,由于没有具体的文件内容,这部分只能是推测。 总的来说,Google Maps的公交服务为用户提供了一...

    离线google地图

    虽然离线Google地图听起来像是绕过了Google的服务,但通常情况下,我们仍然需要Google Maps API的某些部分来初始化地图和处理交互。在离线场景下,这通常意味着需要一个经过修改的API版本,它能够从本地而不是...

    Google Map(需安装Flash AIR)

    综上所述,这个"Google Map(需安装Flash AIR)"是一个依赖Flash技术的谷歌地图应用,可能包含独特的功能或改进,如本地搜索优化。用户需要安装Adobe Flash AIR才能运行,并且可能附带了详细的文档来辅助使用。然而,...

    C#中加载地图控件,支持离线地图显示

    using (var stream = GMap.NET.MapProviders.GMapProviders.GoogleMap.GetTileStream(new GMap.NET.PointLatLng(lat, lng), zoom, true)) { if (stream != null) { var bitmap = new Bitmap(stream); // 将图片...

    利用Leaflet+heatmap加载本地google瓦片地图实现热力图

    在本文中,我们将深入探讨如何利用Leaflet JavaScript库与heatmap.js插件,结合本地存储的谷歌离线瓦片地图,来实现一个自定义的热力图应用。这将帮助开发者在离线环境下创建动态且直观的数据可视化效果。 首先,...

Global site tag (gtag.js) - Google Analytics