MBTiles 1.2

可以参考超图的文档MBTiles扩展

具体实现可以参考浅谈利用SQLite存储离散瓦片的思路和实现方法

mapbox提供了一个简单实现测试代码,github地址在这里https://github.com/mapbox/mbtiler.git

子标签:

  • Interaction: 实现交互所需的HTTP端点
  • UTFGrid:此规范依赖于UTFGrid 1.2进行交互.

抽象

MBTiles是在SQLite数据库中存储地图瓦片数据的规范,用于即时使用和传送.

MBTiles文件称为tilesets(瓦片集),必须实现以下规范,以确保与设备的兼容性。

数据库规格

Tilesets使用version 3.0.0或更高版本的SQLite数据库。

仅使用SQLite核心功能; tilesets 无需扩展.

MBTiles数据库可以选用官方分配幻数(magic number)去快速识别为MBTiles。

数据库

注意: 所概述的schemas尽量遵循接口。产生兼容结果的SQLite视图同样有效。

方便起见,本规范将(tables)和虚拟表(virtual tables,视图views)都当做表(tables)。

Metadata 元数据

Schema 方案

数据库需要包含名为metadata的table或view。

该表必须具有名为namevalue的两列。metadata表典型创建语句如下:

    CREATE TABLE metadata (name text, value text);

Content 内容

metadata表用作key/value存储,用于保存一些配置settings

以下五个key是必须的:

  • name: tileset的纯英文名称.
  • type: overlay(覆盖型)或baselayer(基本图层型).
  • version: tileset的版本,纯数字.
  • description: 描述图层(layer)的文本.
  • format: 瓦片数据的图像文件格式: pngjpg

rowmetadata中是推荐提供的,如有,可以提高性能。

  • bounds: 呈现的地图区域的最大范围。Bounds必须定义所有缩放级别所覆盖的区域。范围boundsWGS:84中经纬度值表示,在OpenLayers Bounds格式表示为-

    左,下,右,上.全球范围为例: -180.0,-85,180,85.

  • attribution:属性字符串,使用纯英文(和HTML)解释地图数据和(或)样式的来源.

通常的tilesets实现都支持这些附加键。

基于UTFGrid交互.

Tiles 瓦片

Schema 方案

数据库需要包含名为tiles的表.

该表必须具有zoom_leveltile_columntile_rowtile_data四列。tiles表典型创建语句如下:

    CREATE TABLE tiles (zoom_level integer, tile_column integer, tile_row integer, tile_data blob);

Content 内容

tiles用于包含瓦片和用于定位的值。

zoom_leveltile_columntile_row列在其构造中遵循

Tile Map Service规范,但受限于以下形式:

假定是global-mercator (球面墨卡托SphericalMercator)

tile_data blob列包含原始图像二进制数据.

图像文件的格式允许使用以下两种:

  • png
  • jpg

Grids 网格

有关网格和交互元数据本身的实现细节,请参阅UTFGrid规范:MBTiles规范仅涉及存储。

Schema 方案

数据库可以有可选的表gridsgrid_data

grids必须具有zoom_leveltile_columntile_rowgrid四列。grids表典型创建语句如下:

    CREATE TABLE grids (zoom_level integer, tile_column integer, tile_row integer, grid blob);

grid_data必须具有zoom_leveltile_columntile_rowkey_namekey_json五列。grid_data表典型创建语句如下:

    CREATE TABLE grid_data (zoom_level integer, tile_column integer, tile_row integer, key_name text, key_json text);

Content 内容

grids表包含UTFGrid数据,gzip压缩。

grid_data表包含grid keyvalue映射,将value编码为JSON对象。

MBTiles 1.2 规范翻译的更多相关文章

  1. [转]MBTiles 1.2 规范翻译

    MBTiles 1.2 可以参考超图的文档MBTiles扩展具体实现可以参考浅谈利用SQLite存储离散瓦片的思路和实现方法 mapbox提供了一个简单实现测试代码,github地址在这里https: ...

  2. Go语言安全编码规范-翻译(分享转发)

    Go语言安全编码规范-翻译 本文翻译原文由:blood_zer0.Lingfighting完成 如果翻译的有问题:联系我(Lzero2012).匆忙翻译肯定会有很多错误,欢迎大家一起讨论Go语言安全能 ...

  3. BSON 1.0版本规范(翻译)

    BSON 1.0版本规范 本文翻译自 http://bsonspec.org/spec.html BSON是用于存储零个或多个键/值对为一个单一的实体的一个二进制格式.我们称这个实体为文档(Docum ...

  4. JSON-RPC 2.0规范 翻译 中文版

    JSON-RPC 2.0规范 起源日期: 2010-03-26(基于2009-05-24的版本号) 修正: 2013-01-04 作者: JSON-RPC 工作组 <json-rpc@googl ...

  5. Promise/A+规范-翻译

    Promise 表示一个异步操作的最终结果,与之进行交互的方式主要是 then 方法,该方法注册了两个回调函数,用于接收 promise 的终值或本 promise 不能执行的原因. 本规范详细列出了 ...

  6. 3、LwIP协议栈规范翻译——概述

    3.概述 像许多其他TCP/IP实现一样,分层协议设计已经成为设计lwIP实现的指南.每个协议实现为自己的模块,其中几个功能充当每个协议的入口点.尽管协议层是单独实现的,一些层却不全是,正如前面所叙述 ...

  7. 4、 LwIP协议栈规范翻译——流程模型

    4.流程模型 协议实现的流程模型描述了系统被划分为不同的流程的方式.用于实现通信协议的一个流程模型是让每个协议作为一个独立的进程运行.有了这个模型,严格的协议分层被强制执行,并且协议之间的通信点必须严 ...

  8. 5、 LwIP协议栈规范翻译——操作系统仿真层

    为了使lwIP可移植,操作系统特定的函数调用和数据结构不直接在协议的代码中使用.相反,当需要这样的函数调用和数据结构时,直接使用操作系统仿真层. 操作系统仿真层为操作系统服务提供统一的接口,如定时器, ...

  9. LwIP协议栈规范翻译——摘要目录

    摘要 LwIP是一种TCP/IP协议栈的实现.LwIP协议栈专注于减少内存的使用和代码的大小,使LwIP适用于嵌入式系统中在有限的资源下能够使用小型的客户机.为了减少处理和内存的需求,LwIP使用裁剪 ...

随机推荐

  1. MongoDB资料大全

    摘要: 为了帮助大家进一步了解MongoDB,云栖社区组织翻译了GitHub Awesome MongoDB 资源,涵盖MongoDB中常见的库与工具.应用列表.以及相关的文档.教程等资源. Mong ...

  2. 使用C++ Builder XE5获取Sensor值之Light Sensor

    献上代码C++代码,仅供參考. 若使用Delphi.请參考文献,http://blogs.embarcadero.com/davidi/2013/12/02/43032/ 一定记得要安装FireMon ...

  3. Apache URL重写的配置 及其 apache500错误

    1:如果apache报500错误时 ----->原因:可能是你的ReWrite模块没有打开(有时在apache重装时会忘记打开该模块) 将apache--->httpd.conf文件中Lo ...

  4. 第三章 logstash - 输入插件之tcp与redis

    常用的输入插件: tcp redis 一.tcp 1.用法 input { tcp { port => 4560 codec => json_lines mode => server ...

  5. Python/Shell 正则表达式与运用

    正则表达式用的地方是很多的.比如字符串处理过程中.最近遇到记录一下. 1. 比如在shell中 #!/bin/bash str="date:2017-11-28 os:centos blac ...

  6. SharePoint2013 以其他用户登录和修改AD域用户密码 功能

    sharepoint默认是没有修改AD密码 和切换 用户的功能,这里我用future的方式来实现. 部署wsp前: 部署后: 点击以其他用户身份登录 点击修改用户密码: 这里的扩展才菜单我们用Cust ...

  7. 利用blob对象实现粘贴图片

    blob的一个常用应用场景,就是获取剪切板上的数据来进行粘贴的操作.例如通过QQ截图后,需要在网页上进行粘贴操作. 粘贴图片我们需要解决下面几个问题 1.监听用户的粘贴操作 2.获取到剪切板上的数据 ...

  8. [Math]理解卡尔曼滤波器 (Understanding Kalman Filter) zz

    1. 卡尔曼滤波器介绍 卡尔曼滤波器的介绍, 见 Wiki 这篇文章主要是翻译了 Understanding the Basis of the Kalman Filter Via a Simple a ...

  9. Linux系统下对NFS服务安全加固的方法

    NFS(Network File System)是 FreeBSD 支持的一种文件系统,它允许网络中的计算机之间通过 TCP/IP 网络共享资源.不正确的配置和使用 NFS,会带来安全问题. 概述 N ...

  10. assetbundle 对自定义shader的打包

    http://docs.unity3d.com/Manual/managingassetdependencies.html Managing asset dependencies   Any give ...