开源方案搭建可离线的精美矢量切片地图服务-6.Mapbox之.pbf字体库

Posted attuing

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了开源方案搭建可离线的精美矢量切片地图服务-6.Mapbox之.pbf字体库相关的知识,希望对你有一定的参考价值。

项目成果展示(所有项目文件都在阿里云的共享云虚拟主机上,访问地图可以会有点慢,请多多包涵)。

01:中国地图:http://test.sharegis.cn/mapbox/html/3china.html

02:德国-德累斯顿市:http://test.sharegis.cn/mapbox/html/6germany.html

1.为什么要使用.pbf格式的字体库

     .pbf全称Protocal Buffers,是Google公司开发的一种数据描述语言,类似于XML能够将结构化数据序列化,可用于数据存储、通信协议等方面。简单来说就是结构简单、速度快,我们前面讲到的矢量切片也使用了这种格式。

    我们常见的字体库例如微软雅黑的.ttf字体文件大约有15M,一次请求加载15M并且还要解析,对服务端和客户端的压力都大,所以Mapbox使用了.pbf的格式进行分批请求,下面是两种格式的对比。.pbf格式大大的减少了请求压力。

技术分享图片

技术分享图片

2.pbf格式的字体库的生成

1.使用node-fontnik工具进行转换,具体参考https://www.jianshu.com/p/23634e54487e这篇文章。

2.使用Arcgis pro进行转换,Arcgis pro包含基于Mapbox企业级的矢量切片方案,要收费,但是有20天试用,大家可以试一下,我会在下篇进行详细分析。我自己使用的自己就是通过这种方式获取的。

3.分享一些常用.pbf字体库

我在一些Mapbox群里,大家离线部署Mapbox js遇到最主要的问题就是字体库弄不下来,这里我分享几个常用字体库。

SimSun Regular(宋体):https://pan.baidu.com/s/1lv69EP5QlaUnlKZlH4-qlA

Microsoft YaHei Regular(雅黑):https://pan.baidu.com/s/1-tJr-PpKSFRxlfhWwtc0Kw

Microsoft YaHei Bold:https://pan.baidu.com/s/1Ls1hgLIbcu5impJ086x5DQ

Arial Regular:https://pan.baidu.com/s/102-e8pYKB2CO9bvP3LvWug

4.Mapbox中调用字体

字体引用

style 中添加请求路径,fontstack就是字体文件夹的名称,range就是文件名,这些请求Mapbox会自动给我们完成。

"glyphs": "../fonts/{fontstack}/{range}.pbf",

具体给symbol添加字体的方式

{
     //郊区
     "id": "place-suburb",
     "type": "symbol",
     "source": "germany",
     "source-layer": "gis_osm_places_07_1",
     "minzoom": 10,
     "maxzoom": 16,
     "filter": [
         "==",
         "fclass",
         "suburb"
     ],
     "layout": {
         "text-field": "{name}",
         "text-transform": "uppercase",
         "text-font": [

              //这个就是{fontstack},也就是字体文件夹的名称
             "Microsoft YaHei"
         ],
         "text-letter-spacing": 0.15,
         "text-max-width": 7,
         "text-padding": 3,
         "text-size": {
             "base": 1,
             "stops": [
                 [
                     11,
                     11
                 ],
                 [
                     15,
                     18
                 ]
             ]
         }
     },
     "paint": {
         "text-halo-color": "hsl(0, 0%, 100%)",
         "text-halo-width": 1,
         "text-color": "hsl(230, 29%, 35%)",
         "text-halo-blur": 0.5
     },
     "interactive": true
},

 

5.总结

     本文主要分享了一些适用Mapbox 的.pbf字体库,下篇我们主要讲一下企业级Arcgis Pro 发布矢量切片服务的方法,他会将Mapbox所需的所有离线文件生成。可以借鉴一下企业级服务是如何构建的。

待续。。。。。。。。。。。。。。。。。。。。。

作者:ATtuing

出处:http://www.cnblogs.com/ATtuing

本文版权归作者和博客园共有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文链接。

以上是关于开源方案搭建可离线的精美矢量切片地图服务-6.Mapbox之.pbf字体库的主要内容,如果未能解决你的问题,请参考以下文章

开源方案搭建可离线的精美矢量切片地图服务-1.开篇(附成果演示地址)

开源方案搭建可离线的精美矢量切片地图服务-6.Mapbox之.pbf字体库

搭建可离线的精美矢量切片地图服务

C#拼接地图瓦片

osm 搭建离线地图_搭建开源地图服务 - 利用OSMGIS和iD

百度开源地图服务器搭建