vue + echarts 省份地图 以及打包后地图加载不出来(比较详细)「建议收藏」

vue + echarts 省份地图 以及打包后地图加载不出来(比较详细)「建议收藏」刚开始地图怎么也出不来,经过解决,是因为echarts.min.js引入位置在index.html中引入需要的js版本按照自己需要的来<scriptsrc=”./static/plugins/echarts-5.1.2/echarts.common.min.js”></script><scriptsrc=”./static/plugins/echarts.min.js”></script>(必须引入,地图才能加载)全局引入im

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE稳定放心使用

刚开始地图怎么也出不来,经过解决,是因为echarts.min.js 引入位置

在index.html 中引入需要的js
版本按照自己需要的来
<script src="./static/plugins/echarts-5.1.2/echarts.common.min.js"></script>
<script src="./static/plugins/echarts.min.js"></script>    (必须引入,地图才能加载)
  • 全局引入
import * as echarts from "echarts";
Vue.prototype.$echarts = echarts
  • 局部引入
    我写的时候全局引入没有效果,在页面还是得引入,必须是 * 这样的
import * as vueEcharts from "echarts";
  • 在自己的页面引入需要的省份js
const guangxiJson = require("@/utils/js/guangxi.json");
  • 在该网站上下载需要的地图json(也可以百度搜 都有的)
    http://datav.aliyun.com/tools/atlas/#&lat=30.37018632615852&lng=106.68898666525287&zoom=3.5

1.给一个盒子 宽高必须给

<div class="map" id="mapBox" style="width:100%;height:100%;"></div>

2.在这里调用

mounted() {
    this.$nextTick(() => {
      vueEcharts.registerMap("guangxi", guangxiJson);
        this.guangxiMap();
    });
  },

3.methods (直接复制就好了,里面的标注位置可以自己修改,或者增加)
上面的标注我是根据这个改的
这是标注参照

guangxiMap() {
      // 获取经纬度数据
      const seriesList = [
        {
          // image: zaixian,
          data: [
            {
              value: [106.9, 27.7],
            },
            {
              value: [105.29, 27.32],
            },
            {
              value: [106.04, 27.03],
            },
            {
              value: [104.82, 26.58],
            },
          ],
        },
        {
          // image: shangxian,
          data: [
            {
              value: [107.43, 28.56],
            },
          ],
        },
        {
          // image: lixian,
          data: [
            {
              value: [107.5, 27.76],
            },
          ],
        },
      ];
      // 自定义图标
      const series = seriesList.map((v) => {
        return {
          type: "custom", //配置显示方式为用户自定义
          coordinateSystem: "geo",
          renderItem(params, api) {
            //具体实现自定义图标的方法
            return {
              type: "image",
              style: {
                image: v.image,
                x: api.coord([
                  v.data[params.dataIndex].value[0],
                  v.data[params.dataIndex].value[1],
                ])[0],
                y: api.coord([
                  v.data[params.dataIndex].value[0],
                  v.data[params.dataIndex].value[1],
                ])[1],
                width: "29",
                height: "35",
              },
            };
          },
          data: v.data,
        };
      });
      

      // 上面的标注坐标
      var gdGeoCoordMap = {
        "南宁烟厂": [108.320004, 22.82402],
        "柳州烟厂": [109.411703, 24.314617],
        "桂林市": [110.299121, 25.274215],
        "梧州市": [111.297604, 23.474803],
        "北海市": [109.119254, 21.473343],
        "防城港市": [108.345478, 21.614631],
        "钦州市": [108.624175, 21.967127],
        "贵港市": [109.602146, 23.0936],
        "玉林市": [110.154393, 22.63136],
        "百色市": [106.616285, 23.897742],
        "贺州市": [111.552056, 24.414141],
        "静兰烟厂": [109.455500, 25],
        "来宾市": [109.229772, 23.733766],
        "崇左市": [107.353926, 22.404108]

      };
      //**我上面只写了三个标注,如果需要其他的,在这里继续添加就好了,name必须和上面的一样**
      var data = [{
        name: "南宁烟厂",
        // value: 4,

    },
    {
        name: "柳州烟厂",
        value: 4617,
    },

    {
        name: "静兰烟厂",
        value: 5899,
    },
];
      var img = 'image://'
      var img2 = 'image://'

      var convertData = function(data) {
        var res = [];
        for (var i = 0; i < data.length; i++) {
            var geoCoord = gdGeoCoordMap[data[i].name];
            if (geoCoord) {
                res.push({
                    name: data[i].name,
                    value: geoCoord.concat(data[i].value)
                });
            }
        }
        return res;
      };
      // options
      const distributionOptions = {
        tooltip: {
          show: true, // 鼠标移入是否触发数据
          trigger: "item", // 触发方式
          triggerOn: "click",
          formatter: "名称:{b}<br />坐标:{c}",
        },
        series:[
          {
                tooltip: {
                    show: false,
                },
                type: 'effectScatter',
                coordinateSystem: 'geo',
                rippleEffect: {
                    scale: 10,
                    brushType: 'stroke',
                },
                showEffectOn: 'render',
                itemStyle: {
                    normal: {
                        color: '#00FFFF',
                    }
                },
                label: {
                    normal: {
                        color: '#fff',
                    },
                },
                symbol: 'circle',
                symbolSize: [10, 5],
                data: convertData(data),
                zlevel: 1,
            },
            {
                type: 'scatter',
                coordinateSystem: 'geo',
                itemStyle: {
                    color: '#00FFF6',
                },
                symbol: img,
                symbolSize: [32, 41],

                symbolOffset: [0, -20],
                z: 999,
                data: convertData(data),
            },
            {
                type: 'scatter',
                coordinateSystem: 'geo',
                label: {
                    normal: {
                        show: true,
                        formatter: function(params) { 
                            var name = params.name
                            var value = params.value[2]
                            var text = `{
  
  {tline|${name}}`
                            return text;
                        },   
                        color:'#fff',
                        rich: {
                            fline: {
                                padding: [0, 25],
                                color: '#fff',
                                fontSize: 14,
                                fontWeight:400
                            },
                            tline: {
                                padding: [0, 27],
                                color: '#ABF8FF',
                                fontSize: 12,
                            },
                        }
                    },
                    emphasis: {
                        show: true
                    }
                },
                itemStyle: {
                    color: '#00FFF6',

                },
                symbol: img2,
                symbolSize: [100, 50],
                symbolOffset: [0, -60],
                z: 999,
                data: convertData(data),
            }
        ],
        geo: {
          //引入广西省的地图
          map: "guangxi",
          layoutCenter: ["50%", "50%"], //设置后left/right/top/bottom等属性无效
          layoutSize: "90%",
          roam: false, //关闭鼠标缩放和拖动
          zoom: 1,
          label: {
            normal: {
              //静态的时候展示样式
              show: true, //是否显示地图省份得名称
              textStyle: {
                color: "#fff",
                // fontSize: 10,
                fontFamily: "Arial",
              },
            },
            emphasis: {
              show: true,
              //动态展示的样式
              color: "#fff",
            },
          },
          itemStyle: {
            // 设置地图块的相关显示信息
            normal: {
              areaColor: "#1B8ADE",
              borderColor: "#BA6A15",
              borderWidth: 1,
              textStyle: {
                color: "#fff",
              },
              // 地图块凸起
              // shadowBlur: 10,
              // shadowOffsetX: 10
              left: "5%",
              right: "5%",
              top: "5%",
              bottom: "5%",
            },
            emphasis: {
              areaColor: "#BA6A15", // hover效果
              color: "#fff",
            },
          },
        },
      };
      var myChart = vueEcharts.init(document.getElementById("mapBox"));
      myChart.setOption(distributionOptions);
      var that = this
      myChart.on("click", function (params) {
      //点击柳州烟厂的时候,跳转到想跳的页面
        if(params.data.name == '柳州烟厂') {
          that.$router.push({ path: "/faceMonitor" })
        }
      }); 
      window.onresize = function () {
        myChart.resize();
      };
    },

最后如果打包后的地图加载不出来:

找到自己项目里static 里面的 config 文件 (动态加载初始资源)

/**
 * 动态加载初始资源
 */
;(function() {
  var resList = {
    icon: window.SITE_CONFIG.cdnUrl + '/static/img/favicon.ico',
    css: [
      window.SITE_CONFIG.cdnUrl + '/static/css/app.css',
    ],
    js: [
      // 插件, 放置业务之前加载, 以免业务需求依赖插件时, 还未加载出错
      // 插件 - echarts
      window.SITE_CONFIG.cdnUrl + '/static/plugins/echarts-3.8.5/echarts.common.min.js',
      //***在这里引入需要的 js 文件  就可以了!!!!!!!!!!!!!!!!!!很重要***
      window.SITE_CONFIG.cdnUrl + '/static/plugins/echarts.min.js',

    ]
  };

  // 图标
  // 样式
})();

希望可以帮助到大家!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/182653.html原文链接:https://javaforall.cn

【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛

【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...

(0)


相关推荐

发表回复

您的电子邮箱地址不会被公开。

关注全栈程序员社区公众号