echarts默认高亮省市区联动

在这里插入图片描述

选中省份联动对应的二级市或三级区县,有项目的地区进行高亮标点,浮窗显示具体数值

//main.js 引入echarts
import * as echarts from 'echarts';
Vue.prototype.$echarts = echarts
<!--父组件   全国地图-->
<div class="map" id="map"></div>
<script>
  //引用地址在下方
  import china from '/public/json/china.json'
  import { Mapprovinces, MapprovincesText } from "./provinces.js";
  export default {
	data(){
      return{
        Mapprovinces,
        MapprovincesText,
        provinceInfo: {},
        projectMapVis:false
      }
    },
    mounted(){
      this.init()
    },
    methods:{
    // 该需求为通过点击省份获取该省份下的所有市(二级)/区县(三级)
	  init(){
   	    this.$echarts.registerMap('china', china);
        const provinceList = china.features;
        // axios 获取后端数据,通过循环对比获取对应的经纬度,进行标点
        /**
        let res = 'api/xxxxxxx'
        provinceList.filter(pl => {
          res.filter(al => {
            if (al.areaCode === pl.id) {
              projectNums.push({
                name: pl.properties.name,
                value: al.num,
              })
              effectScatterData.push({
                name: pl.properties.name,
                value: pl.properties.cp,
                num: al.num
              })
            }
          })
        })
        */
        // 所需数据格式
        let projectNums = [{name:'云南',value:5},{name:'广西',value:1}]; // 项目省份
        let effectScatterData = [
 		  {name:'云南',value:[101.712251, 24.040609],num:5},
 		  {name:'广西',value:[108.720004, 23.82402],num:1}
        ]; //散点数据
        const myChart = this.$echarts.init(document.getElementById('map'), null, {renderer: 'svg'});
        let option = {
          tooltip: {//提示框组件
            trigger: 'item',
            formatter: function (item) {
              if (item.componentSubType == 'map' && item.value) {
                return item.name + `<strong style="fontStyle:normal">${item.value}</strong>`
              } else if (item.componentSubType == 'effectScatter' && item.data.num) {
                return item.name + `<strong style="fontStyle:normal">${item.data.num}</strong>`
              } else {
                return item.name
              }
            },
            show: true,
            borderColor: '#fff',
            padding: [4, 15],
            textStyle: {
              color: "#262F3F",
              fontSize: 10
            }
          },
          geo: {
            map: 'china',
            aspectScale: 0.75,
            selectedMode: false,
            layoutCenter: ["50%", "50%"], 
            layoutSize: '100%',
            regions: [{
              name: '南海诸岛',
              itemStyle: {
                areaColor: 'rgba(0, 10, 52, 1)',
                borderColor: '#aee9fb',
                normal: {
                  opacity: 0,
                  label: {
                    show: false,
                    color: "#009cc9",
                  }
                },
              },
              label: {
                show: false,
                color: '#262F3F',
                fontSize: 10,
              },
            }],
          },
          visualMap: {
            show: false,
            min: 1,
            inRange: {
              color: ['#EFF4F9']
            },
          },
          series: [
            // 常规地图
            {
              type: 'map',
              mapType: 'china',
              aspectScale: 0.75, 
              layoutCenter: ["50%", "50%"], 
              layoutSize: '100%', 
              label: {
                show: true, //区域
                formatter: '{b}',
                color: '#262F3F',
                fontSize: 10,
              },
              itemStyle: { // 区域样式
                normal: {
                  areaColor: {
                    type: 'linear',
                    x: 0,
                    y: 0,
                    x2: 1,
                    y2: 1,
                    colorStops: [{
                      offset: 0, color: '#D7E0EC' 
                    }, {
                      offset: 1, color: '#D1DBE8' 
                    }],
                    global: false 
                  },  // 背景
                  borderColor: '#A1AFC6',
                  borderWidth: 1
                },
                emphasis: { // 区域hover样式
                  areaColor: 'pink',
                  label: {
                    color: "#262F3F"
                  }
                },
              },
              select: { // 区域选中样式
                itemStyle: {
                  areaColor: 'pink'
                },
                label: {
                  color: "#262F3F"
                }
              },
              data: projectNums
            },
            {
              type: 'effectScatter',
              coordinateSystem: 'geo',
              symbolSize: 4,
              rippleEffect: { //点动画
                color: '#0051D9',
                period: 3,
                scale: 5,
                brushType: 'fill'
              },
              // 坐标点
              data: effectScatterData,
              symbolOffset: ['-150%', '-150%'] // 光标偏移
            },
          ]
        };
        let that = this
        myChart.on('click', function (params) {
          if (params.name == '南海诸岛') { return }
          provinceList.filter(pl => {
            if (pl.properties.name === params.name) {
              params.areaCode = pl.id
            }
          })
          //点击省份显示二级或三级(市、区县地图)
          that.projectMapVis = true;
          myChart.setOption(option);
          that.provinceInfo = params  // 子组件用
        });
        myChart.setOption(option);
        window.addEventListener("resize", function () {
          myChart.resize();
        });
      }
    }
  }
</script>
<!--子组件  根据所选省份联动的市/区县地图-->
<div class="map" id="provinceMap"></div>
<script>
import axios from "axios";
import { MapprovincesText, Mapprovinces } from "./provinces.js";
export default {
  data () {
    return {
      MapprovincesText,
      Mapprovinces
    }
  },
  methods:{
    // 省份点击后调用 传递 provinceInfo 参数
    getCity(params){
       for (var i = 0; i < this.MapprovincesText.length; i++) {
        if (params.name == this.MapprovincesText[i]) {
          //点击获取对应城市数据 
          const name = this.Mapprovinces[i]
          //JSON数据在下方 来源datav
          let url = '/json/province/' + name + '.json';
          axios.get(url).then(res => {
            this.canvasProvinceMap(name, params.areaCode, res.data)
          })
          break;
        }
      }
    },
    //绘制
    canvasProvinceMap: function (name, areaCode, mapData) {
      let _this = this;
      const params = {
        queryRange: "province",
        queryValue: areaCode
      }
      axios.get('xxxxxx').then(res => {
        const regionMapData = mapData.features;
        let projectNumData = [];
        let effectScatterData = [];
        regionMapData.filter(pl => {
          res.filter(al => {
            if (al.areaCode == pl.properties.adcode) {
              projectNumData.push({
                name: pl.properties.name,
                value: al.num,
                areaCode: al.areaCode
              })
              effectScatterData.push({
                areaCode: al.areaCode,
                name: pl.properties.name,
                // value: al.coordinate.split(','),
                value: pl.properties.centroid,
                num: al.num
              })
            }
          })
        })
        const provinceChart = this.$echarts.init(document.getElementById('provinceMap'), null, { renderer: 'svg' });
        this.$echarts.registerMap(name, mapData);
        //移除点击事件
        provinceChart.off('click')
        // 绘制图表
        let option = {
          tooltip: {
            trigger: 'item',
            formatter: function (item) {
              if (item.componentSubType == 'map' && item.value) {
                return item.name + item.value
              } else if (item.componentSubType == 'effectScatter' && item.data.num) {
                return item.name + item.data.num
              } else {
                return item.name
              }
            },
            show: true,
            borderColor: '#fff',
            padding: [4, 15],
            textStyle: {
              color: "#262F3F",
              fontSize: 8
            }
          },
          geo: {
            type: 'map',
            map: name,   //省份
            selectedMode: false,
            aspectScale: 0.75,
            layoutCenter: ["50%", "50%"],
            layoutSize: '100%',
            roam: true, //是否平游或缩放
            scaleLimit: { //滚轮缩放的极限控制
              min: 1,
              max: 30
            },
            label: {
              show: true, //区域名称样式
              color: '#262F3F',
              fontSize: 8
            },
            itemStyle: { // 区域样式
              normal: {
                areaColor: '#EFF4F9',// 背景
                borderColor: '#A1AFC6',
                borderWidth: 1
              },
              emphasis: { // 区域hover样式
                areaColor: 'pink',
                label: {
                  color: "#262F3F",
                  fontSize: 8,
                }
              },
            },
            select: { // 选中样式
              itemStyle: {
                areaColor: '#BCDAFF'
              }
            },
          },
          visualMap: {
            show: false,
            min: 1,
            inRange: {
              color: ['#BCDAFF']
            },
          },
          series: [
            {
              type: 'map',
              mapType: name,
              geoIndex: 0,
              aspectScale: 0.75,
              layoutCenter: ["50%", "50%"],
              layoutSize: '100%',
              data: projectNumData
            },
            // 区域散点图
            {
              type: 'effectScatter',
              coordinateSystem: 'geo',
              symbolSize: 3,
              rippleEffect: { //点动画
                color: '#0051D9',
                period: 3,
                scale: 3,
                brushType: 'fill'
              },
              data: effectScatterData
            }
          ]
        };
        //散点点击事件
        provinceChart.on('click', function (params) {
          
        });
        provinceChart.clear();
        setTimeout(() => {
          provinceChart.setOption(option);
        }, 300)
        window.addEventListener("resize", function () {
          provinceChart.resize();
        });
      })
    },
  }
}
</script>

静态资源

//provinces.js
const iconRQ = "image://"
const Mapprovinces = ['shanghai', 'hebei', 'shanxi', 'neimenggu', 'liaoning', 'jilin', 'heilongjiang', 'jiangsu', 'zhejiang', 'anhui', 'fujian', 'jiangxi', 'shandong', 'henan', 'hubei', 'hunan', 'guangdong', 'guangxi', 'hainan', 'sichuan', 'guizhou', 'yunnan', 'xizang', 'shanxi1', 'gansu', 'qinghai', 'ningxia', 'xinjiang', 'beijing', 'tianjin', 'chongqing', 'xianggang', 'aomen', 'taiwan'];
const MapprovincesText = ['上海', '河北', '山西', '内蒙古', '辽宁', '吉林', '黑龙江', '江苏', '浙江', '安徽', '福建', '江西', '山东', '河南', '湖北', '湖南', '广东', '广西', '海南', '四川', '贵州', '云南', '西藏', '陕西', '甘肃', '青海', '宁夏', '新疆', '北京', '天津', '重庆', '香港', '澳门', '台湾'];
export {
  iconRQ,
  Mapprovinces,
  MapprovincesText,
};

全国地图数据及省市json数据

评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值