【译者按:在看MapBox Guides文档时,看到这篇How do web maps work?,这篇文档通俗易懂地阐述了Web地图是如何工作的,其实更偏向讲瓦片地图的工作原理,鉴于之前很多人不了解地图切片的原理,因此简单翻译一下,由于源自MapBox文档,文中免不了涉及MapBox的相关术语,但不会影响我们的理解】

在MapBox上打开的Web地图或在你自己的网站上嵌入的Web地图,其实是由很多部件共同工作的结果,包括MapBox地图服务器,遍布世界各地的分布式系统以及在你的浏览器中运行的客户端代码等。

这篇指南文档将向你介绍单幅的瓦片地图是如何在一起工作并生成Web地图的。

连续的空间和细节

Web地图现在非常普遍,以至于人们经常忘记它区别于普通的纸质城市地图、世界地图的优点。当你浏览一个Web地图的时候,就像在一个很大的连续的图片上漫游,你可以通过在地图上平移(移动距离可能会比较远)来自由地查看纽约、巴黎甚至东京。通过放大和缩小Web地图,你会从国家轮廓看到越来越多的细节,如城市街道和建筑物。

Web地图可以在一个连续的空间系统内为你导航,而不是从这个国家直接跳跃到那个州或者某个城市。尽管名字叫做Web地图,但这个概念同样适用于许多移动地图并且在网上有了越来越多的Web地图,这使得纸质地图逐渐孤立。然而,从现在起,我们称这种概念为Web地图。

瓦片地图和缩放级别

一幅精确到街道级别的世界地图图片宽度为数以百万计的像素,由于这些数据太大了,从而导致无法一次下载并且在内存里也无法一次都hold住。实际上,Web地图由许多小的正方形的图片组成,这些小图片称作瓦片。瓦片的大小一般为256*256像素,这些瓦片一个挨一个并列放置以组成一张很大的看似无缝的地图。

如果我们想看到更多的地图细节,如想了解国家轮廓级别的地图与街道级别地图的不同,可以使用不同的缩放级别达到目的。缩放级别越高,显示地图的物理尺寸和细节表现也会相应增加。

为了组织如此多的地图瓦片,Web地图使用了一个简单的坐标系统。每一个瓦片都有一个z坐标来表示其缩放级别,还有一个x坐标和一个y坐标用来表示该瓦片在当前缩放级别下的网格内的位置,如:z/x/y。

第一张瓦片在Web地图系统中的坐标为0/0/0,此时缩放级别为0,只有一张瓦片并覆盖了整个世界的范围。

当缩放级别为1时,把缩放级别为0时的那张瓦片分割成四个相等的方块,其中坐标为1/0/0和1/1/0的两块覆盖北半球,坐标为1/0/1和1/1/1的两块覆盖南半球。

每一个缩放级别包含的瓦片数量为4的n次方,其中n为缩放级别。如:

缩放级别0包含1张瓦片;

缩放级别1包含4张瓦片;

缩放级别2包含16张瓦片;

依此类推。

由于瓦片数量是随缩放级别按指数增长的,因此每提高一个缩放级别会增加大量的地图细节,同时为了应付越来越多的瓦片,对带宽和存储空间的需求也会相应增加。

例如,一张缩放级别为15的地图,精确到可以看到城市建筑,大约需要11亿张瓦片才能覆盖整个世界,而缩放级别为17时,仅仅是增加了两个缩放级别,同样覆盖全世界却需要170亿张瓦片。

为什么要使用瓦片?

简单来说,因为瓦片地图可以很好的工作,所以Web地图使用瓦片。

1.瓦片地图缓存非常高效。如果你曾查看中央公园的地图而下载过曼哈顿的瓦片,当你需要显示泽西城的地图时,你的浏览器可以使用之前缓存的相同的瓦片,而不是重新再下载一次。

2.瓦片地图可以渐进加载。中央公园的瓦片会在曼哈顿地图边缘加载之前加载,你可以移动或缩放地图到某一个特定点,即使当前地图的边缘部分还没有加载完成。

3.瓦片地图简单易用。描述地图瓦片的坐标系统很简单,使得很容易在服务器、网络、桌面或移动设备上实现技术集成。

地图客户端与瓦片

让我们来展示一下中央公园的地图。因为地图瓦片是在网络上的图片,你需要把如下HTML代码嵌入到你的网页中。

你将会在浏览器中看到坐标为0/0/0的瓦片。

你需要进行许多缩放才能定位到中央公园。通过一些HTML、CSS和JavaScript代码,你可以按如下步骤显示中央公园的地图:

1.首先确定能够覆盖曼哈顿且能够详细显示中央公园的瓦片的z/x/y坐标。

2.在网页中添加一系列标签并使用CSS以便在网格中将它们定位到合适的位置。

3.为地图添加缩放按钮及拖拽平移等事件的响应处理,然后再次开始这些处理过程。

幸运的是,你已不需要再做上面这些,这是地图客户端做的事情。地图客户端通常是一个JavaScript库,这个库可以帮你找到需要显示的瓦片,帮助你从地图服务器下载并将它们显示到地图的合适位置。MapBox JavaScript API就是一种地图客户端,当然你还可以使用其他的地图客户端。

地图客户端需要知道你要显示的中心位置以及缩放级别,你可以输入一个位置的坐标然后MapBox.js就能找到你需要的瓦片。

中央公园的经纬度为40.783和-73.966,且查看该公园的最佳缩放级别为13。我们可以使用setView([40.783, -73.966], 13)方法告诉MapBox.js将中央公园的位置在地图上居中并缩放到13的级别。显示效果如下图:

原文档地址:https://www.mapbox.com/guides/how-web-maps-work/

原文:http://blog.csdn.net/ahence/article/details/44057681

html5地图连线原理,Web(瓦片)地图的工作原理相关推荐

  1. Web安全—脚本木马工作原理(持续更新)

    Web安全-脚本木马工作原理(持续更新) Webshell分类: 一句话木马 大马 小马 打包马 脱裤马 拿到网站Webshell意义(Webshell的权限取决于Web容器运行的权限,通常为网络服务 ...

  2. 网络编程技术——Web系统构成与工作原理

    Web系统构成与工作原理 1.1 Web系统的发展历程 C/S结构:客户机和服务器结构 如QQ.迅雷.魔兽争霸等需要下载安装客户端软件的系统 B/S架构:不需要安装客户端软件,它运行在客户端的浏览器之 ...

  3. servlet工作原理_Servlet 生命周期、工作原理

    Servlet 生命周期:Servlet 加载--->实例化--->服务--->销毁. init():在Servlet的生命周期中,仅执行一次init()方法.它是在服务器装入Ser ...

  4. 什么叫机械硬盘_机械硬盘的工作原理是什么?硬盘的工作原理简介

    机械硬盘的工作原理是什么?硬盘的工作原理简介 每个硬盘都有一块电路板,电路板主要负责与电脑进行通讯,并控制管理整个硬盘的工作,电路板可以说是硬盘的控制部门.由于个别硬盘电路设计不良,或芯片的质量不好, ...

  5. 一个动画看懂网络原理之CSMA/CD的工作原理

    一个动画看懂网络原理之CSMA/CD的工作原理 CSMA/CD协议是以太网传输中的一个重要协议,由于线路中同一时间只能允许一台电脑发送信息,否则各计算机之间就会产生干扰,为了解决这个问题,采用了CSM ...

  6. arcgis制作瓦片地图_一种GIS瓦片地图的存储方式的制作方法

    本发明涉及一项测绘与地理信息行业数据存储方式. 背景技术: 目前主要使用的GIS瓦片存储技术有两种一种是数据库文件存储,另一种是压缩包存储方式:数据库存储文件方式存在存储数据的冗余,数据格式体积较大的 ...

  7. html web上传文件原理,Web上传文件的原理及实现

    本文为原创,如需转载,请注明作者和出处,谢谢! 现在有很多Web程序都有上传功能,实现上传功能的组件或框架也很多,如基于java的Commons FileUpload.还有Struts1.x和Stru ...

  8. java session原理_java web开发—session的工作原理总结

    session的工作原理总结 一.什么是session session是一次浏览器和服务器交互的会话,在jsp中,作为一个内置对象存在.我的理解,就是当用户打开网页时,程序会在浏览器中开辟一段空间来存 ...

  9. WEB之http协议工作原理

    除了TCP/IP协议,http可以说是最重要,且使用最多的网络协议了.本节简要介绍一下http协议的工作原理. 假设现在有一个html文件:http.html, 存放在Web服务器上,其URL为www ...

  10. 灰度巡线传感器_灰度传感器的工作原理_灰度传感器调节方法

    灰度传感器的工作原理 灰度传感器是模拟传感器,有一只发光二极管和一只光敏电阻,安装在同一面上.灰度传感器利用不同颜色的检测面对光的反射程度不同,光敏电阻对不同检测面返回的光其阻值也不同的原理进行颜色深 ...

最新文章

  1. 在SQL Server中调用.NET程序集
  2. 天气预报都哪儿去了?
  3. SAP ABAP里数据库表的Storage Parameters从哪里来的
  4. BC:带你温习并解读《中国区块链技术和应用发展白皮书》—国内外区块链发展现状
  5. 网易云信亮相LiveVideoStackCon 2019,解读移动端播放器优化实践
  6. Android ActionBar随ScorllView上下拖动而透明度渐变效果
  7. 通过 .NET NativeAOT 实现用户体验升级
  8. Microsoft好员工的十个标准
  9. python old six day
  10. 给HUSTOJ用户提供的源码阅读与修改建议
  11. ssas_通过SSAS透视图提高可读性
  12. 计算机技术学 试卷,计算机技术及科学技术学院试卷模板A.doc
  13. 注意啦,Struts 2.1.6跟sitemesh-2.4.1不兼容
  14. OpenSSH学习笔记(安装配置openssh-4.6p1)[zz]
  15. Java程序员最常犯的错误盘点之Top 10
  16. Jmeter安装+配置+运行
  17. Xmind模板文档分享——学习记录(4)
  18. 找回git误删除的文件
  19. git 取消托管文件
  20. 比亚迪F6专用高清车载导航影音登场

热门文章

  1. footer在html中作用,footer在html中是什么意思
  2. footer的显示与隐藏
  3. html5添加下划线虚线,web中添加下划线的方法及优缺点
  4. 平安ETL开发面试积累
  5. 华为交换机配置dhcp中继
  6. gif透明背景动画_【超实用干货! 】iPad上的动画App大推荐
  7. java通过网易邮箱发送邮件
  8. 网易新闻客户端(高仿)
  9. IDC机房服务器的作用和分类
  10. openvpen最新安卓中文版_openvpen安卓