非常好用的开源矢量地图切片工具

一直在研究矢量瓦片相关内容,想找一款比较稳定的切片工具比较费劲,看了很多设计,建议用四叉树开发,或者是开源工具,在qgis里有个mbtiles切图的工具,用了一下也还可以。试了一下geowebcache直接把服务器磁盘切挂了,数据量并不大。就在网上四处寻摸,终于功夫不负有心人,mapbox api可以直接上传数据然后切图在线效率不高,而且数据保密嘛,先跳过,直接进入mapboxtippcanoe这个开源工具,c++写的软件包很小,切图性能很稳定,关键是快,飞一般的快。能想象我切北京全市的建筑物4-14级只用几秒吗。

tippcanoe安装部署超级简单。功能很强大。

矢量地图切片

使用tippecanoe 进行矢量地图切片,切片格式由geojson转为pbf

1. 安装

  • 需求Linux环境
  • 需要 sqlite3, zlib两个库文件

1.1 安装库文件支持

#安装make
sudo apt-get install build-essential libsqlite3-dev zlib1g-dev

1.2 安装tippecanoe

#下载
wget https://github.com/mapbox/tippecanoe/archive/1.34.3.tar.gz

#解压
tar -zxvf 1.34.3.tar.gz

#编译及安装
cd tippecanoe-1.34.3/
make
make install

#下载
git clone https://github.com/mapbox/tippecanoe.git

#编译及安装
cd tippecanoe
make && make install

1.3 验证是否安装成功

tippecanoe -v

2. 一般数据生产使用

tippecanoe -e [文件夹名称] -z [最大缩放等级] -Z [最小缩放等级] -pC XX.geojson

tippecanoe -e test -s EPSG:3857 -z 20 -Z 18  -pC polygon.geojson
//批处理
for i in `ls`;do tippecanoe -e ${i%_*} -s EPSG:3857 -z 20 -Z 18  -pC $i;done

将polygon.geojson文件进行矢量切片,传入的坐标系为3857,切片等级12-18,切片生成的目录名称为test,不使用geobuf压缩

2.1 Geojson数据转换成mbtiles数据(测试通过)

接下来就是进行矢量瓦片的生成部分, Tippecanoe为用户提供了多种切片配置参数,如缩放级别、要素简化程度、筛选要素等,也可以选择输出mbtiles矢量瓦片数据集或pbf矢量瓦片文件两种格式,详细的参数说明可以参考说明https://github.com/mapbox/tippecanoe/blob/master/README.md

# 80M=>17M
tippecanoe -z14 -pS -g3 -r1.25 -o jianzhuwu.mbtiles jianzhuwu.geojson
#切片到目录
tippecanoe -z14 -pS -g3 -r1.25 -e jianzhuwu jianzhuwu.json

tippecanoe -z14 -pS -g3 -r1.25 -s EPSG:3857 -o jianzhuwu.mbtiles jianzhuwu.geojson

其中各参数的配置参考上述链接,这里不予赘述。有一点值得注意的是,如果在上文数据源shp的投影设置为EPSG:4326,这里就可以不通过-s命令进行投影设置,因为默认采用的就是EPSG:4326;而如果上文采用EPSG:3857,这里就需要进行-s EPSG:3857进行投影设置。(注意:矢量切片配置参数的搭配要按照项目的实际需求进行不同的设置!)

       在完成上述命令后,可以在对应的文件夹中看到yourData.mbtiles矢量瓦片数据集,如果是linux系统,直接可以通过sqlite3进行查看。

# 80M=>7M
tippecanoe -zg -pS -o jianzhuwu.mbtiles jianzhuwu.geojson

tippecanoe -zg -pS -e 0104 jianzhuwu.geojson

切成按zoom级别分割的文件夹

注意:source-layer填如入参的geojson文件名

sources: {
  jianzhuwu: {
    type: 'vector',
    tiles: [
      'http://127.0.0.1:8085/1/2/3/915e6641-a14c-4222-a658-be0eb995a852/{z}/{x}/{y}.pbf'
    ],
  }
},
layers: [{
  "id": "jianzhuwu",
  "type": "fill",
  "source": "jianzhuwu",
  "source-layer": "23de09937f324c5e8c0c49eeecf95734",
  "paint": {
    "fill-translate-anchor": "map",
    "fill-color": "rgba(8, 179, 225, 1)"
  }
}]

3. 常用选项

通常情况,我们需要将geojson文件转换为geobuf。

使用方法为:

tippecanoe -o file.mbtiles [options] [file.json file.geobuf ...]

3.1 输出格式

  • -o file.mbtiles or --output=file.mbtiles:输出mbtiles文件
  • -e directory or --output-to-directory=directory:输出文件至指定 目录
  • -f or --force:如果mbtiles文件已存在,则删除它
  • -F or --allow-existing:如果已经存在对应的文件,不删除已存在的文件

3.2 切片描述与水印

  • -n name or --name=name: (默认)生成XXX.json作为可读的切片描述
  • -A text or --attribution=text: 切片水印
  • -N description or --description=description: 生成XXX.mbtiles作为切片描述

3.3 输入文件和图层名称

  • name.json or name.geojson: 将geojson的 name 写入图层名称,命名为 name
  • name.geobuf or name.geobuf: 将geobuf的 name 写入图层名称,命名为 name
  • -l name or --layer=name: 使用指定的名称而不是输入文件名称作为图层名称
  • -L name:file.json or --named-layer=name:file.json: 对每一个文件指定图层名称

3.4 输入文件的投影

  • -s projection or --projection=projection: 指定输入文件的坐标系 EPSG:4326 (默认WGS84) and EPSG:3857 (Web Mercator). 通常情况下,使用WGS84作为输入文件的坐标系

3.5 缩放等级

  • -z zoom or --maximum-zoom=zoom: 最大缩放等级
  • -zg or --maximum-zoom=g: 默认使用估算合理的最大缩放等级
  • -Z zoom or --minimum-zoom=zoom: 最小缩放等级
  • -ae or --extend-zooms-if-still-dropping: 如果最小要素依然存在,增大最大的缩放等级

3.6 切片分辨率

  • -d detail or --full-detail=detail: 最大缩放等级的分辨率(默认 12级, 切片分比率 2^12=4096)
  • -D detail or --low-detail=detail: 较低等级的分辨率(默认 12级, 切片分比率 2^12=4096)
  • -m detail or --minimum-detail=detail: 最小的分辨率(默认7级)

3.7 属性表过滤器

  • -x name or --exclude=name: 移除所有要素对应的指定字段
  • -y name or --include=name: 移除所有空字段要素
  • -X or --exclude-all: 移除所有属性字段,只保留几何字段
  • -T attribute:type or --attribute-type=attribute:type: 改变指定字段的类别:string, float, int, bool.
  • -j filter or --feature-filter=filter: 字段过滤,"*"表示使用所有图层,使用mapbox过滤函数
  • -J filter-file or --feature-filter-file=filter-file: 和"-j"一样,只不过从文件中过滤

字段过滤example:

tippecanoe -z 5 -o filtered.mbtiles -j '{ "ne_10m_admin_0_countries": [ "all", [ "<", "scalerank", 3 ], [ ">", "LABELRANK", 5 ] ] }' ne_10m_admin_0_countries.geojson

3.8 线、面的简化

  • -S scale or --simplification=scale: 容差
  • -ps or --no-line-simplification: 无线简化
  • -pS or --simplify-only-low-zooms: 在高缩放等级时不简化
  • -pt or --no-tiny-polygon-reduction: 不合并面

3.9 公共面边界优化

  • -ab or --detect-shared-borders: 检测公共边界并简化
  • -aL or --grid-low-zooms: 线、面吸附

3.10 裁剪切片边界

  • -b pixels or --buffer=pixels: 缓冲区(默认5,2^5=32)
  • -pc or --no-clipping: 不裁剪
  • -pD or --no-duplication: 无重复

3.11 切片要素重排

  • -pi or --preserve-input-order: 以输入顺序作为绘制顺序
  • -ao or --reorder: 所有同属性要素按顺序重排
  • -ac or --coalesce: 合并具有相同属性的相邻线、面
  • -ar or --reverse: 合并相邻但反向的线段

3.12 增加计算的额外字段

  • -ag or --calculate-feature-density: 增加字段tippecanoe_feature_density, 用于描述切片中的要素密度

3.13 修复破损几何

  • -aw or --detect-longitude-wraparound: 检测相邻点,并修复几何

3.14 切片大小设

  • -M bytes or --maximum-tile-bytes=bytes: 切片大小指定(默认500k)
  • -pf or --no-feature-limit: 切片要素数量限制(默认20W)
  • -pk or --no-tile-size-limit: 不使用切片大小限制
  • -pC or --no-tile-compression: 不使用PBF压缩(此处必须选择,否则mapbox无法使用)
  • -pg or --no-tile-stats: 不生成切片信息

3.15 临时储存

  • -t directory or --temporary-directory=directory: 临时目录,如果未指定,使用/tmp.

3.16 结果指示器

  • -q or --quiet: 静默模式
  • -v or --version: 返回Tippecanoe版本号
  • 0
    点赞
  • 17
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
Geotools是一个开源的地理信息系统(GIS)工具包,可以用于处理和分析空间数据。其中一个常见的应用是矢量切片矢量切片是指将矢量数据切割成一系列较小、更容易处理的区域。它的目的是提高地图渲染的效率和用户体验。当地图中的矢量数据量较大时,直接渲染整个地图可能会导致加载时间延长和性能下降。因此,将地图切割成小的区域(矢量切片),只在需要时加载和渲染,可以提高地图的加载速度和交互性能。 Geotools提供了一些方法和工具来实现矢量切片。首先,可以使用Geotools库中的矢量数据读取功能,将需要切片矢量数据加载到内存中。然后,可以使用Geotools的几何处理工具(Geometry Processors)来对矢量数据进行切割操作。可以根据空间范围、图层、缩放级别等条件来定义切割规则。 一旦完成矢量切片,可以使用Geotools库中的地图渲染功能来加载和显示切片。可以根据用户的视口和缩放级别动态加载和显示不同的切片。此外,Geotools还提供了一些辅助工具,如矢量样式化(styling)、标注(labeling)和符号化(symbolizing),可以在地图上添加各种标记和样式。 综上所述,Geotools提供了一套方便且强大的工具来实现矢量切片。通过矢量切片,可以提高地图的性能和渲染效果,使用户能够更快速、流畅地浏览和交互地图数据。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值