echarts实现山东地图可放大缩小可下钻

最近遇到一个新需求,要求展示山东省的地图,并且点击可进入地级市地图。这可是难倒了我,我尝试着用不同的方法,高德地图、百度地图等,发现都有一定的缺陷,最终决定使用echarts实现,下面就来跟大家分享一下我的心路历程。
先来看一下效果:

点击济南市即可进入济南市的地图:

实现步骤如下所示:
1.图中的地图都是需要去网站上自行下载的,包括山东省地图,各个地级市的地图都需要进行下载,网址http://datav.aliyun.com/tools/atlas/,下载格式为.json
2.地图中需要用到的小图标,小图片什么的,需要提前转换成base64格式,百度搜一下,有不少在线转换工具可以直接转换
3.安装echarts,并导入
4.html代码:

<div style="width:400px;height:400px" id="barChart"></div>

5.js代码

//导入地图
import shandong from "../../../../../assets/get/shandongData.json";
......

async getLeftBar() {
      let nc = document.getElementById("barChart");
      var myChart = this.echarts.init(nc);
      this.echarts.registerMap("山东", shandong);
      var cityMap = {
        济南市: jinan,
        青岛市: qingdao,
        烟台市: yantai,
        潍坊市: weifang,
        菏泽市: heze,
        日照市: rizhao,
        威海市: weihai,
        枣庄市: zaozhuang,
        临沂市: linyi,
        滨州市: bingzhou,
        东营市: dongying,
        淄博市: zibo,
        泰安市: taian,
        聊城市: liaocheng,
        济宁市: jining,
        德州市: dezhou,
      };
      var sdGeoCoordMap = {
        济南市: [117.000923, 36.675807],
        青岛市: [120.355173, 36.082982],
        烟台市: [121.391382, 37.539297],
        潍坊市: [119.107078, 36.70925],
        菏泽市: [115.469381, 35.246531],
        日照市: [119.461208, 35.428588],
        威海市: [122.116394, 37.509691],
        枣庄市: [117.557964, 34.856424],
        临沂市: [118.326443, 35.065282],
        滨州市: [118.016974, 37.383542],
        东营市: [118.66471, 37.434564],
        淄博市: [118.047648, 36.814939],
        泰安市: [117.129063, 36.194968],
        聊城市: [115.980367, 36.456013],
        济宁市: [116.587245, 35.415393],
        德州市: [116.307428, 37.453968],
      };
      var sdDatas = [
        {
          name1: "济南市",
          name: "济南市供电局",
          value: [117.050923, 36.678807, 0.5],
        },
        {
          name1: "济南市",
          name: "济南市供电局23",
          value: [117.053923, 36.638807, 3.5],
        },
        {
          name1: "济南市",
          name: "济南市随便吧",
          value: [117.653923, 37.038807, 11],
        },
        {
          name1: "青岛市",
          name: "青岛市供电局",
          value: [120.385173, 36.042982, 7.5],
        },
      ];
      var jinandata = [
        {
          name: "东莞市供电局",
          value: [117.000623, 36.672807, 0.5],
        },
        {
          name: "东莞东城供电分局",
          value: [117.001923, 36.685807, 1],
        },
        {
          name: "广东电网东莞南城供电局",
          value: [117.002923, 36.675207, 1],
        },
        {
          name: "沙田供电分局",
          value: [117.007923, 36.675107, 0.1],
        },
        {
          name: "广东电网(松山湖)",
          value: [117.040923, 36.625807, 0.4],
        },
        {
          name: "东莞供电局万江供电局",
          value: [117.100923, 36.695807, 1],
        },
        {
          name: "广东电网公司石龙供电分局",
          value: [117.003923, 36.673807, 1.4],
        },
        {
          name: "广东电网东莞虎门供电局",
          value: [117.002913, 36.676607, 0.7],
        },
        {
          name: "广东电网公司中堂供电公司",
          value: [117.01123, 36.633807, 0.1],
        },
        {
          name: "望牛墩供电公司",
          value: [117.000333, 36.675557, 0.5],
        },
        {
          name: "东莞供电局石碣供电局",
          value: [117.000233, 36.674307, 2],
        },
        {
          name: "高埗供电分局",
          value: [117.445923, 36.874507, 0.9],
        },
        {
          name: "东莞市麻涌供电公司",
          value: [117.003423, 36.678807, 2],
        },
        {
          name: "东莞市长安供电公司",
          value: [117.000444, 36.675444, 2],
        },
        {
          name: "东莞市道滘供电公司",
          value: [117.110923, 36.635807, 0.4],
        },
        {
          name: "东莞市洪梅供电公司",
          value: [117.0334923, 36.673434, 0.6],
        },
        {
          name: "东莞市厚街供电公司",
          value: [117.003423, 36.634807, 2],
        },
        {
          name: "东莞市寮步供电公司",
          value: [117.047923, 36.674807, 2],
        },
        {
          name: "大岭山供电公司",
          value: [117.046923, 36.635807, 0.1],
        },
        {
          name: "广东电网大朗供电分公司",
          value: [117.150923, 36.715807, 0.9],
        },
        {
          name: "黄江供电分局",
          value: [117.003453, 36.672307, 0.5],
        },
        {
          name: "东莞供电局樟木头供电局",
          value: [117.099923, 36.699807, 2],
        },
        {
          name: "东莞市清溪供电公司",
          value: [117.089923, 36.689807, 2],
        },
        {
          name: "东莞供电局谢岗分局",
          value: [117.029923, 36.629807, 2],
        },
        {
          name: "东莞市凤岗镇雁田供电所",
          value: [117.004443, 36.673337, 0.4],
        },
        {
          name: "东莞常平供电分局",
          value: [117.004373, 36.6787857, 0.6],
        },
        {
          name: "东莞桥头供电分局",
          value: [117.003413, 36.623407, 2],
        },
        {
          name: "东莞电网横沥供电分局",
          value: [117.00032343, 36.6342807, 0.8],
        },
        {
          name: "广东电网公司东莞东坑供电分局",
          value: [117.0087653, 36.67467807, 0.2],
        },
        {
          name: "塘厦供电局",
          value: [117.045673, 36.6567307, 2],
        },
        {
          name: "企石供电局",
          value: [117.003633, 36.6755427, 0.7],
        },
        {
          name: "石排供电公司",
          value: [117.0456923, 36.645807, 0.1],
        },
        {
          name: "茶山供电分局",
          value: [117.003453, 36.6345807, 0.2],
        },
      ];
      var qingdaodata = [
        {
          name: "东莞市供电局",
          value: [120.345173, 36.0842982, 0.5],
        },
      ];
      var yantaidata = [
        {
          name: "东莞市供电局",
          value: [121.393382, 37.53497, 0.5],
        },
      ];
      var weifangdata = [
        {
          name: "东莞市供电局",
          value: [119.107078, 36.70925, 0.5],
        },
      ];
      var hezedata = [
        {
          name: "东莞市供电局",
          value: [115.489381, 35.286531, 0.5],
        },
      ];
      var rizhaodata = [
        {
          name: "东莞市供电局",
          value: [119.491208, 35.499588, 0.5],
        },
      ];
      var weihaidata = [
        {
          name: "东莞市供电局",
          value: [122.1199394, 37.599691, 0.5],
        },
      ];
      var zaozhuangdata = [
        {
          name: "东莞市供电局",
          value: [117.597964, 34.896424, 0.5],
        },
      ];
      var linyidata = [
        {
          name: "东莞市供电局",
          value: [118.386443, 35.085282, 0.5],
        },
      ];
      var bingzhoudata = [
        {
          name: "东莞市供电局",
          value: [118.016974, 37.383542, 0.5],
        },
      ];
      var dongyingdata = [
        {
          name: "东莞市供电局",
          value: [118.016974, 37.383542, 0.5],
        },
      ];
      var zibodata = [
        {
          name: "东莞市供电局",
          value: [118.016974, 37.383542, 0.5],
        },
      ];
      var taiandata = [
        {
          name: "东莞市供电局",
          value: [118.016974, 37.383542, 0.5],
        },
      ];
      var liaochengdata = [
        {
          name: "东莞市供电局",
          value: [118.016974, 37.383542, 0.5],
        },
      ];
      var jiningdata = [
        {
          name: "东莞市供电局",
          value: [118.016974, 37.383542, 0.5],
        },
      ];
      var dezhoudata = [
        {
          name: "东莞市供电局",
          value: [118.016974, 37.383542, 0.5],
        },
      ];

      var that = this;

      var opt = {
        bgColor: "#013954", // 画布背景色
        mapName: "山东", // 地图名
        goDown: true, // 是否下钻
        // 下钻回调
        callback: async function (name, option, instance) {
          console.log(name, option, instance);
          if (name == "山东") {
            this.ifShow = true;
            option.series[0].data = converntData(data_tmp);
            option.series[1].data = data_tmp;
            myChart.setOption(option, true);
            setTimeout(() => {
              // 定时后启动飞线
              myChart.setOption(option, true);
            }, 500);
          } else if (name == "济南市") {
            that.ifShow = false;
            that.cityName = "济南市";
            that.cityCode = "370100";
            await that.getLonLat();
            that.getSixData();
            that.$emit("changeArea", "济南市", "370100");
            setTimeout(() => {
              option.series[0] = {
                type: "effectScatter",
                coordinateSystem: "geo",
                zlevel: 2,
                rippleEffect: {
                  //涟漪特效
                  period: 8, //动画时间,值越小速度越快
                  brushType: "fill", //波纹绘制方式 stroke, fill
                  scale: 0, //波纹圆环最大限制,值越大波纹越大
                },
                label: {
                  normal: {
                    show: false,
                    position: "right", //显示位置
                    offset: [5, 0], //偏移设置
                    formatter: function (params) {
                      //圆环显示文字
                      return params.data.name;
                    },
                    fontSize: 19,
                  },
                  emphasis: {
                    show: true,
                  },
                },
                itemStyle: {
                  normal: {
                    show: false,
                    color: "#f00",
                  },
                },
                data: that.dataArr,
              };
            }, 600);
            option.series[1].data = that.cityFactoryData;
            option.series[2].data = that.cityFactoryData;
            console.log("option.series:");
            console.log(option.series);
            myChart.setOption(option, true); // 赋值后初始化
            setTimeout(() => {
              // 定时后启动飞线
              myChart.setOption(option, true);
            }, 600);
          } else if (name == "青岛市") {
            that.ifShow = false;
            that.cityName = "青岛市";
            that.cityCode = "370200";
            await that.getLonLat();
            that.getSixData();
            that.$emit("changeArea", "青岛市", "370200");
            setTimeout(() => {
              option.series[0] = {
                type: "effectScatter",
                coordinateSystem: "geo",
                zlevel: 2,
                rippleEffect: {
                  //涟漪特效
                  period: 8, //动画时间,值越小速度越快
                  brushType: "fill", //波纹绘制方式 stroke, fill
                  scale: 0, //波纹圆环最大限制,值越大波纹越大
                },
                label: {
                  normal: {
                    show: false,
                    position: "right", //显示位置
                    offset: [5, 0], //偏移设置
                    formatter: function (params) {
                      //圆环显示文字
                      return params.data.name;
                    },
                    fontSize: 19,
                  },
                  emphasis: {
                    show: true,
                  },
                },
                itemStyle: {
                  normal: {
                    show: false,
                    color: "#f00",
                  },
                },
                data: that.dataArr,
              };
            }, 600);
            option.series[1].data = that.cityFactoryData;
            option.series[2].data = that.cityFactoryData;
            myChart.setOption(option, true); // 赋值后初始化
            setTimeout(() => {
              // 定时后启动飞线
              myChart.setOption(option, true);
            }, 600);
          } else if (name == "烟台市") {
            that.ifShow = false;
            that.cityName = "烟台市";
            that.cityCode = "370600";
            that.getLonLat();
            that.getSixData();
            that.$emit("changeArea", "烟台市", "370600");
            option.series[0].data = convertData1(yantaidata);
            option.series[1].data = yantaidata;
            option.series[2].data = [];
            myChart.setOption(option, true); // 赋值后初始化
            setTimeout(() => {
              // 定时后启动飞线
              myChart.setOption(option, true);
            }, 500);
          } else if (name == "潍坊市") {
            that.ifShow = false;
            that.cityName = "潍坊市";
            that.cityCode = "370700";
            that.getLonLat();
            that.getSixData();
            that.$emit("changeArea", "潍坊市", "370700");
            option.series[0].data = convertData1(weifangdata);
            option.series[1].data = weifangdata;
            option.series[2].data = [];
            myChart.setOption(option, true); // 赋值后初始化
            setTimeout(() => {
              // 定时后启动飞线
              myChart.setOption(option, true);
            }, 500);
          } else if (name == "菏泽市") {
            that.ifShow = false;
            that.cityName = "菏泽市";
            that.cityCode = "371700";
            that.getLonLat();
            that.getSixData();
            that.$emit("changeArea", "菏泽市", "371700");
            option.series[0].data = convertData1(hezedata);
            option.series[1].data = hezedata;
            option.series[2].data = [];
            myChart.setOption(option, true); // 赋值后初始化
            setTimeout(() => {
              // 定时后启动飞线
              myChart.setOption(option, true);
            }, 500);
          } else if (name == "日照市") {
            that.ifShow = false;
            that.cityName = "日照市";
            that.cityCode = "371100";
            that.getLonLat();
            that.getSixData();
            that.$emit("changeArea", "日照市", "371100");
            option.series[0].data = convertData1(rizhaodata);
            option.series[1].data = rizhaodata;
            option.series[2].data = [];
            myChart.setOption(option, true); // 赋值后初始化
            setTimeout(() => {
              // 定时后启动飞线
              myChart.setOption(option, true);
            }, 500);
          } else if (name == "威海市") {
            that.ifShow = false;
            that.cityName = "威海市";
            that.cityCode = "371000";
            that.getLonLat();
            that.getSixData();
            that.$emit("changeArea", "威海市", "371000");
            option.series[0].data = convertData1(weihaidata);
            option.series[1].data = weihaidata;
            option.series[2].data = [];
            myChart.setOption(option, true); // 赋值后初始化
            setTimeout(() => {
              // 定时后启动飞线
              myChart.setOption(option, true);
            }, 500);
          } else if (name == "枣庄市") {
            that.ifShow = false;
            that.cityName = "枣庄市";
            that.cityCode = "370400";
            that.getLonLat();
            that.getSixData();
            that.$emit("changeArea", "枣庄市", "370400");
            option.series[0].data = convertData1(zaozhuangdata);
            option.series[1].data = zaozhuangdata;
            option.series[2].data = [];
            myChart.setOption(option, true); // 赋值后初始化
            setTimeout(() => {
              // 定时后启动飞线
              myChart.setOption(option, true);
            }, 500);
          } else if (name == "临沂市") {
            that.ifShow = false;
            that.cityName = "临沂市";
            that.cityCode = "371300";
            that.getLonLat();
            that.getSixData();
            that.$emit("changeArea", "临沂市", "371300");
            option.series[0].data = convertData1(linyidata);
            option.series[1].data = linyidata;
            option.series[2].data = [];
            myChart.setOption(option, true); // 赋值后初始化
            setTimeout(() => {
              // 定时后启动飞线
              myChart.setOption(option, true);
            }, 500);
          } else if (name == "滨州市") {
            that.ifShow = false;
            that.cityName = "滨州市";
            that.cityCode = "371600";
            that.getLonLat();
            that.getSixData();
            that.$emit("changeArea", "滨州市", "371600");
            option.series[0].data = convertData1(bingzhoudata);
            option.series[1].data = bingzhoudata;
            option.series[2].data = [];
            myChart.setOption(option, true); // 赋值后初始化
            setTimeout(() => {
              // 定时后启动飞线
              myChart.setOption(option, true);
            }, 500);
          } else if (name == "东营市") {
            that.ifShow = false;
            that.cityName = "东营市";
            that.cityCode = "370500";
            that.getLonLat();
            that.getSixData();
            that.$emit("changeArea", "东营市", "370500");
            option.series[0].data = convertData1(dongyingdata);
            option.series[1].data = dongyingdata;
            option.series[2].data = [];
            myChart.setOption(option, true); // 赋值后初始化
            setTimeout(() => {
              // 定时后启动飞线
              myChart.setOption(option, true);
            }, 500);
          } else if (name == "淄博市") {
            that.ifShow = false;
            that.cityName = "淄博市";
            that.cityCode = "370300";
            that.getLonLat();
            that.getSixData();
            that.$emit("changeArea", "淄博市", "370300");
            option.series[0].data = convertData1(zibodata);
            option.series[1].data = zibodata;
            option.series[2].data = [];
            myChart.setOption(option, true); // 赋值后初始化
            setTimeout(() => {
              // 定时后启动飞线
              myChart.setOption(option, true);
            }, 500);
          } else if (name == "泰安市") {
            that.ifShow = false;
            that.cityName = "泰安市";
            that.cityCode = "370900";
            that.getLonLat();
            that.getSixData();
            that.$emit("changeArea", "泰安市", "370900");
            option.series[0].data = convertData1(taiandata);
            option.series[1].data = taiandata;
            option.series[2].data = [];
            myChart.setOption(option, true); // 赋值后初始化
            setTimeout(() => {
              // 定时后启动飞线
              myChart.setOption(option, true);
            }, 500);
          } else if (name == "聊城市") {
            that.ifShow = false;
            that.cityName = "聊城市";
            that.cityCode = "371500";
            that.getLonLat();
            that.getSixData();
            that.$emit("changeArea", "聊城市", "371500");
            option.series[0].data = convertData1(liaochengdata);
            option.series[1].data = liaochengdata;
            option.series[2].data = [];
            myChart.setOption(option, true); // 赋值后初始化
            setTimeout(() => {
              // 定时后启动飞线
              myChart.setOption(option, true);
            }, 500);
          } else if (name == "济宁市") {
            that.ifShow = false;
            that.cityName = "济宁市";
            that.cityCode = "370800";
            that.getLonLat();
            that.getSixData();
            that.$emit("changeArea", "济宁市", "370800");
            option.series[0].data = convertData1(jiningdata);
            option.series[1].data = jiningdata;
            option.series[2].data = [];
            myChart.setOption(option, true); // 赋值后初始化
            setTimeout(() => {
              // 定时后启动飞线
              myChart.setOption(option, true);
            }, 500);
          } else if (name == "德州市") {
            that.ifShow = false;
            that.cityName = "德州市";
            that.cityCode = "371400";
            that.getLonLat();
            that.getSixData();
            that.$emit("changeArea", "德州市", "371400");
            option.series[0].data = convertData1(dezhoudata);
            option.series[1].data = dezhoudata;
            option.series[2].data = [];
            myChart.setOption(option, true); // 赋值后初始化
            setTimeout(() => {
              // 定时后启动飞线
              myChart.setOption(option, true);
            }, 500);
          }
        },
        // 数据展示
        data: [],
      };

      var defaultOpt = {
        mapName: "china", // 地图展示
        goDown: true, // 是否下钻
        bgColor: "#013954", // 画布背景色
        activeArea: [], // 区域高亮,同echarts配置项
        data: [],
        // 下钻回调(点击的地图名、实例对象option、实例对象)
        callback: function () {},
        // callback: function (name, option, instance) {},
      };
      var opt1 = "";
      if (opt) {
        opt1 = $.extend(defaultOpt, opt);
      }

      // 层级索引
      var name = [opt1.mapName];
      var idx = 0;
      var pos = {
        //层级位置
        leftPlus: 55,
        leftCur: 50,
        left: 10,
        top: 10,
      };

      var line = [
        //箭头
        [0, 0],
        [8, 11],
        [0, 22],
      ];

      // 头部导航style样式
      var style = {
        font: '18px "Microsoft YaHei", sans-serif',
        textColor: "#eee",
        lineColor: "rgba(147, 235, 248, .8)",
      };

      var handleEvents = {
        /**
         * i 实例对象
         * o option
         * n 地图名
         **/
        resetOption: function (i, o, n) {
          console.log(i);
          console.log(o);
          console.log(n);
          var breadcrumb = this.createBreadcrumb(n);

          var j = name.indexOf(n);
          var l = o.graphic.length;
          if (j < 0) {
            console.log("jinru1");
            o.graphic.push(breadcrumb);
            o.series = series;
            o.graphic[0].children[0].shape.x2 = 195;
            o.graphic[0].children[1].shape.x2 = 195;
            if (o.graphic.length > 2) {
              for (var x = 0; x < opt1.data.length; x++) {
                if (n === opt1.data[x].name + "市") {
                  o.series[0].data = handleEvents.initSeriesData(
                    opt1.data[x].data
                  );
                  break;
                } else o.series[0].data = [];
              }
            }
            name.push(n);
            idx++;
          } else {
            console.log("jinru2", j);
            o.graphic.splice(j + 2, l);
            if (o.graphic.length <= 2) {
              o.graphic[0].children[0].shape.x2 = 85;
              o.graphic[0].children[1].shape.x2 = 85;
              o.series[0].data = handleEvents.initSeriesData(data_tmp);
              o.series[0].symbol = zuanshi;
              o.series[0].symbolSize = 30;
              o.series[2].data = handleEvents.initSeriesData(data_tmp);
            }
            name.splice(j + 1, l);
            idx = j;
            pos.leftCur -= pos.leftPlus * (l - j - 1);
          }

          o.geo.map = n;
          o.geo.zoom = 1;
          i.clear();
          i.setOption(o);
          this.zoomAnimation();
          opt1.callback(n, o, i);
        },

        createBreadcrumb: function (name) {
          var cityToPinyin = {
            济南市: "jinan",
            青岛市: "qingdao",
            烟台市: "yantai",
            潍坊市: "weifang",
            菏泽市: "heze",
            日照市: "rizhao",
            威海市: "weihai",
            枣庄市: "zaozhuang",
            临沂市: "linyi",
            滨州市: "bingzhou",
            东营市: "dongying",
            淄博市: "zibo",
            泰安市: "taian",
            聊城市: "liaocheng",
            济宁市: "jining",
            德州市: "dezhou",
          };
          var breadcrumb = {
            type: "group",
            id: name,
            left: pos.leftCur + pos.leftPlus,
            top: pos.top + 3,
            children: [
              {
                type: "polyline",
                left: -90,
                top: -5,
                shape: {
                  points: line,
                },
                style: {
                  stroke: "#fff",
                  key: name,
                },
                onclick: function () {
                  var name = this.style.key;
                  handleEvents.resetOption(myChart, option, name);
                },
              },
              {
                type: "text",
                left: -68,
                top: "middle",
                style: {
                  text: name,
                  textAlign: "center",
                  fill: style.textColor,
                  font: style.font,
                },
                onclick: function () {
                  var name = this.style.text;
                  handleEvents.resetOption(myChart, option, name);
                },
              },
              {
                type: "text",
                left: -68,
                top: 10,
                style: {
                  name: name,
                  text: cityToPinyin[name]
                    ? cityToPinyin[name].toUpperCase()
                    : "",
                  textAlign: "center",
                  fill: style.textColor,
                  font: '12px "Microsoft YaHei", sans-serif',
                },
                onclick: function () {
                  // console.log(this.style);
                  var name = this.style.name;
                  handleEvents.resetOption(myChart, option, name);
                },
              },
            ],
          };

          pos.leftCur += pos.leftPlus;

          return breadcrumb;
        },

        // 设置effectscatter
        initSeriesData: function (data) {
          console.log(data, "22222222222");
          var temp = [];
          for (var i = 0; i < data.length; i++) {
            var geoCoord = sdGeoCoordMap[data[i].name];
            if (geoCoord) {
              temp.push({
                name: data[i].name,
                value: geoCoord.concat(data[i].value, data[i].level),
              });
            }
          }
          return temp;
        },

        zoomAnimation: function () {
          var count = null;
          var zoom = function (per) {
            if (!count) count = per;
            count = count + per;
            // console.log(per,count);
            myChart.setOption({
              geo: {
                zoom: count,
              },
            });
            if (count < 1)
              window.requestAnimationFrame(function () {
                zoom(0.2);
              });
          };
          window.requestAnimationFrame(function () {
            zoom(0.2);
          });
        },
      };

      var iconYellow =
        "image://";
      var iconGreen =
        "image://";
      var iconBlue =
        "image://";
      var iconRed =
        "image://";
      var mapTextBack =
        "image://";
      var zuanshi =
        "image://";

      var convertData = function (data) {
        data.forEach((item) => {
          item.symbol =
            item.value[2] < 1
              ? iconYellow
              : item.value[2] < 6 && item.value[2] >= 1
              ? iconGreen
              : iconBlue;
          item.symbolSize = 20;
        });
        return data;
      };

      var convertData1 = function (data) {
        data.forEach((item) => {
          item.symbol = iconYellow;
          item.symbolSize = 20;
        });
        return data;
      };
      var symbolFunc = function (data) {
        var iconColor;
        data.forEach((item) => {
          iconColor =
            item.coalAvaDay < 7
              ? iconRed
              : item.coalAvaDay > 14
              ? iconGreen
              : iconYellow;
        });
        return iconColor;
      };

      var data_tmp = [
        { name: "济南市", value: 24 },
        { name: "青岛市", value: 48 },
        { name: "烟台市", value: 48 },
        { name: "潍坊市", value: 61 },
        { name: "菏泽市", value: 22 },
        { name: "日照市", value: 18 },
        { name: "威海市", value: 35 },
        { name: "枣庄市", value: 20 },
        { name: "临沂市", value: 52 },
        { name: "滨州市", value: 88 },
        { name: "东营市", value: 30 },
        { name: "淄博市", value: 30 },
        { name: "泰安市", value: 36 },
        { name: "聊城市", value: 46 },
        { name: "济宁市", value: 56 },
        { name: "德州市", value: 28 },
      ];

      var converntData = function (data) {
        var res = [];
        for (var i = 0; i < data.length; i++) {
          var geoCoord = sdGeoCoordMap[data[i].name];
          if (geoCoord) {
            res.push({
              name: data[i].name,
              value: geoCoord.concat(data[i].value),
            });
          }
        }
        return res;
      };

      var series = [];
      [["济南市", data_tmp]].forEach(function (item, i) {
        series.push(
          // 下面圆点
          {
            symbol: zuanshi,
            symbolSize: 30,
            label: {
              normal: {
                formatter: "{b}",
                position: "right",
                show: false, //是否显示地名
              },
              emphasis: {
                show: true,
              },
            },
            itemStyle: {
              normal: {
                color: "#fff",
              },
            },
            name: "light",
            type: "scatter",
            coordinateSystem: "geo",
            data: converntData(
              data_tmp
                .sort(function (a, b) {
                  return b.value - a.value;
                })
                .slice(0, 20)
            ),
            showEffectOn: "render",
            rippleEffect: {
              brushType: "stroke",
            },
            hoverAnimation: true,
          },
          {
            type: "map",
            map: "china",
            geoIndex: 0,
            aspectScale: 0.75, //长宽比
            showLegendSymbol: false, // 存在legend时显示
            label: {
              normal: {
                show: false,
              },
              emphasis: {
                show: false,
                textStyle: {
                  color: "#fff",
                },
              },
            },
            roam: true,
            itemStyle: {
              normal: {
                areaColor: "#031525",
                borderColor: "#FFFFFF",
              },
              emphasis: {
                areaColor: "#2B91B7",
              },
            },
            animation: false,
            data: data_tmp,
          },
          // 黄圈圈
          {
            name: "Top 5",
            type: "scatter",
            coordinateSystem: "geo",
            symbol: mapTextBack,
            symbolSize: [70, 30],
            symbolOffset: [0, -33],
            label: {
              normal: {
                show: true,
                textStyle: {
                  fontSize: 12,
                  fontFamily: "Adobe Heiti Std",
                  fontWeight: "bold",
                  color: "#FFFFFF",
                },
                formatter(value) {
                  if (value.length > 2) {
                    return "值是:" + value.data.value[2];
                  } else {
                    return value.data.name;
                  }
                },
              },
            },
            itemStyle: {
              normal: {
                color: "#dfae10", //标志颜色
              },
            },
            data: converntData(
              data_tmp
                .sort(function (a, b) {
                  return b.value - a.value;
                })
                .slice(0, 20)
            ), // 流量最大的前
            showEffectOn: "render",
            rippleEffect: {
              brushType: "stroke",
            },
            hoverAnimation: true,
            zlevel: 1,
          }
        );
      });

      console.log("series");
      console.log(series);

      var that = this;
      var option = {
        tooltip: {
          trigger: "item",
          backgroundColor: "rgba(0,0,0,0)",
          formatter: function (item) {
            console.log(item, "item!!!!");
            if (item.componentSubType === "lines") {
              var tipHtml1 = "";
              tipHtml1 =
                '
' + '
' + item.data.name + "
"
+ '
' + '' + "在运机组数:" + item.data.value + " " + "" + "
"
+ "
"
; return tipHtml1; } else if (item.componentSubType === "effectScatter") { var tipHtml2 = ""; tipHtml2 = '
' + '
' + item.data.name + "
"
+ '
' + '' + "在运机组数:" + item.data.value[2] + " " + "" + "
"
+ "
"
; return tipHtml2; } else if (item.componentSubType === "scatter") { var tipHtml3 = ""; tipHtml3 = '
' + '
' + item.data.name + "
"
+ '
' + '' + "在运机组数:" + item.data.value[2] + " " + "" + "
"
+ "
"
; return tipHtml3; } }, }, backgroundColor: "rgb(0,0,0,0)", //背景色透明 graphic: [ { type: "group", left: pos.left, top: pos.top - 4, children: [ { type: "line", left: 0, top: -20, shape: { x1: 0, y1: 0, x2: 85, y2: 0, }, style: { stroke: style.lineColor, }, }, { type: "line", left: 0, top: 20, shape: { x1: 0, y1: 0, x2: 85, y2: 0, }, style: { stroke: style.lineColor, }, }, ], }, { id: name[idx], type: "group", left: pos.left + 2, top: pos.top, children: [ { type: "polyline", left: 90, top: -12, shape: { points: line, }, style: { stroke: "transparent", key: name[0], }, onclick: function () { var name = this.style.key; handleEvents.resetOption(myChart, option, name); }, }, { type: "text", left: 0, top: "middle", style: { text: name[0] === "山东" ? "山东省" : name[0], textAlign: "center", fill: style.textColor, font: style.font, }, onclick: function () { that.ifShow = true; that.$emit("changeArea", "山东省"); handleEvents.resetOption(myChart, option, "山东"); }, }, { type: "text", left: 0, top: 10, style: { text: "SHANDONG", textAlign: "center", fill: style.textColor, font: '12px "Microsoft YaHei", sans-serif', }, onclick: function () { that.ifShow = true; that.$emit("changeArea", "山东省"); handleEvents.resetOption(myChart, option, "山东"); }, }, ], }, ], // 暂时先注释 // visualMap: { // //图例值控制 // min: 0, // max: 1, // calculable: true, // show: false, // color: ["#f44336", "#fc9700", "#ffde00", "#ffde00", "#00eaff"], // textStyle: { // color: "#fff", // }, // }, geo: { map: "山东", layoutCenter: ["55%", "50%"], layoutSize: "135%", label: { normal: { show: true, textStyle: { color: "#fff", }, }, emphasis: { textStyle: { color: "#fff", }, }, }, roam: true, //是否允许缩放 mapLocation: { width: "110%", height: "97%", }, itemStyle: { normal: { borderColor: "rgba(147, 235, 248, 1)", borderWidth: 1, areaColor: { type: "radial", x: 0.5, y: 0.5, r: 0.8, colorStops: [ { offset: 0, color: "rgba(147, 235, 248, 0)", // 0% 处的颜色 }, { offset: 1, color: "rgba(147, 235, 248, .2)", // 100% 处的颜色 }, ], globalCoord: false, // 缺省为 false }, shadowColor: "rgba(128, 217, 248, 1)", // shadowColor: 'rgba(255, 255, 255, 1)', shadowOffsetX: -2, shadowOffsetY: 2, shadowBlur: 10, }, emphasis: { itemStyle: { areaColor: "#FFD181", borderColor: "#404a59", borderWidth: 1, }, }, }, }, series: series, }; myChart.setOption(option); myChart.on("click", function (params) { var _self = this; if (cityMap[params.name]) { var url = cityMap[params.name]; echarts.registerMap(params.name, url); handleEvents.resetOption(_self, option, params.name); } }); },

代码量比较多,里面有一些冗余代码,大家可以自行选择是否删除
另外,我贴出的代码只包含地图部分,截图中的图例之类的,这里不做解释,欢迎大家留言讨论!

你可能感兴趣的:(vue.js,elementui,echarts,json,地图)