(数据科学学习手札158)基于martin为在线地图快速构建精灵图服务

本文示例代码已上传至我的Github仓库https://github.com/CNFeffery/DataScienceStudyNotes

1 简介

大家好我是费老师,martin作为快速发展中的新一代开源高性能 地图服务框架,在之前的两篇文章中,我已为大家分别介绍过使用martin快速发布矢量切片地图服务https://www.cnblogs.com/feffery/p/17581158.html )以及字体切片服务https://www.cnblogs.com/feffery/p/17846899.html )的相关教程。

而在基于MaplibreMapbox等高性能地图框架构建地图应用时,使用一整张集成了多个图片信息的精灵图Sprite )来代替单独请求 各个图标文件,可以在地图应用需要渲染类型众多的图标时,大幅度提升相关资源的网络请求加载速度(精灵图示例如下):

而想将原始的众多图片,转换为类似上图所示的一整张精灵图并附带生成对应的索引信息,传统的方式都比较繁琐。而在今天的文章中,费老师我就将为大家介绍如何基于martin,仅通过一行命令就搞定从精灵图动态生成,到部署为直接可用服务的全过程😎~

2 利用martin快速构建精灵图服务

本文演示所使用的martin版本为0.13.0

有关martin的环境配置、安装及版本升级,请移步我先前的相关文章,这里不再赘述。

直接使用martin命令,我们只需要通过参数--sprite来指定存放精灵图原始文件的路径即可,下面举个实际案例,我在设施点目录下存放了若干个svg格式的图标文件:

在此基础上,只需要执行martin --sprite ./设施点命令,就直接启动了相关的服务:

默认参数下,访问http://127.0.0.1:3000/catalog,即可看到有关精灵图的相关资源目录信息:

其中,sprites下的键名即为对应精灵图的id,据此,我们可以访问http://127.0.0.1:3000/sprite/精灵图id.png来查看对应的目标精灵图:

而访问http://127.0.0.1:3000/sprite/精灵图id@2x.png则可以看到高精度版本的目标精灵图:

将后缀名更换为json则可以直接获取到相对应的精灵图索引信息:

而在命令中使用多个--sprite参数来指定多个路径,即可同时架起多个独立的精灵图服务,非常的方便:

在此基础上,我们就可以直接在MaplibreMapbox等地图框架中直接使用了,下面是一个简单的地图应用示例,全部数据及源码你可以在文章开头的仓库地址 中找到,按照requirements.txt使用pip安装相关依赖后,直接python app.py即可启动该应用:


以上就是本文的全部内容,欢迎在评论区与我进行讨论~

相关推荐
Modify_QmQ3 天前
leaflet【十一】地图瓦片路径可视化
gis·vue3·leaflet·leafletmapblock
杨超越luckly3 天前
ArcGISPro应用指南:ArcGISPro制图全流程详解
arcgis·信息可视化·gis·制图·arcgispro
一个有理想的摸鱼选手4 天前
CesiumLite-开箱即用的轻量化三维地图包(持续更新中...)
gis·cesium
小艳加油17 天前
生态环评GIS/遥感制图:土地利用+植被覆盖+土壤侵蚀+水系提取,ArcGIS+ENVI实战
gis·遥感解译·环境影响评价
疯狂学习GIS23 天前
ArcGIS工具操作报错999999的通用处理方式
arcgis·gis·rs·学术工作效率·遥感数据
小艳加油1 个月前
GIS应用攻略:全面涵盖GIS基础、ArcGIS操作、数据制备、空间分析、地图制作、三维建模与多领域实战应用,助力科研与行业实践!
arcgis·gis·空间分析·数据制备
阿怼丶1 个月前
🚀 如何在内网中运行 Cesium?基于 NestJS 构建离线地形与影像服务
前端·gis
疯狂学习GIS1 个月前
数据分析必备:GPS轨迹、软件签到、手机信令数据获取方式合集
gis·学术工作效率·gis数据
Dorian_Ov01 个月前
ArcGIS/geosceneAPI学习01
gis
山人在山上1 个月前
达梦 空间数据库扩展记录
gis·达梦数据库