读取/导入 .tpk 地图到 R 或 QGIS 并用作 shapefile

Posted

技术标签:

【中文标题】读取/导入 .tpk 地图到 R 或 QGIS 并用作 shapefile【英文标题】:Reading/importing .tpk maps into R or QGIS and use as shapefile 【发布时间】:2022-01-02 04:02:54 【问题描述】:

是否可以在 R 中导入 .tpk 地图文件>QGIS 并将其用作 shapefile?我需要 .tpk 地图 中特定位置的坐标,可以使用 shapefile 地图提取。我无权访问 ArcGIS。

感谢任何指导!

有关 .tpk 的更多信息,请参阅:https://pro.arcgis.com/en/pro-app/latest/help/sharing/overview/tile-package.htm

【问题讨论】:

有一个可以下载试用的吗?我说“R 不能这样做(还)”,因为 GDAL 不理解这里的文件:github.com/consbio/tpkutils/tree/main/tests/data - 你可以尝试使用该 python 代码转换为 GDAL 确实理解的东西...... 另请注意该存储库中有关 ESRI 更改格式(10.1 与 10.3)的评论。他们总是在移动球门柱。 感谢 python 包信息。这里有一个 .tpk 文件。如果 R 可以将其读取为 shapefile 那就太好了,这绝对是一个超出我 R 技能的项目:drive.google.com/file/d/10jfFw4ovfdfnw3qnLVsJjMSZQ8HvjTDG/… 这些是光栅数据而不是矢量数据,因此如果您的意思是线和多边形,您将无法将其“作为 shapefile”读取。它的网格图像,具有不同分辨率的不同地图。 python 代码可以以任何给定的分辨率创建地图,但 R 将所有分辨率解释为全局地图,因此在缩放 17 以查看您的研究区域时,栅格为数百万 x 数百万。考虑到边界,这可能是可裁剪的,但它仍然不是“shapefile”矢量数据。 感谢您的见解和您的时间。您是否认为使用您提到的 python 包,我可以获得这些地图的质心,或者更一般地说,这些地图中点的特定坐标?您介意分享一下我自己可以尝试的潜在方法吗? 【参考方案1】:

这是我所做的:

首先使用 tpk 转换实用程序将 tpk 文件转换为 mbtiles 来自https://github.com/consbio/tpkutils

tpk export mbtiles 04010588800801.tpk 04010588800801.mbtiles

gdalinfo 显示了有关 mbtiles 文件的一些信息:

$ gdalinfo 04010588800801.mbtiles 
Driver: MBTiles/MBTiles
Files: 04010588800801.mbtiles
Size is 23418224, 20166662
...
Metadata:
  ZOOM_LEVEL=17
...
  minzoom=0
  maxzoom=17
...

我们可以将它加载到 R 中,但它的大小非常大,我找不到基于有效图块选择给定缩放级别和给定范围的方法。我可以在命令行上使用gdal_translate 或通过gdalUtils 包来为给定缩放级别创建GeoTIFF,使用USE_BOUNDS=NO 将输出限制为仅存在瓷砖的地方:

命令行:

gdal_translate -oo ZOOM_LEVEL=17 -oo USE_BOUNDS=NO 04010588800801.mbtiles zoom17.tiff

gdalUtils 包:

gdal_translate("04010588800801.mbtiles","z17.tiff",
     oo=c("USE_BOUNDS=NO","ZOOM_LEVEL=17"))

然后可以读取并绘制这个 17 级 RGB 图像:

> z17 = raster::stack("z17.tiff")
[ignore CRS warnings...]
> plotRGB(z17)

请注意,这是一个非常高分辨率的图像,因此您无法读取标签,但如果您放大(或加载到 QGIS 并在那里进行交互),您可以读取标签。这是 QGIS 中 17 级的极端放大图,显示了分辨率的限制:

请记住,这只是光栅图像数据,因此如果您想要这些点的坐标,您必须在 QGIS 中创建一个新图层并在图像上手动创建一个点数据集。如果这是您想要的,那么我强烈建议您尝试从供应商处获取矢量数据,而不必这样做!

其他缩放级别可能对您有用,因此请使用上述gdal_translate 过程进行转换。当你出去时,你会失去细节,在 13 级以下你只会得到概览图。

16 级:

13 级:

12 级:

更新

.mbtiles 文件中读取的更直接的方法。使用stars 包,它允许您传递GDAL 选项:

s = stars::read_stars("04010588800801.mbtiles",
    options=c("USE_BOUNDS=NO","ZOOM_LEVEL=17"), proxy=FALSE)
rs = as(s,"Raster")
raster::plotRGB(rs)

proxy=FALSE 是必需的,否则当使用 as(..,"Raster") 进行转换时,输出将恢复为完整的全局 17 级缩放栅格的 20166662x23418224 维度。某处星星中可能存在的错误。无论如何,这让您无需在任何地方使用 gdal_translate 即可获得缩放的栅格。

【讨论】:

library(terra); r = rast("04010588800801.mbtiles", opts=c("USE_BOUNDS=NO","ZOOM_LEVEL=17")) 怎么样? @RobertHijmans “未使用的参数”错误与 opts。 1.3-22 ...从 CRAN (1.4.22) 获得了最新的并且可以运行,但似乎每次都没有获得正确的缩放级别 - 级别 15、16、17 看起来它们都是 15 级。他们具有预期的更高分辨率,但似乎重新缩放缩放 = 15 块。错误报告? 可以分享mbtiles文件吗? dropbox.com/s/weaiqu7fkia3fbp/04010588800801.mbtiles?dl=0 我们去别处讨论?【参考方案2】:

基于@Spacedmans 的回答并使用他创建的tpk 文件,我使用terra 包显示了一系列缩放级别

library(terra)
plotm <- function(zoom, e=NULL) 
    # read file with GDAL options
    r = rast("04010588800801.mbtiles", opts=c("USE_BOUNDS=NO", paste0("ZOOM_LEVEL=",zoom))); 
    # declare the RGB channels
    RGB(r) <- 1:4
    plot(r, ext=e)

par(mfrow=c(3,3))
x <- lapply(6:14, plotm)

这里使用范围放大一点,以便能够更好地看到最高分辨率下的差异

par(mfrow=c(2,2))
e <- ext(3935206, 3935662, 1085835, 1086294)
x <- lapply(14:17, plotm, e=e)

这在 ArcMap 中看起来与原始 tpk 文件相同。

【讨论】:

以上是关于读取/导入 .tpk 地图到 R 或 QGIS 并用作 shapefile的主要内容,如果未能解决你的问题,请参考以下文章

将 imageCollection 从 Google 地球引擎导入到 QGIS - 如果代码和 crs 似乎没问题,为啥地图不会出现在画布上?

ArcGIS创建tpk切片缓存

Arcgis 生成离线地图(.tpk)

利用QGIS下载地图数据

谁能教教怎么用ArcGIS10.1制作一个简易地图,是个宿舍的地图,做成tpk格式的

使用 pycollada 制作 3d 线条