2022-05-28 Vue中高德地圖api結(jié)合echarts實(shí)現(xiàn)地圖下鉆功能

省市區(qū)3級(jí)下鉆
示意圖如下


image.png
image.png
image.png
<template>
  <div class="home-container">
    <el-button type="primary" @click="mapBack">返回上級(jí)地圖</el-button>
    <div id="map"></div>
  </div>
</template>

<script lang="js">
import {defineComponent} from 'vue';
import * as echarts from 'echarts';

export default defineComponent({
  name: 'map',
  data() {
    return {
      echartsMap: null,
      mapJson: {},
      level: 'province'
    }
  },
  props: {
    markers: {
      type: Array,
      default: () => []
    }
  },
  watch: {
    level(val) {
      console.log(val)
    }
  },
  mounted() {
    this.loadMapData('320000')
  },
  methods: {
    mapBack() {
      if (this.level === 'district') {
        this.level = 'city'
        const parentCode = this.mapJson.features[0].properties.acroutes[2]
        this.loadMapData(parentCode)
      } else if (this.level === 'city') {
        this.level = 'province'
        this.loadMapData('320000')
      }
    },
    loadMapData(areaCode) {
      // eslint-disable-next-line no-undef
      AMapUI.loadUI(['geo/DistrictExplorer'], DistrictExplorer => {

        //創(chuàng)建一個(gè)實(shí)例
        var districtExplorer = window.districtExplorer = new DistrictExplorer({
          eventSupport: true, //打開事件支持
          map: this.map
        });

        districtExplorer.loadAreaNode(areaCode, (error, areaNode) => {

          if (error) {
            console.error(error);
            return;
          }
          let mapJson = {};
          mapJson.type = 'FeatureCollection'
          //特別注意這里哦馋吗,如果查看過正常的geojson文件撑教,都會(huì)發(fā)現(xiàn)只搁,文件都是以features 字段開頭的豆挽,所以這里要記得加上
          mapJson.features = areaNode.getSubFeatures();
          this.mapJson = mapJson
          this.loadMap('province', mapJson);
        });
      });
    },
    //通過loadMap函數(shù)加載地圖
    loadMap(mapName, data) {

      if (this.echartsMap) this.echartsMap.dispose();

      //注冊(cè)并賦值給echartsMap
      this.echartsMap = echarts.init(document.getElementById('map'));
      if (data) {

        echarts.registerMap(mapName, data);//把geoJson數(shù)據(jù)注入echarts
        //配置echarts的option
        const option = {
          backgroundColor: '#020933',
          geo: {
            map: mapName,
            aspectScale: 0.75, //長(zhǎng)寬比
            zoom: 1.1,
            roam: false,
            label: {
              normal: {
                show: true,
                textStyle: {
                  color: '#fff'
                }
              },
              emphasis: {
                textStyle: {
                  color: '#fff'
                }
              }
            },
            nameProperty: 'name',
            data: this.markers,
            itemStyle: {
              normal: {
                borderColor: '#2ab8ff',
                borderWidth: 1.5,
                areaColor: '#12235c'
              },
              emphasis: {
                areaColor: '#2AB8FF',
                borderWidth: 0,
                color: 'green'
              }
            },
          },
          series: [
            {
              type: 'effectScatter',
              coordinateSystem: 'geo',
              showEffectOn: 'render',
              rippleEffect: {
                period: 15,
                scale: 4,
                brushType: 'fill'
              },
              hoverAnimation: true,
              itemStyle: {
                normal: {
                  color: '#ffff',
                  shadowBlur: 10,
                  shadowColor: '#333'
                }
              },
              data: this.markers
            }

          ]
        };
        this.echartsMap.setOption(option);

        this.echartsMap.on('click', this.echartsMapClick);
      }
    },
    echartsMapClick(params) {
      const currentMap = this.mapJson.features.filter(item => {
        if (item.properties.name === params.name) return true
      })

      this.level = currentMap[0].properties.level

      if (this.level === 'district') {
        let mapJson = {};
        mapJson.type = 'FeatureCollection'
        mapJson.features = currentMap
        this.mapJson = mapJson
      }
      this.$emit('mapClick', {level: this.level, code: currentMap[0].properties.adcode})
    },
  },
  beforeUnmount() {
    this.echartsMap = null
  }
});
</script>


<style scoped>
#map {
  height: 600px;
  width: 800px;
}
</style>


?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市擅威,隨后出現(xiàn)的幾起案子咧栗,更是在濱河造成了極大的恐慌,老刑警劉巖教藻,帶你破解...
    沈念sama閱讀 206,839評(píng)論 6 482
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異右锨,居然都是意外死亡括堤,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,543評(píng)論 2 382
  • 文/潘曉璐 我一進(jìn)店門绍移,熙熙樓的掌柜王于貴愁眉苦臉地迎上來悄窃,“玉大人,你說我怎么就攤上這事蹂窖≡梗” “怎么了?”我有些...
    開封第一講書人閱讀 153,116評(píng)論 0 344
  • 文/不壞的土叔 我叫張陵瞬测,是天一觀的道長(zhǎng)横媚。 經(jīng)常有香客問我,道長(zhǎng)月趟,這世上最難降的妖魔是什么灯蝴? 我笑而不...
    開封第一講書人閱讀 55,371評(píng)論 1 279
  • 正文 為了忘掉前任,我火速辦了婚禮狮斗,結(jié)果婚禮上绽乔,老公的妹妹穿的比我還像新娘。我一直安慰自己碳褒,他們只是感情好折砸,可當(dāng)我...
    茶點(diǎn)故事閱讀 64,384評(píng)論 5 374
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著沙峻,像睡著了一般睦授。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上摔寨,一...
    開封第一講書人閱讀 49,111評(píng)論 1 285
  • 那天去枷,我揣著相機(jī)與錄音,去河邊找鬼是复。 笑死删顶,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的淑廊。 我是一名探鬼主播逗余,決...
    沈念sama閱讀 38,416評(píng)論 3 400
  • 文/蒼蘭香墨 我猛地睜開眼,長(zhǎng)吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼季惩!你這毒婦竟也來了录粱?” 一聲冷哼從身側(cè)響起腻格,我...
    開封第一講書人閱讀 37,053評(píng)論 0 259
  • 序言:老撾萬榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎啥繁,沒想到半個(gè)月后菜职,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 43,558評(píng)論 1 300
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡旗闽,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,007評(píng)論 2 325
  • 正文 我和宋清朗相戀三年酬核,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片宪睹。...
    茶點(diǎn)故事閱讀 38,117評(píng)論 1 334
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡愁茁,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出亭病,到底是詐尸還是另有隱情鹅很,我是刑警寧澤,帶...
    沈念sama閱讀 33,756評(píng)論 4 324
  • 正文 年R本政府宣布罪帖,位于F島的核電站促煮,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏整袁。R本人自食惡果不足惜菠齿,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,324評(píng)論 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望坐昙。 院中可真熱鬧绳匀,春花似錦、人聲如沸炸客。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,315評(píng)論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽痹仙。三九已至是尔,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間开仰,已是汗流浹背拟枚。 一陣腳步聲響...
    開封第一講書人閱讀 31,539評(píng)論 1 262
  • 我被黑心中介騙來泰國(guó)打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留众弓,地道東北人恩溅。 一個(gè)月前我還...
    沈念sama閱讀 45,578評(píng)論 2 355
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像谓娃,于是被迫代替她去往敵國(guó)和親脚乡。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 42,877評(píng)論 2 345

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