echart和v-chart设置省市地图

需求:

展示浙江省地图,并给每个市打标注.点击市区域地图切换为对应的市的地图,并给区县打标注.

解决方案:

使用echarts和v-charts开发

注意点:

下载地图数据,可以在阿里云资源下载对应的地图数据,并引入

      positionJsonLink:"https://geo.datav.aliyun.com/areas_v2/bound/330000_full.json",
      position: "zhejiang"

先引入markPoint模块,在:extend="mapExtend"的series中设置markPoint选项,配置项参考https://echarts.apache.org/zh/option.html#series-map.markPoint

1.安装依赖

安装:npm i v-charts echarts -S

main.js中引入(也可以去全局引入https://v-charts.js.org/#/,看个人需求)

//按需引入
import VeLine from 'v-charts/lib/line.common'
import VeBar from 'v-charts/lib/bar.common'
import VeHistogram from 'v-charts/lib/histogram.common'
import VeRing from 'v-charts/lib/ring.common'
import VeMap from 'v-charts/lib/map.common'

import 'v-charts/lib/style.css'

Vue.component(VeLine.name, VeLine)
Vue.component(VeBar.name, VeBar)
Vue.component(VeHistogram.name, VeHistogram)
Vue.component(VeRing.name, VeRing)
Vue.component(VeMap.name, VeMap)

 

2.页面中使用(全部代码)

<template>
  <div class="middleview">
    <div class="maps">
      <div class="tit flexcc">
        <img src="@/assets/img/posi.png" alt="title" />
        <span>浙江省信息展示</span>
      </div>
      <div class="foot flexcc" @click="backZhejiang" v-if="isCity">
        <img src="@/assets/img/back.png" alt="back" />
        <span>返回到浙江省</span>
      </div>
      <div class="map" v-if="mapShow">
        <ve-map
          :data="mapData"
          width="100%"
          height="650px"
          :legend-visible="false"
          :settings="mapSettings"
          :extend="mapExtend"
          :events="mapEvents"
        ></ve-map>
      </div>
    </div>
  </div>
</template>

<script>
import "echarts/lib/component/markPoint"; //引入该模块,不然不会显示标注
export default {
  name: "middleview",
  data() {
    var img =
"image://";
    this.mapSettings = {
      labelMap: {
        siteNum: "直营车场总数",
        spaceNum: "在线车位总数",
        remainSpaceNum: "实时剩余车位"
      },
      // position: "province/zhejiang",
      // roam: "move", //是否开启鼠标缩放和平移漫游
      // zoom:3,
      // aspectScale:1,
      // scaleLimit:{ min: 3, max: 3 },
      mapGrid: {
        left: "3%",
        right: "3%",
        top: "3%",
        bottom: "3%"
      },
      scaleLimit: { min: 1, max: 1 }, //滚轮缩放的极限控制
      itemStyle: {
        areaColor: "#3dF6d4", //rgba(44,245,195.0.1)   "#2CF5C3"
        borderColor: "#6EB8A8",
        borderWidth: 2,
        shadowColor: "rgba(74,166,138,0.5)",
        shadowBlur: 10,
        shadowOffsetX: 10,
        shadowOffsetY: 10,
        emphasis: {
          //高亮状态
          areaColor: "#4eF7e5",
          borderColor: "#8fdaca"
        }
        // normal: {}
      },

      //标签
      label: {
        show: true,
        color: "#5E1D0B",
        fontSize: 12,
        fontWeight: 600,
        align: "center",
        position: "insideTop",
        distance: 55,
        rotate: 30,
        offset: [30, 0],
        lineHeight: 14
        // backgroundColor: {
        //   image: "http://qiniu.renmating.com/map.png",
        //   width:'80px',height:"100px"
        // },
        // formatter: v => {
        //   // console.log(v)
        //   return v.data
        //     ? " \n   " + v.name + "   " + "\n" + v.data.value + " \n \n"
        //     : "";
        // }
      },
      positionJsonLink: "http://qiniu.renmating.com/zhejiang.json",
      // positionJsonLink:"https://geo.datav.aliyun.com/areas_v2/bound/330000_full.json",
      position: "zhejiang"
    };
    this.mapEvents = {
      click: v => {
        // console.log(v);
        if (this.isCity) return;
        this.isCity = !this.isCity;
        this.mapShow = !this.mapShow;
        // this.mapData.rows = [
        //   { areaName: "西湖区", spaceNum: 123, remainSpaceNum: 455, siteNum: 223 },
        //   { areaName: "余杭区", spaceNum: 123, remainSpaceNum: 455, siteNum: 1423 },
        //   { areaName: "上城区", spaceNum: 123, remainSpaceNum: 455, siteNum: 2123 }
        // ];

        this.area.forEach(item => {
          if (item.name === v.name) {
            this.mapSettings.positionJsonLink = item.positionJsonLink;
            this.mapSettings.position = item.position;
            this.areaName = item.name;
            this.getData({ type: "区", areaId: item.areaId });//获取新数据
          }
        });
        this.$nextTick(function() {
          this.mapShow = !this.mapShow;
        });
      }
    };
    
    return {
      areaName: "浙江省",
      isCity: false,
      mapShow: true,
      area: [
        {
          positionJsonLink: "http://qiniu.renmating.com/zhejiang.json",
          position: "zhejiang",
          name: "浙江省",
          areaId: 330000
        },
        {
          positionJsonLink: "http://qiniu.renmating.com/hangzhou.json",
          position: "hangzhou",
          name: "杭州市",
          areaId: 330100
        },
        {
          positionJsonLink: "http://qiniu.renmating.com/huzhou.json",
          position: "huzhou",
          name: "湖州市",
          areaId: 330500
        },
        {
          positionJsonLink: "http://qiniu.renmating.com/jiaxing.json",
          position: "jiaxing",
          name: "嘉兴市",
          areaId: 330400
        },
        {
          positionJsonLink: "http://qiniu.renmating.com/zhoushan.json",
          position: "zhoushan",
          name: "舟山市",
          areaId: 330900
        },
        {
          positionJsonLink: "http://qiniu.renmating.com/shaoxing.json",
          position: "shaoxing",
          name: "绍兴市",
          areaId: 330600
        },
        {
          positionJsonLink: "http://qiniu.renmating.com/ningbo.json",
          position: "ningbo",
          name: "宁波市",
          areaId: 330200
        },
        {
          positionJsonLink: "http://qiniu.renmating.com/jinhua.json",
          position: "jinhua",
          name: "金华市",
          areaId: 330700
        },
        {
          positionJsonLink: "http://qiniu.renmating.com/taizhou.json",
          position: "taizhou",
          name: "台州市",
          areaId: 331000
        },
        {
          positionJsonLink: "http://qiniu.renmating.com/quzhou.json",
          position: "quzhou",
          name: "衢州市",
          areaId: 330800
        },
        {
          positionJsonLink: "http://qiniu.renmating.com/lishui.json",
          position: "lishui",
          name: "丽水市",
          areaId: 331100
        },
        {
          positionJsonLink: "http://qiniu.renmating.com/wenzhou.json",
          position: "wenzhou",
          name: "温州市",
          areaId: 330300
        }
      ],
      mapData: {
        columns: ["areaName", "siteNum", "spaceNum", "remainSpaceNum"],
        rows: [
          { areaName: "杭州市", spaceNum: 123, remainSpaceNum: 455, siteNum: 223 },
          { areaName: "湖州市", spaceNum: 123, remainSpaceNum: 455, siteNum: 1423 },
          { areaName: "嘉兴市", spaceNum: 123, remainSpaceNum: 455, siteNum: 2123 },
          { areaName: "舟山市", spaceNum: 123, remainSpaceNum: 455, siteNum: 4523 },
          { areaName: "绍兴市", spaceNum: 123, remainSpaceNum: 455, siteNum: 1623 },
          { areaName: "宁波市", spaceNum: 123, remainSpaceNum: 455, siteNum: 1723 },
          { areaName: "金华市", spaceNum: 123, remainSpaceNum: 455, siteNum: 1123 },
          { areaName: "台州市", spaceNum: 123, remainSpaceNum: 455, siteNum: 4153 },
          { areaName: "衢州市", spaceNum: 123, remainSpaceNum: 455, siteNum: 3123 },
          { areaName: "丽水市", spaceNum: 123, remainSpaceNum: 455, siteNum: 173 },
          { areaName: "温州市", spaceNum: 123, remainSpaceNum: 455, siteNum: 123 }
        ]
      },
      mapExtend: {
        series: {
          //标注/标点
          markPoint: {
            symbol: img,
            silent:true,
            symbolOffset: [0, -26], //偏移
            symbolSize: [30, 44],
            label: {
              show: true,
              color: "#5E1D0B",
              offset: [0, -6],
              fontSize: 14,
              fontWeight: 900
              // position: 'inside',
              // formatter: v => {
              //   console.log(v);
              //   return v.value;
              // }
            },
            animation: true,
            data: [
              { coord: [120.153576, 30.287459], value: 59 },
              { coord: [121.549792, 29.868388], value: 1 },
              { coord: [120.750865, 30.762653], value: 1 },
              { coord: [120.102398, 30.867198], value: 3 },
              { coord: [120.582112, 29.997117], value: 4 },
              { coord: [122.106863, 30.016028], value: 1 }
            ]
          }
        }
      }
    };
  },
  methods: {
    backZhejiang() {
      this.isCity=!this.isCity
      if(!this.isCity){
        this.mapShow=!this.mapShow
        this.mapSettings.positionJsonLink=this.area[0].positionJsonLink
        this.mapSettings.position=this.area[0].position
        this.$nextTick(function(){
          this.mapShow=!this.mapShow
        })
      }
    },
    getData(data) {
      // /infoSite/screenInfoSite?type=市&areaId=330000
      //type:浙江省传'市',其他市传'区';  areaId传区域编号
      this.$axios.get("/infoSite/screenInfoSite", { params: data }).then(ds => {
        let d = ds.data;
        // console.log(d.data);
        if (d.data && d.data.length) {
          this.mapData.rows = d.data;
          let url="http://qiniu.renmating.com/zhejiang.json"
          this.area.forEach(obj=>{
            obj.areaId===data.areaId?url=obj.positionJsonLink:''
          })
          //引入了jquery,在index.html中直接引入jquery的cdn服务
          $.getJSON(url, json => {
            console.log(json);
            this.mapExtend.series.markPoint.data = [];
            d.data.forEach(v => {
              if (v.siteNum > 0) {
                let item = json.features.find(
                  val => v.areaId === val.properties.adcode
                );
                this.mapExtend.series.markPoint.data.push({
                  coord: item.properties.centroid,
                  value: v.siteNum
                });
              }
            });
            console.log(JSON.stringify(this.mapExtend.series.markPoint.data));
          });
        }
      });
    }
  },
};
</script>

positionJsonLink的值可以去这里下载:阿里云资源

结果:

 

如果图表出现宽高问题,可参考:https://blog.csdn.net/bamboozjy/article/details/107659956

评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值