转自原文 支持WEB、Android、IOS的地图解决方案

工具链

GIS工具集
  1. OpenGeo Suite
    包含PostGIS, GeoServer, GeoWebCache, OpenLayers, 和 QGIS
地图准备
  1. QGIS
    导入、导出、编辑.shp,postgis,geotiff,geojson,dxf等多种GIS文件,给普通图片配准到地理坐标
    教程:http://www.qgistutorials.com/en/

  2. DraftSight
    编辑CAD文件

  3. SketchUp   从CAD文件生成3D视图

地图服务
  1. GeoServer
    地图服务发布。作为war放入Tomcat或Jetty即可使用。可发布geotiff,.shp,POSTGIS等多种GIS数据为地图。通过openlayer或QGIS浏览。

  2. GeoWebCache
    缓存地图瓦片,提高性能。已内置在最新版GeoServer中。

  3. TileStream
    把.mbtile文件发布为地图服务

离线地图打包
  1. TileMill
    将geotiff,geojson,csv,shp,postgis等文件美化、打包为.mbtile瓦片地图文件,存有地图信息的sqlite文件。
    教程:https://www.mapbox.com/tilemill/docs/crashcourse/introduction/

  2. mbutil
    将.mbtile文件分解为普通图片和json文件

地图浏览
  1. Mapbox.js
    在浏览器中显示TMS地图(Javascript)。基于Leaflet。可配合TileSteam使用。Example:https://www.mapbox.com/mapbox.js/example/v1.0.0/

  2. Mapbox IOS SDK
    在IOS设备中显示TMS或.mbtile地图,基于Route-Me

  3. Mapbox Android SDK
    在Android设备中显示TMS或.mbtile地图,基于osmdroid
    例程://depot/research/mapstudy/tstmapbox/

  4. OsmDroid
    在Android设备中显示TMS或.mbtile地图
    例程://depot/research/mapstudy/tstosmdroid/

  5. osmbonuspack
    为OsmDroid增加显示POI等功能
    例程://depot/research/mapstudy/tstosmbonuspack/

  6. Leaflet
    在浏览器中显示TMS地图(Javascript)。

  7. OpenLayers
    在浏览器中显示TMS、WMS地图(Javascript)。比Leaflet功能强大复杂。

  8. Indoor.js
    Indoor 工具集,基于OpenSteetMap,TileMill,Leaflet。 目前尚不稳定。

  9. d3.js
    Javascript数据显示工具

工具链关系图

离线地图制作举例

假设输入为DWG,若原图为位图(JPG/PNG),直接跳到第5步

在SketchUp中导入DWG。并用Make Faces 插件(YouTube)生成面

在SketchUp中拉伸为3D模型

导出,如果用render渲染更好

打开QGIS,"栅格"->配准工具。左边第一个图标打开底图。点击黄色齿轮。设置输出为base.tif。 目标空间参照系统为EPSG:3857. 勾选“完成时载入到QGIS”

在图上任点2点。在弹出框内输入该点坐标值。输入像素坐标即可。

点第二个图标完成配准。

添加一个矢量图层描述信标,类型为“点”,新建属性ccode,类型为整数(信标内容码)。新建属性name,类型为字符串。

点击黄色小铅笔到编辑模式,再点击 * 图标,在图上点击要增加信标的位置。添加3个点,id和ccode分别为1,2,3。再次点击黄色小铅笔退出编辑模式。

添加一个矢量图层描述信标,类型为“多边形”,新建属性name,类型为字符串.

点击黄色小铅笔到编辑模式,再点击 * 图标,在图上勾出围栏区域。并分别命名。

右键位图图层,另存为GeoTiff

右键矢量图层。另存为GeoJson

打开TileMill,Project-->New project

Layers-->Add Layer, 选择刚才导出的base.tif,SRS选择900913. “Save & Style” 。点击图层#base上得放大镜缩放到合适大小。

删除Contries图层和相应的mss。把background-color改为和底图一致

"+ Add Layer" 添加刚才导出的2个geojson文件

选择左侧手指==>Teaser.下面图层选择为hotarea.上面内容框中填入{{{name}}}

Save以后。可以看到热区效果。 当鼠标移到热区时。相应的name会显示。

将polygon-opacity,line-opacity和marker-opacity设为0。点击Export导出mbtiles. 放大图片到zoom 16级,把中心标志放到图中央。shift+鼠标拖动框选地图区域。点击 Export导出为文件。在~/Documents/MapBox/export中可以找到导出的example.mbtiles文件

启动地图服务。在terminal中执行 tilestream --tiles=/Users/fangjian/Documents/MapBox/export 然后访问http://localhost:8888/ 可以看到地图已经生效。访问 http://localhost:8888/v2/example.json 可以下载tilejson. 访问 http://localhost:8888/v2/example.mbtiles可以下载mbtiles文件。 如果只制作离线地图可以跳过这步。

解包example.mbtiles为普通图片和json文件.在.mbtiles所在目录。运行mb-util example.mbtile example
图片文件被解到了example目录下

复制metadata.json为tile.json 改为example.json的格式 。将center和bounds改为数组(如果只做离线文件可以跳过)

参考metadata.json 修改 https://www.mapbox.com/mapbox.js/example/v1.0.0/ 样例

<script>
var map = L.mapbox.map('map');
var stamenLayer = L.tileLayer('./{z}/{x}/{y}.png', {
attribution: 'Map tiles by <a href="http://dreamvoc.com">DreamVoc</a>.',
minZoom:14,
maxZoom:17
}).addTo(map);
map.setView([-0.0047,0.0075], 16);
</script>

拷贝ccode.geojson和hotarea.geojson到当前目录。编辑文件内容为var ccode={... var hotarea={...map.featureLayer.setGeoJSON(ccode); 然后加入以下代码

<script src="ccode.geojson" ></script>
<script src="hotarea.geojson" ></script>
<script>
map.featureLayer.setGeoJSON(ccode);
</script>
<script>
L.geoJson(hotarea).addTo(map);
</script>

加入热区参考文章 http://leafletjs.com/examples/choropleth.html

支持WEB、Android、IOS的地图解决方案的更多相关文章

  1. Android WebView常见问题的解决方案总结----例如Web page not available

    之前android虚拟机一直都可以直接联网,今天写了一个WebView之后,突然报出了Web page not available的错误,但是查看虚拟机自带的浏览器,是可以上网的,所以检查还是代码的问 ...

  2. SSM整合 完美支持RESTful(Jsp和客户端<android ios...>)

    一 RESTful简介 RESTful是一种网络应用程序的设计风格和开发方式 它结构清晰 符合标准 易于理解 扩展方便 REST 即Representational State Transfer的缩写 ...

  3. [翻译]Nativescript 中 Web 视图与 Android/IOS 的双向通信

    English document From http://shripalsoni.com/blog/nativescript-webview-native-bi-directional-communi ...

  4. Android IOS WebRTC 音视频开发总结(八十五)-- 使用WebRTC广播网络摄像头视频(下)

    本文主要介绍WebRTC (我们翻译和整理的,译者:weizhenwei,校验:blacker),最早发表在[编风网] 支持原创,转载必须注明出处,欢迎关注我的微信公众号blacker(微信ID:bl ...

  5. Xamarin.Android 使用百度地图获取定位信息

    最近做一个项目,web端使用百度地图,PDA使用手持机自带的GPS定位系统获取经纬度,然后再百度地图上显示该经纬度会有一定距离的差异,这里就像可乐的瓶子拧上雪碧的盖子,能拧的上却不美观.所以为了数据的 ...

  6. 用HTML5/CSS3/JS开发Android/IOS应用框架大全

    现在人人都想成为安卓/IOS应用开发工程师.其实,安卓/IOS应用可以用很多种语言来实现.由于我们前端开发工程师,对HTML5/CSS/JavaScript的网络编程已经相当熟悉了.所以,今天大家将会 ...

  7. Android IOS WebRTC 音视频开发总结(八十三)-- 使用WebRTC广播网络摄像头视频(上)

    本文主要介绍WebRTC (我们翻译和整理的,译者:weizhenwei,校验:blacker),最早发表在[编风网] 支持原创,转载必须注明出处,欢迎关注我的微信公众号blacker(微信ID:bl ...

  8. Android IOS WebRTC 音视频开发总结(五七)-- 网络传输上的一种QoS方案

    本文主要介绍一种QoS的解决方案,文章来自博客园RTC.Blacker,欢迎关注微信公众号blacker,更多详见www.rtc.help QoS出现的背景: 而当网络发生拥塞的时候,所有的数据流都有 ...

  9. Android IOS WebRTC 音视频开发总结(四六)-- 从另一个角度看国内首届WebRTC大会

    文章主要从开发者角度谈国内首届WebRTC大会,支持原创,文章来自博客园RTC.Blacker,支持原创,转载必须说明出处,更多详见www.rtc.help. -------------------- ...

随机推荐

  1. Memcached配置失误引发的Keystone token丢失的问题

    故障现象 近期公司的OpenStack上频繁出现虚拟机创建失败的情况,查看日志定位到问题出在neutron-server向keystone认证token失败. 故障原因 Keystone所使用的Mem ...

  2. BZOJ 5215: [Lydsy2017省队十连测]商店购物

    裸题 注意+特判 #include<cstdio> using namespace std; const int mod=1e9+7; int F[1000005],mi[10000005 ...

  3. 【Alpha】Scrum Meeting 5-end

    第一天:2019/6/19 前言: 第5次会议在6月19日由PM在教9C-501召开. 总结项目,进行单元测试并进行简单的整合.时长60min. 团队GitHub仓库 仓库连接 1.1 今日完成任务情 ...

  4. UTV - URL Tag Validation

    What`s UTV 1.URL Tag Validation 2.Special format of URL for preventing unauthorized usage and access ...

  5. Java学习笔记4---打包成双击可运行的jar文件

    写笔记四前的脑回路是这样的: 前面的学习笔记二,提到3个环境变量,其中java_home好理解,就是jdk安装路径:classpath指向类文件的搜索路径:path指向可执行程序的搜索路径.这里的类文 ...

  6. ORACLE 分区表 相关视图

    1. 显示当前用户可访问的所有分区表信息﹕ ALL_PART_TABLES 2. 显示当前用户所有分区表的信息﹕ USER_PART_TABLES 3. 显示表分区信息 显示数据库所有分区表的详细分区 ...

  7. iOS学习笔记44-Swift(四)枚举和结构体

    一.Swift的枚举 枚举是一系相关联的值定义的一个公共的组类型,同时能够让你在编程的时候在类型安全的情况下去使用这些值.Swift中的枚举比OC中的枚举强大得多, 因为Swift中的枚举是一等类型, ...

  8. 【HNOI2011/bzoj2337】XOR和路径

    第二道高斯消元练习题 题意 一张无向图,从点 $1$ 出发每次随机选一条出边走,走到 $n$ 停止,求经过的所有边权异或和的期望. $n\le 100$ 题解 注意一点,异或和的期望 $≠$ 期望的异 ...

  9. [转] Makefile 基础 (6) —— Makefile 使用条件判断

    该篇文章为转载,是对原作者系列文章的总汇加上标注. 支持原创,请移步陈浩大神博客:(最原始版本) http://blog.csdn.net/haoel/article/details/2886 我转自 ...

  10. TransactionProxyFactoryBean 配置问题

    <?xml version="1.0" encoding="UTF-8"?><beans xmlns="http://www.spr ...