MBTiles 1.2 规范翻译
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。
该表必须具有名为name和value的两列。metadata表典型创建语句如下:
CREATE TABLE metadata (name text, value text);
Content 内容
metadata表用作key/value存储,用于保存一些配置settings。
以下五个key是必须的:
name: tileset的纯英文名称.type:overlay(覆盖型)或baselayer(基本图层型).version: tileset的版本,纯数字.description: 描述图层(layer)的文本.format: 瓦片数据的图像文件格式:png或jpg
row在metadata中是推荐提供的,如有,可以提高性能。
bounds: 呈现的地图区域的最大范围。Bounds必须定义所有缩放级别所覆盖的区域。范围bounds以WGS:84中经纬度值表示,在OpenLayers Bounds格式表示为-
左,下,右,上.全球范围为例:-180.0,-85,180,85.attribution:属性字符串,使用纯英文(和HTML)解释地图数据和(或)样式的来源.
通常的tilesets实现都支持这些附加键。
基于UTFGrid交互.
Tiles 瓦片
Schema 方案
数据库需要包含名为tiles的表.
该表必须具有zoom_level、tile_column、tile_row和tile_data四列。tiles表典型创建语句如下:
CREATE TABLE tiles (zoom_level integer, tile_column integer, tile_row integer, tile_data blob);
Content 内容
tiles用于包含瓦片和用于定位的值。
zoom_level、tile_column和tile_row列在其构造中遵循
Tile Map Service规范,但受限于以下形式:
假定是global-mercator (球面墨卡托SphericalMercator)
tile_data blob列包含原始图像二进制数据.
图像文件的格式允许使用以下两种:
pngjpg
Grids 网格
有关网格和交互元数据本身的实现细节,请参阅UTFGrid规范:MBTiles规范仅涉及存储。
Schema 方案
数据库可以有可选的表grids和grid_data。
grids必须具有zoom_level、tile_column、tile_row和grid四列。grids表典型创建语句如下:
CREATE TABLE grids (zoom_level integer, tile_column integer, tile_row integer, grid blob);
grid_data必须具有zoom_level、tile_column、tile_row、key_name和key_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 key到value映射,将value编码为JSON对象。
MBTiles 1.2 规范翻译的更多相关文章
- [转]MBTiles 1.2 规范翻译
MBTiles 1.2 可以参考超图的文档MBTiles扩展具体实现可以参考浅谈利用SQLite存储离散瓦片的思路和实现方法 mapbox提供了一个简单实现测试代码,github地址在这里https: ...
- Go语言安全编码规范-翻译(分享转发)
Go语言安全编码规范-翻译 本文翻译原文由:blood_zer0.Lingfighting完成 如果翻译的有问题:联系我(Lzero2012).匆忙翻译肯定会有很多错误,欢迎大家一起讨论Go语言安全能 ...
- BSON 1.0版本规范(翻译)
BSON 1.0版本规范 本文翻译自 http://bsonspec.org/spec.html BSON是用于存储零个或多个键/值对为一个单一的实体的一个二进制格式.我们称这个实体为文档(Docum ...
- JSON-RPC 2.0规范 翻译 中文版
JSON-RPC 2.0规范 起源日期: 2010-03-26(基于2009-05-24的版本号) 修正: 2013-01-04 作者: JSON-RPC 工作组 <json-rpc@googl ...
- Promise/A+规范-翻译
Promise 表示一个异步操作的最终结果,与之进行交互的方式主要是 then 方法,该方法注册了两个回调函数,用于接收 promise 的终值或本 promise 不能执行的原因. 本规范详细列出了 ...
- 3、LwIP协议栈规范翻译——概述
3.概述 像许多其他TCP/IP实现一样,分层协议设计已经成为设计lwIP实现的指南.每个协议实现为自己的模块,其中几个功能充当每个协议的入口点.尽管协议层是单独实现的,一些层却不全是,正如前面所叙述 ...
- 4、 LwIP协议栈规范翻译——流程模型
4.流程模型 协议实现的流程模型描述了系统被划分为不同的流程的方式.用于实现通信协议的一个流程模型是让每个协议作为一个独立的进程运行.有了这个模型,严格的协议分层被强制执行,并且协议之间的通信点必须严 ...
- 5、 LwIP协议栈规范翻译——操作系统仿真层
为了使lwIP可移植,操作系统特定的函数调用和数据结构不直接在协议的代码中使用.相反,当需要这样的函数调用和数据结构时,直接使用操作系统仿真层. 操作系统仿真层为操作系统服务提供统一的接口,如定时器, ...
- LwIP协议栈规范翻译——摘要目录
摘要 LwIP是一种TCP/IP协议栈的实现.LwIP协议栈专注于减少内存的使用和代码的大小,使LwIP适用于嵌入式系统中在有限的资源下能够使用小型的客户机.为了减少处理和内存的需求,LwIP使用裁剪 ...
随机推荐
- USB线插拔检测使用UEventObserver检测uevent事件的分析
说实话这玩样儿的代码量真的很少,大家如果能耐得住性子啃一会儿也就能撸懂了. 在这之前研究USB线插拔的时候就知道了有这么个东西,当时也就看了看,但没做什么笔记.最近想用起来,却发现就只有个名字在记忆中 ...
- html table奇偶行颜色设置 (CSS选择器)
:nth-child(n) 选择器匹配属于其父元素的第 N 个子元素,不论元素的类型.n 可以是数字.关键词或公式. 下面的例子, 设置表格的奇偶行背景颜色不同:单独设置表格的第1列背景颜色不同. & ...
- 谷歌(Google)被墙,解决地图和字体无法显示的问题
首先,本文以及本站所有文章都是技术探讨文章,不鼓励任何人去fan qiang以及做任何违法的事情.接下来是正文: 谷歌基本上是被和谐透了,谷歌地图API自然也打不开了,于是公司网站上那些谷歌地图都变成 ...
- oracle的!=与<>
效果是完全一样的 Oracle中有三个不等符号的,分别是: != ^= <>
- python 获取几小时之前,几分钟前,几天前,几个月前,及几年前的具体时间
引入以下两个包: import datetime import arrow 具体代码 # import datetime # import arrow def getTime(self, flag,d ...
- Spark(十二)--性能调优篇
一段程序只能完成功能是没有用的,只能能够稳定.高效率地运行才是生成环境所需要的. 本篇记录了Spark各个角度的调优技巧,以备不时之需. 一.配置参数的方式和观察性能的方式 额...从最基本的开始讲, ...
- 【R】函数-字符处理函数
- mysql的sql分页函数limit使用 (转)
http://www.cnblogs.com/beijingstruggle/p/5631603.html mysql的sql分页函数limit使用 My sql数据库最简单,是利用mysql的LIM ...
- MongoDB: 如何删除一个collection中的一个字段?
Try this: If your collection was 'example' db.example.update({}, {$unset: {words:1}}, false, true) ...
- oracle 嵌套查询
select dat.id, dat.voucher_id, dat.type, dat.state, dat.start_point, dat.start_floor, dat.end_point, ...