SVTiles 是由 SuperMap 制定的一种利用 SQLite 数据库存储矢量瓦片数据的存储格式。

 SVTiles 文件的命名由地图名、Hashcode、瓦片的宽和高及.svtiles 后缀组成(如:China_-678451788_256X256.svtiles)。

iServer 9D 后的版本,矢量瓦片支持风格属性信息。生成矢量缓存时,除生成SVTiles文件以外,同时也会生成.resource后缀的风格信息文件,用于存储矢量瓦片的风格属性信息。

风格信息文件也使用SQLite 数据库存储。文件的命名方式同SVTiles一致。

SVTiles 文件

.svtiles 文件、.resource文件分别通过以下表格和视图来存储、管理矢量瓦片:

metadata 元数据表

采用键值对的形式来存储矢量瓦片数据的相关设置,包括两个文本类型的字段”name”和”value”。表结构如图所示。

元数据表的内容举例如表1所示。

1 元数据表举例

name

value

name China
version 201401
bounds

-20037508.342787,-20037508.342787,20037508.342787,20037508.342787

tile_origin -20037508.342787,20037508.342787

crs_wkid

3857
crs_wkt

PROJCS["User Define",

GEOGCS["GCS_WGS_1984",DATUM["D_WGS_1984",

SPHEROID["WGS_1984",6378137.0,298.2572235630001,

AUTHORITY["EPSG","7030"]],AUTHORITY["EPSG","6326"]],

PRIMEM["Greenwich",0.0,AUTHORITY["EPSG","8901"]],

UNIT["DEGREE",0.017453292519943295],AUTHORITY["EPSG","4326"]],

PROJECTION["Popular Visualisation Pseudo Mercator",

AUTHORITY["EPSG","1024"]],

PARAMETER["False_Easting",0.0],

PARAMETER["False_Northing",0.0],

PARAMETER["Central_Meridian",0.0],

PARAMETER["Latitude_Of_Origin",0.0],

PARAMETER["Scale_Factor",1.0],

UNIT["METER",1.0],

AUTHORITY["EPSG","3857"]]

tile_height 256
tile_width 256  
scales 1.690163e-9,3.380327e-9
resolutions

156543.033928,78271.516964

geometry_storage_type

SuperMapJson

attribute_storage_type

Json

layer_infos

[

{"Capitals": {

        "expand_pixels": 2

    },

    "Road": {

        "expand_pixels ": 2

    },

    "Provinces": {

        "expand_pixels ": 2

    }

}

]

元数据表的各字段(keys)说明如表2所示:

表2 元数据表各字段描述

字段名称 说明
name 地图的英文名称,如果地图名称为中文会自动转换为中文名称的拼音。
version 矢量瓦片数据的版本,当前版本201401。
bounds 地图的切图范围,使用的单位与地图单位保持一致。在 iServer 中 bounds 的格式为:左,下,右,上,例如:-180,-85,180,85。
tile_origin 切图原点的位置。
crs_wkid 坐标系的 EPSG Code(-1000为用户自定义坐标系,0为普通平面坐标系)。
crs_wkt 用 wkt 表示的地理坐标系信息。(wkt:由开放地理空间联盟(OGC)制定的一种文本标记语言,详见:http://docs.geotools.org/stable/javadocs/org/opengis/referencing/doc-files/WKT.html)
tile_height 瓦片高度,通常为256。
tile_width 瓦片宽度,通常为256。
scales 各级分辨率对应的比例尺集合。
resolutions 各级瓦片对应的分辨率的值。
geometry_storage_type 几何对象存储的格式。支持的格式为SuperMapJson。
attribute_storage_type 属性数据存储格式。支持的格式为Json。
layer_infos 描述各图层的元数据信息。

tiles 瓦片数据表

包括所有的矢量瓦片数据和用于定位瓦片的值。如图所示。

瓦片数据表的各值说明如表3所示。

表3 SVTiles 瓦片数据表的值说明

字段名称 数据类型 描述
resolution varchar 分辨率,瓦片对应的分辨率。
tile_colum integer 瓦片列号。

tile_row

integer

瓦片行号。
tile_id String 切片 ID。
create_time Text 创建时间。

瓦片数据集内容举例如图所示。

geometries 几何对象表

记录切片中地理要素的几何信息。如图所示

 

 

                  

几何对象表的各值说明如表4所示。

表4 SVTiles 几何对象表的值说明

字段名称 数据类型 描述

layer

Text

图层名。

fid  

Long 地理要素 ID。
tile_id

Text

切片 ID。
geometry_data Text 几何对象。

每条记录对应了一个被裁剪后的几何对象,geometry_data 存储的是像素坐标。不同级别下,同一个几何对象的像素坐标是不一样的;同一级别下,一个几何对象可能横跨多个切片(如图1所示),切片中保存的是被裁剪后的几何对象(如图2所示)。

 

图1 横跨2个切片的地理要素

图2 裁剪后的几何对象

存储格式为 SuperMapJSON,如下所示:

{

“type”:”REGION”,

“points”:[0,0,256,0,256,256,0,256,0,0,1,1,3,3,2,2,1,1],

“parts”:[5,4]

}

attributes 属性信息表

记录了地理要素的属性信息。如图所示

属性信息表的各值说明如表5所示。

  表5 SVTiles 属性信息表的值说明

字段名称 数据类型 描述

layer

Text

图层名。

fid  

Long 地理要素 ID。

attr_data

Text

属性数据。

search_values

Text 查询内容。

属性是和地理要素是一一对应的。而每个地理要素的几何对象可以分布在不同的切片中(2.3),因此 attributes 和 geometry 是1对多的关系。attr_data 的 Json 形式如下所示:

{

“NAME”:”北京”,

“PostCode”:100000,

“POP”:11510000,

“Country”:”China”

}

search_values 是以英文逗号隔开的字符串,用于快速查询。如北京的 search_values 为:“北京,100000”。按 search_values 的查询语句形式如下所示:

where search_values like ‘%北京%’

tilefeatures 视图

基于 tiles、attributes、geometies 生成的 tilesfeatures 视图。如图所示

tilefeatures 视图的各值说明如表6所示。

 表6 SVTiles tilefeature 视图的值说明

字段名称 数据类型 描述

resolution  

Double

分辨率。

tile_column  

Long 切片列号。

tile_row

Long 切片行号。

tile_id

String 切片 ID。

create_time

Text 创建时间。

layer

Text 图层名。

fid  

Integer 地理要素 ID。

geometry_data

Text 几何对象。

search_values

Text 查询内容。

attr_data

Text 属性数据。

 

 tilegeometries 视图

基于 tiles、attributes、geometies 生成的 tilesgeometries 视图用来完整地呈现 tile、tile 内部地理要素的几何信息。若不需要获取地理要素的属性信息,基于 tilegeometries 查询速度更快。如图所示:

tilegeometries  视图的各值说明如表7所示。

表7 SVTile stilegeometries 视图的值说明

字段名称 数据类型 描述

resolution  

Double

分辨率。

tile_column  

Long 切片列号。

tile_row

Long 切片行号。

tile_id

String 切片 ID。

create_time

Text 创建时间。

layer

Text 图层名。

fid  

Integer 地理要素 ID。

geometry_data

Text 几何对象。
  • SQL 清单

metadata

CREATE TABLE metadata (name text, value text);

CREATE UNIQUE INDEX metadata_idx ON metadata (name);

 tiles

CREATE TABLE tiles (resolution double, tile_column integer, tile_row integer,tile_id text, create_time

text);

CREATE UNIQUE INDEX tiles_index on tiles(resolution,tile_column,tile_row);

Create index tiles_id_index ON tiles(tile_id);

 geometries

CREATE TABLE geometries(layer text,fid long,tile_id text,geometry_data text );

CREATE UNIQUE INDEXgeometries_index ON geometries(layer ,fid,tile_id);

 attributes

CREATE TABLE attributes( layer text, fid long, attr_datatext,search_values text);

CREATE UNIQUE INDEX attrbutes_index ON attributes (layer, fid);

 tilefeatures

CREATE VIEW tilefeatures as

SELECT A.*,B.layer,B.fid,B.geometry_data,C.search_values,C.attr_data

FROM tiles as A,geometries as B,attributes as C

WHERE A.tile_id=B.tile_id and B.layer=C.layer and B.fid=C.fid

 tilegeometries

CREATEVIEW tilegeometries as

SELECT A.*,B.layer,B.fid,B.geometry_data

FROM tiles as A,geometries as B

WHERE A.tile_id=B.tile_id

  •    SVTiles V201401与 SVtiles V201310版本对比

功能对比如表8所示:

表8 SVTile 功能对比

功能

 V201310 V201401
几何对象存储  SuperMapJson 扩展规范支持多种格式 SuperMapJson、WKT、GeoJson、GML
要素属性存储 不支持  XML,Json

数据表对比如表9所示:

表9 SVTile 功能对比

版本

表说明

V201310 metadata 元数据表。
tiles 切片表。
tiles_data 字段中存储了所有的几何对象集合。
V201401 metadata 元数据表。
tiles 切片表。仅存储切片索引。
geometries 几何对象表。
attributes 属性信息表。
tilefeatures 切片及要素视图。
tilegeometries 切片及几何对象视图。

 

  •    SuperMapJson

SuperMapJson 是 SuperMap iServer 定义的一种 Json 格式。该 Json 由以下三部分构成:

 type:几何形状类型。

可选值有:POINT、LINE、REGION 分别对应 WKT 中的 MultiPoint、MultLineString、MultiPolygon。

 points:表示一组像素坐标序列,相邻两项代表一个坐标。

 parts:表示当前几何对象的分段信息,每一个分段代表一个子对象,分段的数值代表子对象点的个数。

示例:

{

“type”:”REGION”,

“points”:[0,0,256,0,256,256,0,256,0,0,1,1,3,3,2,2,1,1],

“parts”:[5,4]

}

上面示例中“parts”:[5,4]表示该对象两个分段,两个分段的坐标分别为:[0,0 ,256,0,256,256,0,256,0,0]、[1,1,3,3,2,2,1,1]。

注:对于 type 为 POINT 的几何对象,json 可不包含 parts 项。此类几何对象 points 中每一个坐标就表示一个子 POINT。

resource文件

style风格数据表

记录了每个图层的风格类型和风格描述信息。表中包含的字段如图所示:

风格信息表的各值说明如表10所示。

表10 resource文件style数据表各值说明

字段名称 数据类型 描述

layer name

Text

图层名。

type  

Text

风格类型。目前支持CartoCSS。
style

Text

风格信息。

其中style字段描述了该图层的风格属性信息。示例如下:

#District@Changchun[zoom<=9.80459446371E-5][zoom>=1.05263157895E-5]{text-placement-type:simple;text-placements:"E,NE,SE,W,NW,SW";line-pattern-file:url(SYMBOLLINE__District@Changchun__64__64__true__-1483079698.png);polygon-pattern-file:url(SYMBOLFILL__District@Changchun__64__64__true__-1483079698.png);point-file:url(SYMBOLMARKER__District@Changchun__64__64__true__-1483079698.png);polygon-opacity:1;polygon-pattern-opacity:1;}

Symbol符号数据表

记录切片中的符号图片。

符号数据表的各值说明如表12所示。

表12 resource文件symbol数据表各值说明

字段名称 数据类型 描述

id

Text

符号的标识符。id是由符号类型、所在图层、图片宽高、是否透明以及Hashcode组成

format

Text

符号图片格式。如PNG

symboldata

blob

符号图片

symbol符号数据库内容举例如图所示。