zoukankan      html  css  js  c++  java
  • [原]在GeoServer中为OpenStreetMap数据设置OSM样式

    转载请注明作者think8848和出处(http://think8848.cnblogs.com)

    在前面几篇文章中,我们讲到了部署Postgresql,部署PostGis部署GeoServer以及部署osm2pgsql并导入openstreetmap数据,现在到了发布和呈现OSM数据的时候了,今天我们先来个简单的,使用开源的样式文件呈现地图,本文主要参考了这里

    1. 创建图层数据表

    到目前为止,chinaosmgisdb中包含了planet_osm_line,planet_osm_point,planet_osm_polygon和planet_osm_roads四个数据表,我们要为各个图层分别配置样式,就应该为这些数据归归类,方法有两种,一是使用这四个基础数据表中再创建新的数据表,二是以这四个表为基础,创建视图(View),效果都一样,不过视图在应用时会慢点,我的CPU太低级,但是硬盘还凑合,所以我们采用第一种方式吧。

    先下载本文中将用到的各种脚本和批处理文件osmsld.zip,然后放到合适的位置解压

    wget -O osmsld.zip http://files.cnblogs.com/files/think8848/osmsld.zip

    unzip osmsld.zip

    现在就可以正式创建图层表了,登录postgres用户,然后使用chinaosmgisdb的owner(你想要在GeoServer中使用的那个用户运行SQL脚本文件),不要使用无关用户,不然后面你得一个个得去修改权限。

    su postgres
    
    psql -U think8848 -W -d chinaosmgisdb -a -f /tmp/osmsld/create_tables.sql

    倒也没有非常慢,大概2分钟生成完了,我们来看一下数据库结构,可以看出来比之前多了不少表出来。

    2. 在GeoServer中创建工作空间和数据源

    不好描述过程,直接上图

    创建工作空间

    创建数据源

    3. 创建样式和图表

    可以手动创建,也可以使用批处理文件自动创建,样式和图表加起来近50个,你选哪个?反正我选自动创建了

    回到GeoServer的服务端,将之前我们下载的osmsld.zip文件中的sld.zip解压开 unzip sld.zip ,然后稍修改下SLD_create.sh文件,主要是修改GeoServer的REST API相关参数,如下:

    通常而言,既然是REST服务了,应该远程和本地调用都没有问题,然而在本例中,经实测,发现localhost可以,如果在另一台linux上远程调用REST服务,会出现错误,导致不能创建图层,原因以后在查吧,先使用本地调用。

    在本文件的最下面,也修改点内容,将两行暂不用的命令注释掉,如下:

    然后进入刚才解压sld.zip形成的sld目录 cd sld ,然后调用以下命令

    sudo sh /tmp/osmsld/SLD_create.sh

    看到上面这个画面就说明成功了。

    如果整个过程顺利应该就可以在GeoServer的图层和样式里面能看到结果了:

    图层

    样式

    如果你的点比较低,很有可能只能看见样式,而看不见图层,那最好找找原因,得新来一遍,osmsld.zip包中有一个SLD_delete.sh文件可以自动帮你清理刚才的工作,不过貌似它清理过头了,把工作空间和数据源也给清掉了,因为我都在测试环境下在用,所以会看到在清理后工作空间和数据源里面空空如也,所以SLD_delete.sh批处理文件慎用,不要将你其他有用的东西删掉了!!!

    在使用SLD_delete.sh之前,照例先修改下其配置,如下:

    4. 创建图层组

    执行到上一步,应该是可以看到图层样式了,但是那只能显示整个地图的一个层,我们还需要建个完整的图层组,用来展示完整地图,同样手动方式和自动方式让你选,你选哪个?

    我还是用自动方式吧

    先做个准备工作,打开osmsld.zip包中的layergroup.xml文件,将ocean这一节给删掉,为啥要删呢?因为我们并没有导入海图数据,因我电脑太搓的原因,今天时间有限,不导ocean数据了,另找时间专门开贴导ocean数据吧

    随后打开SLD_create.sh,滚动到最底部看一眼,我们要照着这两行命令创建图层组

    查看建好的图层组:

    包含图层:

    最后,如果想使用命令删除掉这个图层使用下列命令即可

    curl -v -u admin:111111 -XDELETE http://localhost:8080/geoserver/rest/workspaces/chinaosm/layergroups/osm

    5. 添加地名中文字体

    进行完上一步操作后,在Layer Preview中就可以预览地图了,但是地名的显示字体不一定是我们想要的,所以接下来我们看看如果添加相要的字体,如微软雅黑,设置字体部分参考了这里

    首先,给GeoServer所在的CentOS7安装微软雅黑,从Windows操作系统的C:WindowsFonts中复制微软雅黑,放到一个指定文件夹中,就会得到一两个文件:msyh.ttf、msyhbd.ttf,将这两个字体打包到一个zip文件夹中,然后想办法弄到CentOS的/tmp文件夹中。怎么弄自已想办法(我为了方便,在Windows上弄了个web服务器,这样不论怎么折腾虚拟机,服务器上的东西都可以使用)

    安装字体管理工具

    sudo yum install  fontconfig mkfontscale -y

     创建字体目录,并且将msyh.ttf和msyhbd.ttf复制到字体目录中

    sudo mkdir -p /usr/share/fonts/win
    
    sudo mv msyh.ttf msyhbd.ttf /usr/share/fonts/win

    建立字体索引信息,更新字体缓存

    cd /usr/share/fonts/win
    
    sudo mkfontscale
    
    sudo mkfontdir
    
    fc-cache

    然后重启系统, reboot ,重启好后先查看服务器状态,由原来28个字体可用变为30个字体可用了,good!看一眼

    打开GeoServer的Styles菜单,查找到highway-label样式,并打开编辑,将其中的样式内容复制到notepad中,然后全使用Ctrl + H将所有“DejaVu Sans”替换成"微软雅黑",再将notepad中的样式复制到样式编辑器中,然后点击Validate验证,如果没有错误就可以保存了。

    最后,我们在Layer Preview中使用OpenLayers预览一下地图吧

    ------------------------2016年12月30日更新------------------------

    这是经过专业配图后的样式(我们称之为“午夜蓝”Y(^_^)Y)

    ------------------------2016年12月30日更新结束------------------------

    最后让我们来对比一下OpenStreetMap,左边是我刚发布的图,右边是OpenStreetMap在线地图,貌似还有不少的差距,但是总算是有个良好的开端了:)

  • 相关阅读:
    文本框textarea根据输入内容自适应高度 和输入中文和数字换行解决方法
    switch 和 if...else if 的区别
    vue中 eCharts 自适应容器
    AJAX跨域POST发送json时,会先发送一个OPTIONS预请求
    获取鼠标和元素的坐标点
    vue2 数据交互 vue-resource
    网站代码初始化
    vue2 关于ref
    事件监听
    cookie 的 写入,读取, 删除
  • 原文地址:https://www.cnblogs.com/think8848/p/6013939.html
Copyright © 2011-2022 走看看