因为项目需求,要做一个web地图,之前做过高德的在线地图,它提供了一系列的API,并且由于是国产的,所以开发起来比较容易,现在由于项目是内网使用的,所以需要使用离线地图,由此便开始了:

Web GIS离线解决方案:

在CS系统中可以基于GMap.Net来做,参考《百度谷歌离线地图解决方案》

下面介绍下Web系统如何使用GIS切片数据,开发web GIS系统。

首先开发web GIS 主要是采用一些前端框架,目前主流的gis前端框架是openlayers 和 Leaflet至于两者优劣,读者可自行百度,我在项目中使用的是 Leaflet

打开地图下载器(工具在底部的github项目里,可自行下载)

找到 MapDownloader.exe.config 文件 进行修改

具体的就是修改我红框中的内容:该数据库地址,用户名密码等扽,改成自己的就行

修改保存,双击

然后做一些设置

首先选择mysql数据库,其次选择你要下载地图的地方,我这里选择的是北京,根据自己的需求进行选择,选择的位置过大,下载的时间就会很长

接下来选择地图,这一步操作十分重要我在这一步耽误了很长时间,一开始的时候没有选择地图,结果出现地图不显示的情况,后台换百度,谷歌都不行,换了高德就没问题了,个人可以依情况选择

就是这个菜单,选择需要下载的地图提供方,选择完毕之后,双击弹出提示框

这是让你选择下载的级别,通俗来说就是地图的精细程度,级别越大地图就能显示的越精准,需要注意的是,当级别超过15,地图的数据量会特别大,这里给出级别为15的地图的样子,个人可以根据情况来判定

级别选到15大概就是这个样子

等待下载完成之后,进入你的mysql 数据库 发现新建了一张数据表

接下来要做的就是把这张数据库表的数据,导出成瓦片地图(其实就是一张张有规律的256*256图片)

打开 GISMysqlToLocal.exe(后面会给出下载地址)

该填写的填写完整,然后点击导出就可以导出图片了,导出完成后,进入你导出的文件夹内 ,可以看到导出的内容是这样的

都是文件夹套文件夹的形式,然后会到导出的文件夹下,使用Ngix启动服务,也就是把这里图片都放到web服务器里面,你可以使用Nginx,也可以使用Apache,甚至于tomcat

这里我只介绍一下用tomcat配置静态资源访问

我们都知道tomcat可以配置静态资源和动态资源,但是实际工作过程中,我们都是把静态资源跟动态资源放到一个项目的源代码里,进行打包部署,那么对于我们的离线地图,静态资源是十分大的,

把离线地图跟我们的代码放到一个项目里面显然不现实,所以我们需要把静态资源放到其他路径

如:

/data/googlemaps

那我们把文件放到这个目录,浏览器如何访问呢,使用tomcat的话,在此处配置

suffix=".txt" pattern="%h %l %u %t "%r" %s %b" />

注意标注颜色的地方,一般我们都只是在Host标签下配置一个Context标签(你的应用),其实是可以配置两个标签,表示同一个端口的不同地址,重启tomcat之后,这样当你访问     http://localhost:8080/googleMap/hello.png,就可以访问静态资源了

当然你直接访问你的应用 localhost:8080 也是没有问题的

当然你习惯哪个都行(生产环境推荐Nginx,测试环境推荐使用tomcat,因为可以省的配置Nginx),只要我之后可以通过浏览器去访问就可以(我这里使用了一个http-server的一个工具,不过需要先安装Node,具体看个人需求了),启动完成之后,测试使用浏览器访问 具体就是 “ip+端口+路径” 能访问到图片说明服务已经启动成功,  暂且先不用管他

接下来编写html页面

第一步引入js css

标箭头的是必须要引入的

接下来

#定义一个DIV作为地图的容器,一定要为它设置wdith,height

接下来写js

varmap

#这个地址就是你刚才启动服务器的地址788865972代表你导出图片的最上层文件夹,这个文件夹也是自动生成的var osmUrl = 'http://localhost/788865972/{z}/{x}/{y}.png';var osmAttrib = '高德地图';varosm;

$(function() {

osm=L.tileLayer(osmUrl, {

minZoom:5,

maxZoom:15,

attribution: osmAttrib

});

map = L.map('map')

.setView([39.908419, 116.397743], 10)

.addLayer(osm);

以上就是地图的初始化方法:

写完之后,保存双击html 就应该可以看到地图了

红框是我后加的内容,至此离线地图基本已经创建完成了,要想实现更多的功能,比如地图搜索,地图标记可以看我的源码,以及官网的API

特别需要提一点的是关于离线地图的搜索,是需要你内网的数据库里面有位置信息,然后把第三方的位置信息抓取过来,放到自己的数据库里进行搜索等等,并非leafletjs所自有的

不过Leaflet的功能还是非常丰富的

可以自行到官网查看:http://leafletjs.com/

关于搜索的扩展功能,我的后台源码里已经写了,首先自己需要创建一张数据库表,此表需要有你抓取坐标的经纬度,名称,位置信息等字段,坐标抓取方法,可自行百度,单需要记住一点,你用地图下载器下载的什么地图,抓取坐标信息

就抓取哪个地图的坐标信息,我测试的数据是在网上下载的,如果你需要最新的数据,那么需要自己去抓取。我后台使用springboot写的,建表sql,已经下载地图工具都包含在里面了,直接下载源码,打开地图下载器,下载地图,然后导出瓦片图片

再抓取一些坐标信息,就可以看到地图,并且实现搜索功能了

源码连接:https://github.com/chenwuwen/OffineMap

java gis离线地图_java离线地图web GIS制作相关推荐

  1. java基础代码实例_java学习之web基础(3):Servlet 和 Request的登录处理实例

    在页面输入用户名和密码,进行权限判断. 登录成功跳转到SuccessServlet展示:登录成功!用户名,欢迎您: 登录失败跳转到FailServlet展示:登录失败,用户名或密码错误. 我们这里使用 ...

  2. java课程设计斗地主_Java课程设计---web版斗地主

    一. 团队课程设计博客链接 https://www.cnblogs.com/lanxiang/p/10293812.html 二.个人负责模块和任务说明 负责前后端数据传输 JSP界面的设计 根据后台 ...

  3. java泡泡堂分析_java泡泡堂 - WEB源码|JSP源码/Java|源代码 - 源码中国

    文件名大小更新时间 CrazyArcade\.classpath2952019-11-23 CrazyArcade\.gitignore12052019-11-23 CrazyArcade\.proj ...

  4. Web GIS及其应用

    摘 要:分析了Web GIS的主要特点,探讨了Web GIS的关键技术,比较了几种流行的Web GIS软件,并简单举例说明了Web GIS的应用. 关键词:Web GIS 关键技术 应用 中图分类号: ...

  5. 【ArcGIS平台系列】ArcGIS平台,打造可落地的新一代Web GIS

    新一代Web GIS的内涵 "新一代Web GIS",是Esri在新的GIS技术和时代背景下,所提出的一种以Web为中心的.全新的GIS应用模式,在这种模式中,资源和功能都进一步整 ...

  6. 《Web GIS原理与应用开发》读书笔记(5)

    第五章 切片地图 以下均掺杂个人理解 书目:Web GIS 原理与应用开发 -- 刘光 曾敬文 曾庆丰 著 如果要提高Web地图的访问速度,使用地图切片的非常有效的方法. 地图切片就是在多个比例尺下配 ...

  7. Web GIS开发教程

    Web GIS开发教程 非程序员的基本 Web GIS 开发 课程英文名:Web GIS development course 此视频教程共4.0小时,中英双语字幕,画质清晰无水印,源码附件全 下载地 ...

  8. java web调用百度地图_Java web与web gis学习笔记(二)——百度地图API调用

    一.申请百度地图开发者 百度地图API是为开发者免费提供的一套基于百度地图服务的应用接口,包括JavaScript API.Web服务API.Android SDK.iOS SDK.定位SDK.车联网 ...

  9. web高德地图怎么加载离线地图_基于 QGIS 在内网中离线加载卫星地图的方法

    1. 概述 我们之前为大家分享过在三维地球开源平台离线加载卫星影像的方法,主要包括基于桌面端的OsgEarth开源三维地球和基于Web端的Cesium开源三维地球等平台的局域网离线影像加载. 另外,也 ...

最新文章

  1. 【leetcode】1018. Binary Prefix Divisible By 5
  2. xmake入门,构建项目原来可以如此简单
  3. sku属性组合小例子
  4. xshell MySQL表备份_shell mysql数据迁移/备份
  5. XML 需要用的空间
  6. VTK:PolyData之ColorDisconnectedRegionsDemo
  7. CC2530, 各种智能家居通信技术比较
  8. android异步更新UI
  9. [深入学习C#]利用反射给对象赋值
  10. asp.net关于页面不回发,不生成__doPostBack方法问题的完美解决方案--ZT
  11. Linux(4) 实用指令
  12. react native进一步学习(NavigatorIOS 学习)
  13. FormData对象
  14. 3.2生产者和消费者(Producers and Consumers)
  15. python replace替换多个字符_「Python 秘籍」字符串忽略大小写的搜索替换
  16. SQL server增删改查
  17. R语言——R和RStudio软件下载及安装
  18. 数据存储过程之MySQL与ORACLE数据库的差别
  19. S32K--输入捕获(FTM_IC)配置与使用学习笔记(SDK3.0)
  20. 随机森林python实例_用Python实现随机森林算法的示例

热门文章

  1. 思科计算机网络ppt,【思科网络课件】计算机网络双语教程第五章.ppt
  2. EA的使用(用例图)
  3. 离散数学及其应用基本结构知识总结
  4. 给自己定个小目标:每天写点东西
  5. POJ 3666 dp
  6. 一文搞懂cookie与session
  7. android 支付宝手势密码锁,Android实现支付宝手势密码功能
  8. 数据可视化——(提示框插件)
  9. Hadoop及组件的安装
  10. 深度学习(四)-前馈神经网络