如何实现OSM地图本地发布并自定义配图

article/2025/7/22 2:27:24

文章目录

    • 1、缘起
    • 2、准备环境
      • 2.1、安装linux系统
      • 2.2、安装docker
      • 2.3、安装Docker Compose
      • 2.4、安装git
    • 3、发布地图
      • 3.1、拉取代码
      • 3.2、测试网络
      • 3.3、处理数据
      • 3.4、发布矢量瓦片服务
      • 3.5、自定义地图样式
      • 3.6、注意
    • 4、总结

1、缘起

  1. OpenStreetMap(简称OSM)不仅可以免费在线使用,还可以免费下载原始数据,数据格式有.osm.pbfshp
  2. 我们将OSM原始数据下载下来,处理成矢量瓦片,发布成服务,就可以实现OSM地图的本地发布和自定义配图。
  3. OSM对数据的组织方式,是按点、线、面来的,不是我们常见的按道路、建筑物、河流来分图层的方法,但可以根据属性进行提取。
  4. openmaptiles提供了一套OSM数据使用的完整解决方案,可以实现OSM数据的下载、入库、分析、生成矢量瓦片、调整地图样式、地图预览的全套功能,并且开源。
  5. 接下来我们就来详细介绍openmaptiles开源库如何安装和快速入门。

2、准备环境

  1. 安装linux系统(openmaptiles开源库只能在linux系统上运行)
  2. 安装docker
  3. 安装Docker Compose
  4. 安装git

2.1、安装linux系统

  1. 我是在虚拟机上安装的,虚拟机和linux系统的安装教程参考:https://blog.csdn.net/null_of_error/article/details/108133241
  2. 虚拟机版本我用的VM14,百度网盘下载地址:https://pan.baidu.com/s/1BTjByB6oTz8cTxOv_GzGWw,提取码:kshr,含许可。
  3. linux系统我使用的是centOS7.9,阿里云官方镜像下载地址:http://mirrors.aliyun.com/centos/7.9.2009/isos/x86_64/CentOS-7-x86_64-Everything-2009.iso

2.2、安装docker

  1. 安装教程参考:https://www.runoob.com/docker/centos-docker-install.html

  2. 我用的是手动安装方式,安装步骤:

    1. 安装docker

      yum install -y yum-utils device-mapper-persistent-data lvm2
      
    2. 设置国内阿里云的镜像源,会比官方的快

      yum-config-manager --add-repo  http://mirrors.aliyun.com/docker-ce/linux/centos/docker-ce.repo
      
    3. 安装Docker Engine-Community

      yum install docker-ce docker-ce-cli containerd.io
      
    4. 启动docker

      systemctl start docker
      
    5. 测试是否安装正确

      docker run hello-world
      

2.3、安装Docker Compose

  1. 安装教程参考:https://www.runoob.com/docker/docker-compose.html

  2. 安装步骤:

    1. 安装docker compose

      curl -L "https://github.com/docker/compose/releases/download/1.27.4/docker-compose-$(uname -s)-$(uname -m)" -o /usr/local/bin/docker-compose
      
    2. 设置权限

    chmod +x /usr/local/bin/docker-compose
    
    1. 测试是否安装正确
    docker-compose --version
    

2.4、安装git

  1. 安装教程参考:https://www.jianshu.com/p/e6ecd86397fb

  2. 安装步骤:

    1. 安装

      yum install git
      
    2. 测试是否安装正确

      git --version
      

3、发布地图

openmaptiles开源库

  1. github地址:https://github.com/openmaptiles/openmaptiles
  2. 快速入门文档:https://github.com/openmaptiles/openmaptiles/blob/master/QUICKSTART.md

3.1、拉取代码

  1. 拉取openmaptiles代码

    git clone https://github.com/openmaptiles/openmaptiles.git
    
  2. 拉取完成后,进入目录

    cd openmaptiles
    
  3. 执行make命令

make 

3.2、测试网络

  1. 先测试一下你电脑能不能打开这个网址:https://www.wikidata.org/,openmaptiles需要从这个网址下载poi数据,如果不能访问,就按下面的步骤设置,让程序跳过这一步。后续想要poi的数据的,可以自行翻墙解决。

  2. 如何跳过下载poi数据:

    1. 使用vi打开quickstart.sh文件,vi使用方法参考:https://zhuanlan.zhihu.com/p/37704677

      vi quickstart.sh
      
    2. 找到 make import-wikidata 行

    3. 输入 i 进入插入模式

    4. 在 make import-wikidata 命令前输入#号,然后按 esc

    5. 输入:wq 保存退出

3.3、处理数据

执行下面的快速启动命令,程序会自动进行OSM数据的下载、入库、分析、生成矢量瓦片的工作。默认是阿尔巴尼亚地区,生成瓦片的层级是0-7级。后面会讲如何设置地区和层级。这个命令执行时间会稍微有些长,需耐心等待。

./quickstart.sh 

3.4、发布矢量瓦片服务

数据处理完成后,把生成的矢量瓦片发布成地图服务,步骤:

  1. 启动服务

    make start-tileserver
    
  2. 在自己电脑浏览器中输入虚拟机ip地址加端口8080,我电脑的地址是

    http://192.168.50.8:8080/
    
  3. 点击 view 按钮,查看效果

3.5、自定义地图样式

  1. 启动maputnik

    make start-maputnik
    
  2. 在自己电脑浏览器中输入虚拟机ip地址加端口8088,我电脑的地址是

    http://192.168.50.8:8088/
    

  3. 在刚才启动的TileServer-GL 网页中,点击下图中的TileJSON链接,然后拷贝地址

  4. 回到maputnik网页,点击下图蓝框中的按钮Data Sources,把上面的地址粘贴到绿框中,再点击红框中的删除按钮,关闭其它地图。关闭弹出框,就能看到我们发布的地图了。

  5. 接下来就可以自由奔放的自定义地图样式了

3.6、注意

  1. 中国地区的地图这样写,查看所有支持的地区

    ./quickstart.sh china 
    
  2. 建议第一次还是先使用默认的阿尔巴尼亚地区看看效果,熟悉一下流程,因为它的数据小,处理的快。中国地区会很久,也没有个进度条,第一次测试就用这么大的,极容易失去耐心。

  3. 决定数据处理时间的因素:电脑网速、电脑性能、处理数据的大小、生成瓦片的层级。

  4. 我电脑的虚拟机配置比较低,处理阿尔巴尼亚地区,0-7级数据,大概用了10分钟左右,处理台湾地区数据,等了1个小时都没有完成,最后放弃了,等换个好电脑再试。

  5. 想要全国地图的需要注意,中国地区和台湾地区的数据是分开的,需要分别进行下载和处理。

  6. 切图等级在.env文件中配置

4、总结

  1. 本文详细介绍openmaptiles开源库的安装和快速入门使用

  2. 输入下面的帮助命令,可以查看openmaptiles支持的更多功能,我们后续再写文章详细介绍

    make help
    


原文地址:http://gisarmory.xyz/blog/index.html?blog=OSMVectorTiles

关注《GIS兵器库》公众号, 第一时间获得更多高质量GIS文章。

本文章采用 知识共享署名-非商业性使用-相同方式共享 4.0 国际许可协议 进行许可。欢迎转载、使用、重新发布,但务必保留文章署名《GIS兵器库》(包含链接:  http://gisarmory.xyz/blog/),不得用于商业目的,基于本文修改后的作品务必以相同的许可发布。


http://chatgpt.dhexx.cn/article/JyQ0Qjtf.shtml

相关文章

Openlayers案例1——加载OSM地图

1. 代码块 <!DOCTYPE html> <html lang"en"><head><meta charset"UTF-8"><meta name"viewport" content"widthdevice-width, initial-scale1.0"><title>加载OSM地图</title><!-- CSS路…

Python实现OSM地图数据解析——Pydriosm

目录 1. Pydriosm简介2. 安装3. 使用方法3.1 下载数据3.2 解析文件3.3 不同geometry 类型及其数据结构 4. 总结参考 1. Pydriosm简介 Pydriosm是一个开源的OSM地图文件下载和解析工具。通过OSM官方API为研究人员/从业者提供OSM地图文件在线下载和本地OSM地图文件读取解析功能&…

将OSM地图转化成OpenDRIVE

关于OSM 以下来自百度引用&#xff1a;OpenStreetMap&#xff08;简称OSM&#xff09; 开源wiki地图&#xff0c;很多人们习以为常可以随便拿来用的地图&#xff0c;其实有很多法律和技术上的限制&#xff0c;这些限制使得像地图这类的地理资讯无法有创意、有效率地被再利用。开…

OSM地图本地发布(四)-----Geoserver发布自定义地图

一、准备工作 1. 安装jdk 1.8、tomcat 2.安装Geoserver&#xff0c;下载地址&#xff1a;https://sourceforge.net/projects/geoserver/files/GeoServer/2.19.2/ 3.自定义图层准备&#xff0c;OSM本地发布(三)-----自定义图层提取 4.下载osmsld.zip样式文件&#xff0c;链接…

OSM地图本地发布(三)-----自定义图层提取

一、准备工作 1.完成数据准备OSM本地发布(二)-----数据准备 2.推荐使用Navicat操作数据库 3.下文是在《在GeoServer中为OpenStreetMap数据设置OSM样式》基础上的改进&#xff0c;可直接看该文实现图层发布 二、OSM字段说明 planet_osm_line,planet_osm_point,planet_osm_pol…

Python实现OSM地图数据解析——OSM2Rail

目录 1. 简介2. 功能特色2.1 自动下载OpenStreetMap地图数据包2.2 提供更精确的铁路网络数据解析2.3 扩展GMNS标准 3. 快速上手4. 效果展示5. 相关阅读 1. 简介 前期为大家介绍了由美国亚利桑那州立大学ASU TransAI Lab团队开发的开源python依赖库——OSM2GMNS&#xff0c;不仅…

下载OSM地图数据

OSM数据有几种下载方式&#xff1a;1&#xff09;直接通过wget下载&#xff1b; 2&#xff09;通过官网直接导出指定区域&#xff1b; 3&#xff09;通过QGIS下载指定区域 1.通过wget下载数据 进入http://download.geofabrik.de/&#xff0c; 可以按照自己的需求下载不同国家不…

QGIS获取OSM地图矢量数据

目录 一、QGIS加载OSM底图图层 二、quickosm插件导入openstreetmap数据 三、数据导出 四、Overpass query查询用法 五、写在最后 一、QGIS加载OSM底图图层 1.安装QuickMapServices插件&#xff0c;在网络菜单下可以加载各类底图 2.插件安装后&#xff0c;通过插件打开OS…

OSM地图本地发布(一)-----概述

目录 一、前言 二、开源GIS介绍 1.前端GIS框架 2.后端技术 3.空间数据库 4.地图服务器 4.GIS软件 三、技术选型 四、文章目录 1.OSM本地发布(一)-----概述 2.OSM本地发布(二)-----数据准备 3.OSM本地发布(三)-----自定义图层提取 4.OSM本地发布(四)-----Geoserver…

中国省份/城市OSM地图数据

下载访问地址 网站截图

数据分享|2023年OSM道路数据(全国,分省,分市)

道路数据是我们在各项研究中经常使用的数据!道路数据虽然很常用,但是却基本没有能下载最近年份道路数据的网站,所以很多人不知道如何获到道路数据。 本次我们为大家推荐的下载道路数据的网站是Open Street Map!我们先来了解下Open Street Map,其简称为OSM,是一个开源的地…

基于 OSM 构建全球瓦片地图(一):概述

一、什么是OSM 开放街道地图&#xff08;英语&#xff1a;OpenStreetMap&#xff0c;缩写为OSM&#xff09;&#xff0c;其概念启发自维基百科网站&#xff0c;是一个建构自由内容之网上地图协作计划&#xff0c;目标是创造一个内容自由且能让所有人编辑的世界地图。 从2007年…

Python实现OSM地图数据解析——OSM2GMNS

目录 1. 开源地图OSM2. 数据解析方法对比3. OSM2GMNS3.1 关于GMNS数据格式3.2 安装方法3.3 使用方法3.3.1 地图数据下载3.3.2 数据解析 3.4 输出文件 4. 可视化5. 总结参考 1. 开源地图OSM OpenStreetMap&#xff08;www.openstreetmap.org&#xff09;是一款知名的开源地图数…

利用微信网页录音接口实现语音搜索

微信网页接口有3个录音相关接口 开始录音接口 wx.startRecord();停止录音接口 wx.stopRecord({ success: function (res) { var localId res.localId; } });监听录音自动停止接口 wx.onVoiceRecordEnd({ // 录音时间超过一分钟没有停止的时候会执行 complete 回调 complete…

Unity WebGL基于js通信实现网页录音

Unity WebGL基于js通信实现网页录音 由于Unity发布WebGL后无法使用Unity中的Microphone,所以无法进行录音&#xff0c;只能借助与网页进行录音操作&#xff0c;因此基于Unity新版页面对接方式jslib实现页面录音。可以将录音数据回传至unity&#xff0c;并在unity中进行播放。理…

php录音功能,h5做出网页录音功能

这次给大家带来h5做出网页录音功能,h5做出网页录音功能的注意事项有哪些,下面就是实战案例,一起来看一下。 得益于前辈的分享,做了一个h5录音的demo。效果图如下: 点击开始录音会先弹出确认框: 首次确认允许后,再次录音不需要再确认,但如果用户点击禁止,则无法录音: …

java 网页 录音_Java+FlashWavRecorder实现网页录音并上传【新】

【注意】 【说明】 1.在线录音并直接上传到服务器中 【使用】 1.运行 1.请下载本项目&#xff0c;并导入myeclipse中 2.跑起项目&#xff0c;访问http://localhost:8080/recorder-online-upload查看效果 2.定制 1.打开WEB-INF/view/index.html 2.只有两段html注释中的代码是需要…

java 网页 录音_Java+FlashWavRecorder实现网页录音并上传

【注意】 【前言】 肯定有需求要网页录音&#xff0c;并且要上传。这奇葩需求。 然后找到了FlashWavRecorder&#xff0c; 【原始版本号】 1.下载 在上面的地址下载zip解压之后&#xff0c;目录里面有个index.html。打开之后这效果&#xff1a; 2.录音权限 必须保证你的电脑有麦…

10.WebRTC实现网页录音功能

一、概述 通过WebRTC&#xff0c;实现在页面上进行录音&#xff0c;并将录音结果转换为.wav格式进行播放 二、录音实现 检测是否有麦克风权限 navigator.mediaDevices.enumerateDevices().then(function(devices) {// 检测视频输入let video devices.find((device) > {…

uniapp中使用网页录音并上传声音文件(发语音)——js-audio-recorder的使用【伸手党福利】

uniapp中上传音频只能在app或小程序当中实现&#xff0c;如何使用网页完成语音的录制和上传则成为了困扰前端童鞋的重点。 本文着重解决&#xff1a; js-audio-recorder报 error:浏览器不支持getUserMedia ! 的问题。 js-audio-recorder报 NotFoundError : Requested device no…