win7搭建openStreetMap地图

来源:互联网 发布:中外哲学家名言 知乎 编辑:程序博客网 时间:2024/06/05 18:48

一、 参考资料:

https://blog.gmem.cc/setup-openstreetmap-serverhttp://www.v5cn.cn/?p=167http://www.tuicool.com/articles/ba6vEn

二、系统架构:



上图中红色部分为本文主要使用的组件,我们把这些组件全部安装到一个目录%OSM_STACK%下


三、下载安装:

1、地图数据下载

地图数据源网上有很多,这里给出其中一个数据源:

区域地图,可从这里下载:http://download.geofabrik.de/

全球地图,可从这里下载:http://ftp.heanet.ie/mirrors/openstreetmap.org/planet/2015/planet-150105.osm.bz2

2、安装Python

安装Python 2.7.x到%OSM_STACK%\python,并加入PATH环境变量,下载地址:https://www.python.org/ftp/python/2.7.9/python-2.7.9.msi

为避免后续需要下载依赖的模块,可以安装便携版的Python,集成了很多常用模块,安装后把App目录里面的所有文件拷贝到%OSM_STACK%\python即可,下载地址:http://ftp.osuosl.org/pub/portablepython/v2.7/PortablePython_2.7.6.1.exe

3、安装PostgreSQL和PostGIS

最好下载PostgreSQL 9.0以上或者 8.3版,8.4存在性能问题。

9.4的下载地址:http://get.enterprisedb.com/postgresql/postgresql-9.4.0-1-windows-binaries.zip,解压到%OSM_STACK%\psql

下载PostGIS:http://download.osgeo.org/postgis/windows/pg94/postgis-bundle-pg94x32-2.1.5-2.zip,解压覆盖到%OSM_STACK%\psql

注意:上述的PostgreSQL是绿色版的,对MSVC12有C运行时库、C++标准库有依赖,如果你的机器缺少msvcp120.dll、msvcr120.dll这两个DLL,可以下载:Visual C++ Redistributable Packages for Visual Studio 2013并安装,亦可直接拷贝这两个文件到%OSM_STACK%\psql\bin下

打开%OSM_STACK%\psql\data\postgresql.conf,修改以下参数,以提高性能(根据硬件配置调整):


4、下载osm2pgsql­

osm2pgsql­——是由OpenStreetMap开发的一个命令行工具负责将OSM数据导入到基于PostgresSql的Postgis的数据库中。下载地址:http://customdebug.com/osm/osm2pgsql.zip,其次我们还要指定osm2pgsql的gitHub地址因为我们需要的两个文件在里面可以找到一个是900913.sql一个是default.style,osm2pgsql在github的地址如下:https://github.com/openstreetmap/osm2pgsql

需要指出的是:在github中最新版本的osm2pgsql已经没有900913.sql这个文件,需要在github历史版本中去寻找。

OSM数据导入到Postgresql数据库:

第一步:创建一个Postgresql的数据库

打开命令行输入createdb -U postgres -E UTF8 osm其中osm是数据库的名称,postgres是数据库的用户名。执行完成后我们打开pgAdmin III客户端刷新,就可以看到刚才创建的数据库。

第二步:安装language plpgsql

createlang -U postgres plpgsql osm

一般这一步都不需要,默认已经安装上去了。

第三步:添加PostGIS功能到数据库,执行如下命令:

psql -U postgres -d osm -f “你PostgreSQL安装路径/share/contrib/postgis-2.1/postgis.sql”

控制台会打印下一些命令。

第四步:添加EPSG: 900913支持

上面提到过在osm2pgsql的github上包含900013.sql的文件下载到本地。放到一个好访问的目录中,执行如下命令:

psql -U postgres -d osm -f “本地的文件路径/900913.sql”

第五步:添加OSM数据到数据库

下载github上的osm2pgsql中的default.style文件并拷贝到本地osm2pgsql的x64目录中,把下载的chain.osm.bz2文件解压得到的chain.osm文件也拷贝到osm2pgsql的x64目录中。

新打开一个命令行进入osm2pgsql的x64目录中,执行如下命令:

osm2pgsql -U postgres -d osm -s -S ./default.style ./china.osm


5、安装mapnik ­

从http://mapnik.org/pages/downloads.html下载mapnik的windows版本即Windows 32 bit SDK,安装(或解压,好像是绿色版,不用安装)到%OSM_STACK%\mapnik,将其bin、lib目录加入PATH环境变量,python\2.7\site-packages加入PYTHONPATH环境变量。

在mapnik中,一个Map可以包含若干个图层(Layer),每个层可以独立着色,即可为每个层定制样式(Style),每个样式由若干个规则组成(Rule),每个规则由是由若干个符号定制。

6、安装cygwin模拟linux环境

以下的配置或文件生成需要用到linux环境,所以先安装cygwin.

注:cygwin中安装插件代码为:apt-cyg install  **,  如 apt-cyg  install  unzip,所以先看看怎么使用apt-cyg

7、安装和配置TileStache

TileStache作为网络地图服务,类似于apache的功能,只是她提供的是地图服务。WMS协议的服务器

安装便携版Python后,只需要执行下面的脚本:


在Windows上,如果使用的是Python 2.7.6,需要修改一下__init__.py的源码,否则运行时会报错:UnicodeDecodeError: utf8 codec can't decode byte 0xb0 in position 1: invalid start byte,这是Python的一个BUG。


安装完毕后,通过下面的脚本即可启动TileStache的Web服务(基于 Werkzeug,一个WSGI工具库):


%PYTHON_HOME%替换成相应的python安装路径

其中tilestache.cfg是TileStache使用的配置文件,注意要使用utf-8编码,我们先使用下面这个做测试:



上图中的path可能要用linux的目录结构才行,所以类似/tmp/tilecache ,这是值地图的缓存地址,可以自由更改

启动TileStache后,可以通过以下几个URL来测试:


8、下载mapnik-stylesheets

mapnik-stylesheets中提供了osm的样式文件,osm.xml,它表示我们要在web服务中展示的地图style,

下载地址:https://github.com/openstreetmap/mapnik-stylesheets

同时需要下载以来包:

wgethttp://tile.openstreetmap.org/world_boundaries-spherical.tgz# (51M)    wgethttp://tile.openstreetmap.org/processed_p.tar.bz2# (391M)    wgethttp://tile.openstreetmap.org/shoreline_300.tar.bz2# (42M)    wgethttp://www.naturalearthdata.com/http//www.naturalearthdata.com/download/10m/cultural/ne_10m_populated_places.zip# (1.5 MB)    wgethttp://www.naturalearthdata.com/http//www.naturalearthdata.com/download/110m/cultural/ne_110m_admin_0_boundary_lines_land.zip# (44 KB)    

解压

tar xzf world_boundaries-spherical.tgz # creates a 'world_boundaries' folder    

tar xjf processed_p.tar.bz2 -C world_boundaries   

tar xjf shoreline_300.tar.bz2 -C world_boundaries    

unzip -q ne_10m_populated_places.zip -d world_boundaries    

unzip -q ne_110m_admin_0_boundary_lines_land.zip -d world_boundaries

这个仓库中包含了众多的小工具,generate_xml.py用于生成Mapnik的样式文件,generate_image.py用于生成图片,generate_tiles.py用于生成众多的瓦片。

此处我们将使用generate_xml.py来创建一个地图样式文件,

9、通过postgresql中的数据生成地图样式

$ cd mapnik-stylesheets/

$./generate_xml.py osm.xml china.xml--dbname openStreetMap --user postgres --accept-none

其中osm.xml是样式文件,在mapnik-stylesheets中,china.xml是将要生成的样式文件名称,openStreetMap是postgresql中的数据库(之前已把地图数据导入),postgres是数据库的用户名

执行完成后就会生成china.xml文件。

10、集成TileStache与mapnik

tilestache.cfg可以配置为这样:


tilestache.cfg改好后,启动TileStache Web服务,浏览器打开http://127.0.0.1:5539/osm/preview.html进行测试

11、通过前端API使用OSM瓦片

使用Leaflet

Leaflet是一个近来迅速流行的JavaScript库,比起OpenLayers它更小小巧、简单,对于简单寻常的需求,Leaflet是个好的选择。



以上如有不对之处,请参考参考资料(篇顶处)!!!!!

0 0
原创粉丝点击