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. 基于DPI(深度报文解析)的应用识别

    一.概述 1.DPI(Deep packet inspection,深度报文解析) 所谓“深度”是和普通的报文分析层次相比较而言的,“普通报文检测”仅分析IP包4 层以下的内容,包括源地址.目的地址. ...

  2. Chapter 5 -- ImmutableCollections

    Example publicstatic final ImmutableSet<String> COLOR_NAMES =ImmutableSet.of(  "red" ...

  3. cplusplus 库 在线管理; 类似于 python的 pip install 、nodejs 的npm模块

    cplusplus 库 在线管理: 类似于 python的 pip install .nodejs 的npm模块 还有 apache 经常使用的 Apache Ivy 项目依赖管理工具/Maven 这 ...

  4. JDBC 查询的三大参数

    本文转载至 http://blog.csdn.net/turkeyzhou/article/details/5115228 DBC1.0 .JDBC2.0 .JDBC3.0 中分别用以下方法创建Sta ...

  5. 第三十二章 elk(3)- broker架构 + 引入logback

    实际中最好用的日志框架是logback,我们现在会直接使用logback通过tcp协议向logstash-shipper输入日志数据.在上一节的基础上修改!!! 一.代码 1.pom.xml < ...

  6. [leetcode]Palindrome Partitioning II @ Python

    原题地址:https://oj.leetcode.com/problems/palindrome-partitioning-ii/ 题意: Given a string s, partition s  ...

  7. Reboot server stuck at “Press ESC in 1 seconds to skip startup.nsh”

    I have a Cisco C240 server, and everytime after reboot, it will got stuck at screen like below. To r ...

  8. 大数据开发实战:MapReduce内部原理实践

    下面结合具体的例子详述MapReduce的工作原理和过程. 以统计一个大文件中各个单词的出现次数为例来讲述,假设本文用到输入文件有以下两个: 文件1: big data offline data on ...

  9. 剑指offer 高速排序

    高速排序一般的写法.教科书上非常具体,这里介绍作者的写法. 程序例如以下: #include<iostream> #include<stack> using namespace ...

  10. LintCode: Single Number II

    一篇解析比较详细的文章:http://www.acmerblog.com/leetcode-single-number-ii-5394.html C++ 解法(1) 求出每个比特位的数目,然后%3,如 ...