echarts中国省份地图加城市定位(打点)

 效果图:

<template>
    <div id="chinamap" :style="{width: '100%', height: '800px'}"></div>
</template>

 json文件可以去这里下载:地图选择器

import chinaFull from './chinaFull.json'

注:我所使用的json文件中,把"自治区" 、"市" 或  "省"给去掉了,所以,比如在写广东省的时候,不用加"省"字。,直接写广东就好。

  methods: {
    createChinaMap() {
      this.$echarts.registerMap('china', chinaFull);
      let myChart = this.$echarts.init(document.getElementById("chinamap"));
      // 地图默认中心
      let defaultCenter = [ 117.283042, 31.86119 ]
      // 仓库列表(定位)
      let warehouseList = [
                  {name:"北京", value: [116.352963,40.409079], quantity: 159.5, unit: '吨'},
                  {name:"上海", value: [121.463615,31.195908], quantity: 85.5, unit: '吨'},
                  {name:"武汉", value: [114.311582,30.598467], quantity: 55.5, unit: '吨'},
                  {name:"郑州", value: [113.631419,34.753439], quantity: 12.5, unit: '吨'},
                  {name:"深圳", value: [114.064552,22.548457], quantity: 13.4, unit: '吨'},
                  {name:"柳州", value: [109.434422,24.331961], quantity: 568.2, unit: '吨'},
                  {name:"河池", value: [108.084407,24.692636], quantity: 876.2, unit: '吨'},
                  {name:"来宾", value: [109.231766,23.745056], quantity: 133.2, unit: '吨'},
                  {name:"梧州", value: [111.276157,23.507642], quantity: 235.2, unit: '吨'},
                ]
      // 需要高亮的省
      let highlightAreaList = ["广西","广东","湖北","河南","上海", "北京"]
      // 标题
      let title = '仓库分布图'

      let option = {
        myChart: myChart,
        warehouseList: warehouseList,
        highlightAreaList: highlightAreaList,
        title: title,
        defaultCenter: defaultCenter
      }
      this.setOption(option)
    },
    /**
     * option = {
     *  myChart: echarts对象 必须
     *  warehouseList: 仓库信息
     *  highlightAreaList: 需要高亮的省
     *  center: 地图初始中心
     * }
     */
    setOption(option) {
      option.highlightAreaObjList = this.buildHighlightAreaObjList(option.highlightAreaList)
      option.myChart.setOption({
          title: {
            text: option.title,
            // subtext: '',// 副标题
            // sublink: '' // 不标题连接
          },
          tooltip: {
              trigger: 'item',
              formatter: function(params) {
                if(Array.isArray(option.highlightAreaList) && option.highlightAreaList.indexOf(params.name) != -1 ) {
                  return params.name + "<br>xxx仓库 159.3吨<br>xxx仓库 59.1吨"
                } else {
                  return params.name
                }
              },
          },
          // 右边内置工具
          toolbox: {
              show: true,
              orient: 'vertical',
              left: 'right',
              top: 'center',
              feature: {
                  dataView: {readOnly: false},
                  restore: {},
                  saveAsImage: {}
              }
          },
          visualMap: {
            show: false,
          },
          geo: {
            // 指定区域设置样式和
            regions: option.highlightAreaObjList ,
            center: option.center,
            map: 'china',       
            silent: false,       
            itemStyle: {
              color: '#eee', //地图颜色   
              borderColor: 'rgb(0, 0, 0)',// 边框颜色
              borderWidth : 1
            },
            label:{
              color: "rgb(0,0,0)", //文字颜色
              show: true,
              formatter: function(params) {
                return params.name
              },
              rich: {
              }
            },
            zoom : 1.6, //缩放
            roam: true, //鼠标可拖动、缩放
          },
          series: [
               {
                symbolSize: function (data) {
                  return Math.sqrt(data[2]) / 5e2;
                },
                emphasis: {
                  show: false,
                  focus: 'item',
                  itemStyle:{
                    color: 'rgb(252, 1, 26)'
                  }
                },
                tooltip:{
                  formatter: function(params) {
                    return params.name + " " + params.data.quantity + params.data.unit
                  }
                },
                type: 'scatter',
                coordinateSystem: 'geo',
                symbolSize: 15,
                symbol: 'image://',
                // symbolRotate: 35,
                label: {
                  show:true,
                  normal: {
                      formatter: function(params) {
                        return params.name 
                        // return params.name + " " + params.data.quantity + params.data.unit
                      },
                      position: 'right',
                      show: true
                  }
                },
                data: option.warehouseList
                
              },
            ]
        })
    },
    buildHighlightAreaObjList(highlightAreaList) {
      let objList = []
      if(Array.isArray(highlightAreaList)) {
        highlightAreaList.forEach(item => {
          objList.push({
              name: item,
              itemStyle: {
                  color: 'red',
                  areaColor: 'rgb(255, 223, 51)'
              }
            })
        })
      }
      return objList

    }
  }

猜你喜欢

转载自blog.csdn.net/qq_38974073/article/details/117818299