摘要:最近在折騰的端的可視化項(xiàng)目,由于相關(guān)業(yè)務(wù)的需要,用到了這一地圖開(kāi)發(fā)的神器。其技術(shù)奠基于與。分別指縮放級(jí)別地面法線偏移角地軸偏移角等,用以確定當(dāng)前視窗所顯示的地圖區(qū)域和空間關(guān)系。個(gè)人認(rèn)為其最大的亮點(diǎn)在于即使不了解內(nèi)部實(shí)現(xiàn),也不影響其使用。
最近在折騰的 web 端的可視化項(xiàng)目,由于相關(guān)業(yè)務(wù)的需要,用到了 Mapbox 這一地圖開(kāi)發(fā)的神器。在此先奉上一個(gè)基于mapbox-gl實(shí)現(xiàn)的demo(來(lái)源:uber的deck.gl項(xiàng)目):
下面我們從這個(gè)項(xiàng)目一步步來(lái)介紹 Mapbox 的前端 GIS 引擎?Mapbox GL JS.
一、簡(jiǎn)單了解首先,Mapbox 在地圖領(lǐng)域是一家很 Newbee 的公司。已為 Foursquare、Pinterest、Evernote、金融時(shí)報(bào)、天氣頻道、優(yōu)步科技 等公司的網(wǎng)站提供了訂制在線地圖服務(wù)。
自2010年起,該公司快速地拓展了訂制地圖的市場(chǎng)地位,以回應(yīng) Google地圖 等地圖供應(yīng)商提供的有限選擇。Mapbox 是一些開(kāi)放源代碼地圖庫(kù)及應(yīng)用程序的創(chuàng)建者或最大的貢獻(xiàn)者,其中包含了MBTiles 規(guī)范、TileMill 制圖 IDE、Leaflet JavaScript 庫(kù),以及 CartoCSS 地圖格式化語(yǔ)言與語(yǔ)法分析器等。
該公司的數(shù)據(jù)同時(shí)從開(kāi)放與專有的來(lái)源獲取,開(kāi)放的數(shù)據(jù)源如 開(kāi)放街圖(OSM, Open Street Map) 以及 NASA 等,而專有的數(shù)據(jù)源則包含了 DigitalGlobe。其技術(shù)奠基于 Node.js、CouchDB、Mapnik、GDAL 與 Leafletjs。
Mapbox 針對(duì)不同平臺(tái)均開(kāi)發(fā)了相應(yīng)的 GIS 引擎以滿足開(kāi)發(fā)者或相關(guān)用戶的需要,如:iOS SDK(用于iOS端開(kāi)發(fā))、Android SDK(用于Andriod端開(kāi)發(fā))、Navigation SDK(用于Navigation端開(kāi)發(fā))、Unity SDK(用于Unity端開(kāi)發(fā))、GL JS(用于web端開(kāi)發(fā))。不同平臺(tái)的SDK,除使用方式不同外,功能特性上也多多少少存在不同。此外,Uber還針對(duì)react開(kāi)發(fā)了?react-map-gl??偟膩?lái)說(shuō),Mapbox的開(kāi)源技術(shù)棧是非常全面的。
二、輕松上手mapbox-gl 的 文檔 由 API、Style Specification、Example、Plugins 四部分內(nèi)容組成。
顧名思義,API 是一般框架(類庫(kù))提供給用戶的全部接口(方法)的說(shuō)明書(shū);Style Specification 是 Mapbox 地圖的樣式規(guī)范;Example 是一些常用功能或常見(jiàn)業(yè)務(wù)的代碼示例,囊括了使用 Mapbox 所能實(shí)現(xiàn)的大部分功能效果;Plugins 則是官方推薦的可與 mapbox-gl 一同使用的一些增效插件和開(kāi)源項(xiàng)目,如一些第三方的UI控件、顯示類插件、框架集成工具、開(kāi)發(fā)輔助工具、實(shí)用工具類庫(kù)等等。
對(duì)于初了解 Mapbox 的童鞋,建議先從官網(wǎng)的 Example 入手,能夠較快掌握 mapbox-gl 的使用并投入開(kāi)發(fā)實(shí)踐。
三、快速實(shí)踐下面以文章開(kāi)頭展示的項(xiàng)目為主,介紹其實(shí)戰(zhàn)步驟。
1. 加載地圖:由于使用在線地圖服務(wù)和 style 時(shí)需要驗(yàn)證用戶 token,所以在使用 mapboxgl 時(shí)需要先配置用戶 token(在Mapbox官網(wǎng)注冊(cè)用戶即可獲?。?。
import mapboxgl from "mapbox-gl"; mapboxgl.accessToken = "";
接下來(lái)使用創(chuàng)建地圖實(shí)例。主要配置項(xiàng)如下:
const myMap = new mapboxgl.Map({ container: "", style: " ", center: [112.508203125, 37.97980872872457], zoom: 4, pitch: 0, bearing: 0, });
其中,container 是地圖容器的元素 id,style 是地圖樣式的 url,或者你自己定義的 style(需遵循Mapbox樣式規(guī)范),center 是地圖加載后默認(rèn)的中心點(diǎn)位置,用以定位地圖加載時(shí)的位置。zoom pitch bearing 分別指縮放級(jí)別、地面法線偏移角、地軸偏移角等,用以確定當(dāng)前視窗所顯示的地圖區(qū)域和空間關(guān)系。配置項(xiàng)的意義均可查看官網(wǎng)文檔。
2. 繪制圖形這里主要介紹視頻中的3D建筑、飛線動(dòng)畫(huà)等是如何實(shí)現(xiàn)的。這里以相關(guān)代碼片段來(lái)介紹實(shí)踐的方法。
在Mapbox中繪制圖形時(shí), layer 和 source 是最重要的一組概念,后者用于存儲(chǔ)圖形的數(shù)據(jù)內(nèi)容,前者則是圖形在3D場(chǎng)景中的表現(xiàn)(圖層)。在Mapbox中,圖層一旦被創(chuàng)建,與其同名(id相同)的數(shù)據(jù)源源(即source)也必然被創(chuàng)建。反之,也可以在創(chuàng)建source后再創(chuàng)建一個(gè)圖層使用這個(gè)已創(chuàng)建的數(shù)據(jù)源,這時(shí)數(shù)據(jù)源與圖層間并不要求同名。而我們通過(guò)改變數(shù)據(jù)來(lái)驅(qū)動(dòng)圖形變化,便是才去的第二種方式:
// 創(chuàng)建id為buildings的數(shù)據(jù)源 myMap.addSource("buildings", { type: "geojson", data: "", }); // 使用buildings的數(shù)據(jù)來(lái)繪制id為building_layer的圖形 myMap.addLayer({ id: "building_layer", type: "fill-extrusion", source: "buildings", ... , });
基于上面的方式,當(dāng)數(shù)據(jù)改變時(shí),我們只需要重設(shè)數(shù)據(jù)源的數(shù)據(jù),即可驅(qū)動(dòng)圖層重繪:
if (myMap.getLayer("building_layer")) { myMap.getSource("buildings").setData(); }
至于3D效果及動(dòng)畫(huà)的具體實(shí)現(xiàn),這里給出兩個(gè)官網(wǎng)上的示例,相信大家能一目了然:
i.?用3D形式呈現(xiàn)建筑?3. 圖形交互
ii.?給路徑中的一個(gè)點(diǎn)添加動(dòng)畫(huà)效果
Mapbox提供的交互方法是比較靈活的,活學(xué)活用API文檔便能實(shí)現(xiàn)各種炫酷、實(shí)用的交互效果。比如:使用
myMap.on("zoom", callback) 可以將圖形與地圖的縮放相綁定,當(dāng)縮放系數(shù)小于某個(gè)值時(shí),可以隱藏掉一些圖形元素:
myMap.on("zoom", () => { if (myMap.getZoom() <= 4) { myMap.setLayoutProperty("building_layer", "visibility", "none"); } else { myMap.setLayoutProperty("building_layer", "visibility", "visible"); } });
再比如,連續(xù)調(diào)用 myMap.flyTo() 的方法使視圖在地圖上按照一定的軌跡緩慢移動(dòng),可以給用戶一種模擬飛行的體驗(yàn)。視頻中的自動(dòng)巡視的效果正是這樣實(shí)現(xiàn)的。
諸如 click mouseover popup 等效果,官網(wǎng)文檔中的示例已經(jīng)具體呈現(xiàn),這里就不詳細(xì)展開(kāi)了。
4. tiles-server的本地化由于 Mapbox 地圖服務(wù)使用 MBTiles 存儲(chǔ)數(shù)據(jù),目前很多地圖服務(wù)都接受了這套標(biāo)準(zhǔn)(如:OSM,Open Street Map)。所以可以通過(guò)搭建自己的 tiles-server 以替代直接使用 Mapbox 的在線地圖服務(wù)。
這樣做的好處是顯而易見(jiàn)的:一是可以通過(guò)負(fù)載均衡等手段提高數(shù)據(jù)接口的訪問(wèn)速度,有效提高數(shù)據(jù)的加載速度;一是保障應(yīng)用能在零帶寬的環(huán)境下仍能有效部署和使用。
這里墻裂安利一個(gè)docker開(kāi)源鏡像:openmaptiles-server ,在其 官網(wǎng) 和 dockerhub 上均可下載。個(gè)人認(rèn)為其最大的亮點(diǎn)在于——即使不了解內(nèi)部實(shí)現(xiàn),也不影響其使用。
運(yùn)行 tiles-server 服務(wù)的 docker 命令如下:
$ docker run --rm -it -v $(pwd):/data -p 8080:80
然后剩下來(lái)需要做的事情就是打開(kāi)其導(dǎo)航頁(yè)面 http://localhost:8080/(端口號(hào)取決于你的啟動(dòng)命令),然后跟著頁(yè)面上的提示一步一步設(shè)置就好了(最后一步設(shè)置后會(huì)從OSM走動(dòng)下載地圖,所以一開(kāi)始你不用擔(dān)心數(shù)據(jù)從哪來(lái)),完全是傻瓜式的部署。
四、性能調(diào)優(yōu)在 Mapbox GL 實(shí)踐的過(guò)程中,發(fā)現(xiàn)了一些影響應(yīng)用整體性能的因素,故而在此陳述一番,為之后填坑的童鞋提供一些經(jīng)驗(yàn):
使用geo數(shù)據(jù)(如 GeoJson 格式數(shù)據(jù))來(lái)定義圖形的時(shí)候,若數(shù)據(jù)量過(guò)大,則會(huì)拖慢數(shù)據(jù)加載的速度,此時(shí)可考慮:
i. 在 http 請(qǐng)求前后對(duì)數(shù)據(jù)進(jìn)行合理的壓縮和解壓,以盡可能節(jié)省 http 請(qǐng)求傳輸?shù)臄?shù)據(jù)量;
ii. 條件允許的情況下,可將一組數(shù)據(jù)分片加載,以空間換時(shí)間。
在 Mapboox 中繪制的圖層不宜過(guò)多,一是不方便管理(當(dāng)然,github上有很多管理Mapbox圖層的第三方工具),一是圖層過(guò)多會(huì)明顯降低GL的渲染和響應(yīng)性能。所以在繪制圖形前,可以先考慮一下圖層的劃分,以最少的圖層實(shí)現(xiàn)盡可能多的效果。
數(shù)據(jù)量相同的情況下,使用 mapboxgl.Marker 來(lái)添加標(biāo)記,其性能不如使用 type 為 symbol 類型的圖層來(lái)添加標(biāo)記。原因在于前者生成的標(biāo)記是一個(gè)個(gè) DOM 元素,如果你可以想象在一個(gè) web 頁(yè)面中同時(shí)操作成百上千個(gè) DOM 節(jié)點(diǎn)會(huì)是什么結(jié)果,那么你或許能明白我的建議。
五、一點(diǎn)總結(jié)最后,在此總結(jié)下個(gè)人對(duì) Mapbox 的一些感觀。
Mapbox 的產(chǎn)品定位是隨時(shí)隨地的 GIS(跨平臺(tái)、應(yīng)用),它為我們提供了一系列的簡(jiǎn)單操作的 API,使得 GIS 開(kāi)發(fā)變得靈活而有趣。尤其對(duì)于開(kāi)發(fā) GIS 類型的數(shù)據(jù)可視化應(yīng)用,Mapbox 是絕佳的選擇。
然而,如果你只是為了那些絢麗的 3D 效果的話,或許選擇專門的框架更為合適。
文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請(qǐng)注明本文地址:http://systransis.cn/yun/85154.html
MapBox 項(xiàng)目中用到MapBox也是偶然的機(jī)會(huì),項(xiàng)目中需要采用3D地圖,當(dāng)現(xiàn)有的工具(百度地圖)無(wú)法滿足我們的需求,我們肯定需要更高級(jí)開(kāi)源的地圖,無(wú)奈谷歌地圖無(wú)法在國(guó)內(nèi)使用,已是便找到Leafle,一開(kāi)始驚艷于leafle的開(kāi)源程度和其與眾不同的地圖風(fēng)格,后來(lái)順藤摸瓜,找到一個(gè)商業(yè)性地圖,它便是我們的主角-MapBoxshowImg(https://segmentfault.com/img/b...
摘要:讓我們看看都做了哪些工作可視化分析增強(qiáng)數(shù)據(jù)可操作性測(cè)試平臺(tái)的表格和置信區(qū)間可視化可視化分析主要都是由抽象數(shù)據(jù)可視化組成的。大多數(shù)有效的可視化分析在這種情況下都是關(guān)于報(bào)告儀表盤實(shí)時(shí)分析的圖標(biāo)和網(wǎng)絡(luò)圖。 showImg(https://segmentfault.com/img/remote/1460000006771644); 概述 在2015年初,我們?cè)赨ber規(guī)劃了一個(gè)官方的數(shù)據(jù)科學(xué)團(tuán)...
摘要:讓我們看看都做了哪些工作可視化分析增強(qiáng)數(shù)據(jù)可操作性測(cè)試平臺(tái)的表格和置信區(qū)間可視化可視化分析主要都是由抽象數(shù)據(jù)可視化組成的。大多數(shù)有效的可視化分析在這種情況下都是關(guān)于報(bào)告儀表盤實(shí)時(shí)分析的圖標(biāo)和網(wǎng)絡(luò)圖。 showImg(https://segmentfault.com/img/remote/1460000006771644); 概述 在2015年初,我們?cè)赨ber規(guī)劃了一個(gè)官方的數(shù)據(jù)科學(xué)團(tuán)...
閱讀 1139·2021-11-08 13:13
閱讀 1721·2019-08-30 15:55
閱讀 2772·2019-08-29 11:26
閱讀 2439·2019-08-26 13:56
閱讀 2560·2019-08-26 12:15
閱讀 2143·2019-08-26 11:41
閱讀 1402·2019-08-26 11:00
閱讀 1540·2019-08-23 18:30