MapboxGL可視化之千里江山圖

概述

今天在看百度地圖的時候看到在山峰是以等值面的方式展示的,于是就想著試試如何在MapboxGL中來實(shí)現(xiàn)一下梅屉,本文就是我實(shí)現(xiàn)后的記錄舞竿。文章標(biāo)題取名為“千里江山圖”搀捷,主要是生成的效果讓我不由想起了“千里江山圖”锅很,美的不要不要的其馏。

效果

百度效果
頂視圖
頂視放大后
傾斜圖1
傾斜圖2

實(shí)現(xiàn)

數(shù)據(jù)下載

在前面的文章已經(jīng)有交代過,大家可以點(diǎn)擊鏈接看看爆安。

數(shù)據(jù)處理

1. 發(fā)布地形服務(wù)

這個前面的文章已經(jīng)有交代了叛复,下面是文章鏈接。

2.DEM生成等值面

通過DEM數(shù)據(jù)生成等值面我用的是QGIS來完成的扔仓,如下圖褐奥。


生成等值線

代碼實(shí)現(xiàn)

實(shí)現(xiàn)就比較簡單了,用fill圖層進(jìn)行分段渲染就OK翘簇,實(shí)現(xiàn)代碼如下:

<!DOCTYPE html>
<html>
  <head>
    <meta charset="utf-8" />
    <title>Query terrain elevation</title>
    <meta
      name="viewport"
      content="initial-scale=1,maximum-scale=1,user-scalable=no"
    />
    <link href="./mapbox-gl.css" rel="stylesheet" />
    <script src="./mapbox-gl.js"></script>
    <style>
      body {
        margin: 0;
        padding: 0;
      }

      #map {
        position: absolute;
        top: 0;
        bottom: 0;
        width: 100%;
      }
    </style>
  </head>

  <body>
    <div id="map"></div>
    <script>
      const mapStyle = {
        version: 8,
        name: "Dark",
        sources: {
          "xyz-img": {
            type: "raster",
            tiles: [
              "https://webst01.is.autonavi.com/appmaptile?style=6&x={x}&y={y}&z={z}",
              "https://webst02.is.autonavi.com/appmaptile?style=6&x={x}&y={y}&z={z}",
              "https://webst03.is.autonavi.com/appmaptile?style=6&x={x}&y={y}&z={z}",
              "https://webst04.is.autonavi.com/appmaptile?style=6&x={x}&y={y}&z={z}",
            ],
            tileSize: 256,
          },
        },
        layers: [
          {
            id: "img",
            type: "raster",
            source: "xyz-img",
            minzoom: 1,
            maxzoom: 18,
            paint: {
              "raster-opacity": 0.5,
            },
          },
        ],
      };
      const map = new mapboxgl.Map({
        container: "map",
        zoom: 12,
        center: [104.61023753726323, 35.63101027697721],
        pitch: 75,
        bearing: 90,
        style: mapStyle,
        hash: true,
      });
      map.on("load", (e) => {
        // Set custom fog
        map.setFog({
          range: [-0.5, 2],
          color: "#c9eac2",
          "high-color": "#c9eac2",
          "space-color": "#c9eac2",
        });
        // Add terrain source, with slight exaggeration
        map.addSource("mapbox-dem", {
          type: "raster-dem",
          tiles: ["./terrain/{z}/{x}/{y}.png"],
          tileSize: 256,
          maxzoom: 14,
        });
        map.setTerrain({ source: "mapbox-dem", exaggeration: 3 });
        map.addSource("building", {
          type: "geojson",
          data: "./hillshade1.geojson",
        });
        map.addLayer({
          id: "3d-buildings",
          source: "building",
          type: "fill",
          paint: {
            "fill-color": [
              "interpolate",
              ["linear"],
              ["get", "ELEV_MAX"],
              1600, '#f7fcf5', 
              1700, '#f1faee', 
              1800, '#eaf7e6', 
              1900, '#e4f4de', 
              2000, '#d9f0d3', 
              2100, '#cfecc8', 
              2200, '#c3e7bc', 
              2300, '#b6e2af', 
              2400, '#a9dca3', 
              2500, '#9ad696', 
              2600, '#8bcf89', 
              2700, '#7bc77c', 
              2800, '#6abf71', 
              2900, '#58b668', 
              3000, '#46ae60', 
              3100, '#3aa357', 
              3200, '#2f984f', 
              3300, '#258d46', 
              3400, '#18813d', 
              3500, '#0b7634', 
              3600, '#00692a', 
              3700, '#005723', 
              3800, '#00441b'
            ],
            "fill-opacity": 0.95,
          },
        });
      });
    </script>
  </body>
</html>
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末撬码,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子缘揪,更是在濱河造成了極大的恐慌耍群,老刑警劉巖义桂,帶你破解...
    沈念sama閱讀 218,941評論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件找筝,死亡現(xiàn)場離奇詭異蹈垢,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)袖裕,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,397評論 3 395
  • 文/潘曉璐 我一進(jìn)店門曹抬,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人急鳄,你說我怎么就攤上這事谤民。” “怎么了疾宏?”我有些...
    開封第一講書人閱讀 165,345評論 0 356
  • 文/不壞的土叔 我叫張陵张足,是天一觀的道長。 經(jīng)常有香客問我坎藐,道長为牍,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,851評論 1 295
  • 正文 為了忘掉前任岩馍,我火速辦了婚禮碉咆,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘蛀恩。我一直安慰自己疫铜,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,868評論 6 392
  • 文/花漫 我一把揭開白布双谆。 她就那樣靜靜地躺著壳咕,像睡著了一般。 火紅的嫁衣襯著肌膚如雪顽馋。 梳的紋絲不亂的頭發(fā)上囱井,一...
    開封第一講書人閱讀 51,688評論 1 305
  • 那天,我揣著相機(jī)與錄音趣避,去河邊找鬼庞呕。 笑死,一個胖子當(dāng)著我的面吹牛程帕,可吹牛的內(nèi)容都是我干的住练。 我是一名探鬼主播,決...
    沈念sama閱讀 40,414評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼愁拭,長吁一口氣:“原來是場噩夢啊……” “哼讲逛!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起岭埠,我...
    開封第一講書人閱讀 39,319評論 0 276
  • 序言:老撾萬榮一對情侶失蹤盏混,失蹤者是張志新(化名)和其女友劉穎蔚鸥,沒想到半個月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體许赃,經(jīng)...
    沈念sama閱讀 45,775評論 1 315
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡止喷,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,945評論 3 336
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了混聊。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片弹谁。...
    茶點(diǎn)故事閱讀 40,096評論 1 350
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖句喜,靈堂內(nèi)的尸體忽然破棺而出预愤,到底是詐尸還是另有隱情,我是刑警寧澤咳胃,帶...
    沈念sama閱讀 35,789評論 5 346
  • 正文 年R本政府宣布植康,位于F島的核電站,受9級特大地震影響展懈,放射性物質(zhì)發(fā)生泄漏销睁。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,437評論 3 331
  • 文/蒙蒙 一标沪、第九天 我趴在偏房一處隱蔽的房頂上張望榄攀。 院中可真熱鬧,春花似錦金句、人聲如沸檩赢。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,993評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽贞瞒。三九已至,卻和暖如春趁曼,著一層夾襖步出監(jiān)牢的瞬間军浆,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 33,107評論 1 271
  • 我被黑心中介騙來泰國打工挡闰, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留乒融,地道東北人。 一個月前我還...
    沈念sama閱讀 48,308評論 3 372
  • 正文 我出身青樓摄悯,卻偏偏與公主長得像赞季,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子奢驯,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,037評論 2 355

推薦閱讀更多精彩內(nèi)容