襄垣县 中牟县 威信县 钦州市 临沧市 荆州市 洪雅县 清丰县 称多县 蓝山县 灯塔市 湄潭县 尚义县 荣成市 万山特区 陇西县
作者:百年不渡  分类:未来幻想  点击:38253次  下载:76079次  大小:70M  日期:2019-07-19

艺术人生_开源方案搭建可离线的精美矢量切片地图服务-3.Mapbox个性化地图定制入门

标签:一口气 3d象棋游戏

项目成果展示(所有项目文件都在阿里云的共享云虚拟主机上,访问地图可以会有点慢,请多多包涵)。

01:中国地图:http://test.sharegis.cn.xianmultimedia.cn/mapbox/html/3china.html

02:德国-德累斯顿市:http://test.sharegis.cn.xianmultimedia.cn/mapbox/html/6germany.html

1.简介

mapbox是一家非常牛的公司,比如像特斯拉、DJI大疆创新、孤独星球、Airbnb、GitHub、Cisco、Snap、飞猪、Keep、Bosch这些在国内外各自领域中响当当的企业都是它的客户。专注于帮助企业打造定制化地图应用的Mapbox就是这样一家“你看不见我,但我无处不在”的企业。可以开发和定制web、android、IOS、VR、无人驾驶、甚至是游戏地图场景等。

mapbox-gl是Mapbox一款开源Web地图服务解决方案,用于搭建精美的地图服务,可以免费创建并定制个性化地图的网站。他最大的优点就是可以使用类似于css的样式来描述地图,并提供类似于photoshop的图像界面来设计和生成精美的样式。我们本篇主要讲一下Mapbox在We大都会_2018年最新新闻网b地图中的应用。

2.Mapbox入门

1.打开向导页:https://www.mapbox.com/install/,选择开发平台SDK,

image

2.选择Mapbox GL js 方式,第一种为CDN在线模式,类似于引用jquery一样,我们也可以下载下来。第二种为模块化js搭建,可使用webpack等模块化工具搭建。

image

3.搭建第一个页面。

<!DOCTYPE html>
<html>
<head>
     <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
     <title></title>
     <meta charset="utf-8" />
     <style>
         html, body {
             padding: 0;
             margin: 0;
             height: 100%;
             overflow: hidden;
         }

        #map {
             height: 100%;
 女婴起名王者荣耀_2018年最新新闻网            z-index: 0;
         }
     </style>
     <script src="https://api.mapbox.com/mapbox-gl-js/v0.44.2/mapbox-gl.js"></script>
     <link href="https://api.mapbox.com/mapbox-gl-js/v0.44.2/mapbox-gl.css" rel="stylesheet" />
</head>
<body>
     <div id="map"></div>
     <sc大丈夫_2018年最新新闻网ript>
         mapboxgl.accessToken = "pk.eyJ1IjoiYXR0dWluZyIsImEiOiJjamNham4ycTgwZzVkMndzM2lzYTJtN2VjIn0.kB9yWdGNuo7_oi3brXX4-A";
         var map = new mapboxgl.Map({
             container: "map",
             style: "mapbox://styles/mapbox/streets-v10"
         });
     </script>
</body>
</html>

配色非常舒服的地图界面,通过js代码分析可以看出最核心的代码就是 style: "mapbox://styles/mapbox/streets-v10",他包含了所有的地图样式。

3-3

3.Mapbox进阶

入门例子中style样式都封装到了一起,下面这个例子展示如何将style分解,为后面离线部署提供解决方案,具体可以查看一下style api.

<!DOCTYPE html>
<html>
<head>
     <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
     <title></title>
     <meta charset="utf-8" />
     <style>
         html, body {
             padding: 0;
             margin: 0;
             height: 100%;
             overflow: hidden;
         }

        #map {
             height: 100%;
             z-index: 0;
         }
     </style>
     <script src="https://api.mapbox.com/mapbox-gl-js/v0.44.2/mapbox-gl.js"></script>
     <link href="https://爸爸去哪儿_2018年最新新闻网api.mapbox.中国最强音_2018年最新新闻网com/mapbox-gl-js/v0.44.2/mapbox-gl.css" rel="stylesheet" />
</head>
<body>
     <div id="map"></div>
     <script>
         mapboxgl.accessToken = "pk.eyJ1IjoiYXR0dWluZyIsImEiOiJjamNham4ycTgwZzVkMndzM2lzYTJtN2VjIn0.kB9yWdGNuo7_oi3brXX4-A";
         var map = new mapboxgl.Map({
             container: "map",
             style: {
                 "version": 8,
                 "name": "Mapbox Streets",
                 "sprite": "mapbox://sprites/mapbox/streets-v8",
                 "glyphs": "mapbox://fonts/mapbox/{fontstack}/{range}.pbf",
                 "sources": {
                     "mapbox-streets": {
                         "type": "vector",
                         "url": "mapbox://mapbox.mapbox-streets-v6"
                     }
                 },
                 "layers": [
                     {
                         "id": "water",
                         "source": "mapbox-streets",
                         "source-layer": "water",
                         "type": "fill",
                         "paint": {
                             "fill-color": "#00ffff"
                         }
                     }
                 ]
             }
         });
     </script>
</body>
</html>

image

api解析:

1.version:这个JS SDK对应版本必须为8。

2.name:样式的命名。

3.sp造梦者_2018年最新新闻网rite:将一个地图涉及到的所有零星图标图片都包含到一张大图中去,我们看一下streets-v8的sprite图片。

image
4.glyphs:.pbf格式的字体样式,例如微软雅黑等字体库。

5.sources:图层的资源文件,可以支持矢量切片、栅格、dem栅格、图片、geojson、视频等格式。

6.layers:是对每个图层样式的描述,这里就是对地图样式渲染的关键,可以做很多精美的设计。

写到这里我们还有一个疑问 mapboxgl.accessToken 这个accessToken 是干什么的?其实Mapbox提供了在线样式的编辑,以及矢量数据上传,图标的整合等,这个accessToken 其实是为了与你上传到他们服务器的数据做关联,如果我们不依赖他的在线资源,我们完全可以不使用这个accessToken 。

4.Mapbox离线部署

通过上面的分析,mapbox-gl.js、mapbox-gl.css下载到本地就行。离线部署现在主要的问题是首先有自己的矢量切片文件,上一节我们讲过如何发布矢量切片服务,其次有个glyphs字体文件,后面文章我会提供一个微软雅黑的.pbf格式的字体库,以及我获取.pbf字体库的方式。剩下的就是编写自己的地图样式了。

5.总结

这一篇主要讲了一下Mapbox的基础,以及对离线部署的分析,下一篇讲一下我们之前提到的项目实现。

待续。。。。。。。。。。。。。。。。。。。。。

作者:ATtuing

出处:http://www.cnblogs.com.xianmultimedia.cn/ATtuing

本文版权归作者和博客园共有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文链接。

当前文章:http://www-yebeimodiao-com.xianmultimedia.cn/x7f/70a69_155628.html

发布时间:2019-07-19 09:26:28

澳门银河官网手机app  澳门银河2949所有网址华安保险董事长李光荣因涉嫌行贿罪被捕:“精通资本运营”  澳门银河真人yh163am.com  世界杯官网  澳门银河官网yh163am.com  澳门银河送彩金  澳门银河真人yh163am.com  银河国际手机网址2949  澳门银河官网yh163am.com  澳门银河送彩金  

您可能还对以下电子书感兴趣

艺术人生TXT下载声明:

1 2018年最新新闻网免费提供的艺术人生,均由网友上传,供下载测试之用,不作商业用途,下载后请二十四小时后删除!

2 我们根据txt小说全文所整理出艺术人生txt电子书全集免费下载,由程序自动生成艺术人生txt下载文件。

3 书友所发表的txt小说艺术人生的相关评论,并不代表本站赞同艺术人生txt下载或者支持艺术人生的读者观点。

4 如果发现小说《艺术人生txt全集》无法下载未及时更新请联系我们。如果您喜欢艺术人生txt电子书,请支持作者到书店购买正版图书。感谢您的合作与支持。

5 好看的小说艺术人生是作者"百年不渡"的最新力作,艺术人生电子书由网友发布;小说艺术人生版权属于作者所有,如果侵犯您的利益,请通知我们。