Vue3.x使用Echarts绘制世界地图并进行定点

Vue3.x使用Echarts绘制世界地图并进行定点

一、需求

  • 绘制世界地图并根据返回经纬度数据进行定点
  • 将定点数据展示在世界地图内

二、解决

<template>
    <div>
        ...
		<div id="worldgraph"></div>
    </div>
</template>

<script setup>
import * as echarts from 'echarts';
import worldData from '@/assets/json/world.json';
import { ref, onMounted, onUnmounted } from 'vue';

// 世界地图画布
const worldGraph = ref(null);

/* 挂载 */
onMounted(() => {
    initData()
})
/* 卸载 */
onUnmounted(() => {
  if (worldGraph.value) {
    worldGraph.value.dispose();
    worldGraph.value = null;
  }
});
/* 初始化IP画像数据 */
const initData = () => {
    if (worldGraph.value) {
        worldGraph.value.dispose();
        worldGraph.value = null;
    }
    const point = []
    // 添加美国坐标点
    point.push({
        name: '美国',
        value: [-97.822, 37.751 + 15], // +15使定点坐标位置正确
        type: 'iconData'
    })
    drawnWorldChart(point)
};
/* 绘制世界地图图谱 */
const drawnWorldChart = (point) => {
  if (!document.getElementById('ipprotrait-worldgraph')) {
    return;
  }
  echarts.registerMap('world', JSON.stringify(worldData));
  worldGraph.value = echarts.init(document.getElementById('ipprotrait-worldgraph'));
  let option = {
    grid: {
      width: '100%',
      height: '100%',
      left: '0%',
      right: '0%',
      bottom: '0%',
      containLabel: true
    },
    geo: {
      type: 'map',
      map: 'world',
      aspectScale: 0.85,
      emphasis: {
        label: {
          show: false
        },
        itemStyle: {
          areaColor: '#F6FBFF',
          borderColor: '#CEE0E7',
        }
      },
      zoom: 1.2,
      itemStyle: {
        areaColor: '#F6FBFF',
        borderColor: '#CEE0E7',
      },
    },
    series: [
      // 标记点
      {
        type: 'scatter',
        coordinateSystem: 'geo',
        symbolSize: 30,
        symbol: 'image://',
        // rippleEffect: { // 坐标点动画
        //   period: 2,
        //   scale: 4,
        //   brushType: 'fill'
        // },
        label: {
          show: false,
        },
        data: point,
        // itemStyle: { // 坐标点颜色
        //   show: true,
        //   color: '#F53F3F',
        //   shadowColor: '#fff'
        // }
      }
    ]
  };
  worldGraph.value.setOption(option);
};
</script>
  • 最后效果图如下:
    在这里插入图片描述
  • 3
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值