谈谈 WMTS 中的 TileMatrix 与 ScaleDenominator

Posted 岭南灯火

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了谈谈 WMTS 中的 TileMatrix 与 ScaleDenominator相关的知识,希望对你有一定的参考价值。


其实有时间琢磨规范文档的话,倒也不必费时间自己琢磨,这篇算是一些口水话心得。

规范文档指路:OGC Standard - Two Demensional Tile Matrix Set #6. TileMatrixSet,对,并不是 WMTS 规范,而是更精确的 2D瓦片阵列集规范,它独立于 WMTS 规范而发布。

1. WMTS 中的 TileMatrix 是什么

在我之前的文章《OGC WebGIS 常用服务标准速查》中有提过,这个其实就是一个“阵列”,形象的比喻就是一个“棋盘”,一张网格:

因为我们学习线性代数的时候矩阵就和这玩意儿长得像,所以就被称作“瓦片阵列”,即 TileMatrix。而基于同一个坐标系的多个瓦片阵列,就被称作“瓦片阵列集”(或者类似的名字,你开心就好),即 TileMatrixSet

打开 WMTS 的 XML 能力文档,看看 EPSG:4326 坐标系的第 1 级瓦片阵列定义:

<TileMatrix>
  <ows:Identifier>EPSG:4326:1</ows:Identifier>
  <ScaleDenominator>1.3977056600717944E8</ScaleDenominator>
  <TopLeftCorner>90.0 -180.0</TopLeftCorner>
  <TileWidth>256</TileWidth>
  <TileHeight>256</TileHeight>
  <MatrixWidth>4</MatrixWidth>
  <MatrixHeight>2</MatrixHeight>
</TileMatrix>

这些属性一眼看过去很容易知道其含义:

  • Identifier:这个瓦片阵列的 ID

  • TopLeftCorner:这个瓦片的左上角位置,此处是经纬度表达(基于 EPSG:4326 坐标系)

  • TileWidthTileHeight:瓦片的像素长宽,即 256 × 256 像素

  • MatrixWidthMatrixHeight:瓦片阵列的长宽;不理解的可以想象一下“矩阵”的长宽,代表这一级瓦片横向纵向跨度有多少个瓦片

最后一个没说的 ScaleDenominator,翻译过来是 比例分母,也是本文重点要介绍的东西。

2. ScaleDenominator 是什么

在回答这个问题之前,我先提 2 个问题:

  • 在早些年最具代表性的 Windows 系统使用的 96 PPI 像素的屏幕上,1 像素的尺寸是多少?

  • 一个瓦片中,1 像素表示多大经纬度或现实尺寸?

2.1. 一个像素的显示器物理尺寸是多大

回答第 1 个问题很简单,网上一搜大概就有,或者拿 23.8 英寸的 1080p 显示器大致算一下也行:

  • 23.8 英寸 1080p 显示器对角线约 2202.9 个像素

  • 23.8 英寸约为 604.52 毫米

所以 1 个像素的长宽大概是 604.52 / 2202.9 ≈ 0.274 毫米。

同理,算出 27 寸 4k(3840 × 2160)显示器的像素尺寸约为 0.156 毫米。

随着技术进步,现在的显示器面板已经把这个值进一步提高了,27 英寸的 4K 显示器都很常见,物理像素尺寸进一步缩小,而 Windows 操作系统为了显示效果,会在高分辨率屏幕中使用缩放率来提高平滑度 —— 比如,我的 4K 分辨率 27 寸显示器就使用了 200% 缩放率,也即 4 个像素(长宽各缩放 200%,即 2 个像素 × 2 个像素)作为原来的 1 个像素显示,这样 3840 × 2160 的物理分辨率就会模拟成 1920 × 1080。

2.2. 瓦片图片的一个像素是多大

看第 2 个问题。

瓦片是有等级的,想知道瓦片 1 像素的尺寸,那么就势必知道两个因子:

  • 这瓦片长宽多少像素

  • 这瓦片占的总尺寸(长宽)

以 GeoServer 内置的 EPSG:4326 瓦片阵列集定义来看,第 0 级瓦片阵列有 1 行 2 列(MatrixWidthMatrixHeight),那么一个瓦片的东西跨度应为地球周长的一半:

查资料得知地球赤道周长的值约为 400750170米,此 0 级瓦片东西向有 256 个像素,容易得知,每个像素为 (400750170 ÷ 2) ÷ 256 = 782715.17578125 米

现在有了上述的计算例子,就可以足够解释什么是 ScaleDenominator 了:

\\[ScaleDenominator_0 = \\frac782715.175781250.00028 = 2795411342.075892857 \\]

这个值与 GeoServer 中第 0 级瓦片阵列的 ScaleDenominator279541132.0143589 仅差距不到 10,从误差角度看可以认为相等(地球赤道的大小可能采用的数值略不一样)。

从公式来看,这个比例就像是在说:0.00028 米(0.28 mm)的屏幕像素尺寸,实际上是地球表面的 782715.17578125 米,所以这个比例分母也可以这么理解:

\\[\\frac地表实际尺寸ScaleDenominator=像素尺寸 \\]

说人话,这个比例分母的含义就是 “地表距离和屏幕距离的比例尺”。

2.3. 为什么是 0.28 毫米

有人会疑问你这个 0.00028 米(0.28 毫米) 是怎么来的?在文章开头引用的规范中,规定了一个 标准渲染像素尺寸 的东西,即 0.28mm 作为一个像素的长宽。

而在 2.1 小节的实际计算中,传统高清显示器的像素尺寸也就差不多是这个数值,考虑到标准制定的时间和硬件背景,使用 0.28 毫米也不足为奇了。

以上是关于谈谈 WMTS 中的 TileMatrix 与 ScaleDenominator的主要内容,如果未能解决你的问题,请参考以下文章

ArcGIS Server WMTS服务发布与使用

Vue中使用geoserver中的wmts(EPSG:900913)

Geoserver WMTS 瓦片元数据

geoserver发布地图服务WMTS

cesium加载geoserver 发布的wmts服务

ArcGIS Server10.1之服务新特性(WMTS1.0.0)