前端大屏展示可视化——地图的绘制(Echarts)

在这里插入图片描述

1、安装

文档

npm install echarts

2、引入

import * as echarts from 'echarts';

3、渲染

3.1、前期准备,基础配置
// 地图实例
const myChart = ref(null);
// 地图配置
const option = reactive({
  tooltip: {
    trigger: 'item',
    formatter: function (params) {
      return params.name + ':' + (params.value || 0);
    },
  },
  series: [
    // 地图配置
    {
      type: "map",
      geoIndex: 0,
      data: [{
        name: '杭州市',
        value: '333'
      },{
        name: '湖州市',
        value: '444'
      }],
    },
  ],
  geo: [{
    map: "map_area",
    layoutCenter: ['50%', '50%'],
    layoutSize: '92%',
    z: 2,
    label: {
      show: true,
      fontSize: 13,
      color: '#1bfeff',
    },
  }]
})
3.2、初始化

首先要现在HTML中定义一个有宽高的容器

<div id="mainMap" style="width: 100%;height: 100%;"></div>

获取节点,初始化实例

myChart.value = echarts.init(document.getElementById('mainMap'));
3.3、监听

监听窗口大小的变化

  window.addEventListener("resize", () => {
    if (myChart.value) myChart.value.resize();
  })
3.4、渲染加载

geoJSON数据可通过接口获取,或自行下载保存到本地,自行引入,建议通过接口获取


  echarts.registerMap("map_area", geoJSON);
  myChart.value.setOption(option);
3.5、销毁
  window.removeEventListener("resize", () => {
    if (myChart.value) myChart.value.resize();
  })
  if (myChart.value) myChart.value.dispose()

4、完整代码

<script setup>
import * as echarts from 'echarts';
import { onMounted, reactive, ref, onBeforeUnmount } from 'vue';
import geoJSON from './geo.json';

defineOptions({name: 'echarts'});
onMounted(() => {
  loadEchartsMap();
});

// 地图实例
const myChart = ref(null);
// 地图配置
const option = reactive({
  tooltip: {
    trigger: 'item',
    formatter: function (params) {
      return params.name + ':' + (params.value || 0);
    },
  },
  series: [
    // 地图配置
    {
      type: "map",
      geoIndex: 0,
      data: [{
        name: '杭州市',
        value: '333'
      },{
        name: '湖州市',
        value: '444'
      }],
    },
  ],
  geo: [{
    map: "map_area",
    layoutCenter: ['50%', '50%'],
    layoutSize: '92%',
    z: 2,
    label: {
      show: true,
      fontSize: 13,
      color: '#1bfeff',
    },
  }]
})
// 加载Echarts地图
const loadEchartsMap = () => {
  // 初始化
  myChart.value = echarts.init(document.getElementById('mainMap'));
  // 监听窗口大小变化
  window.addEventListener("resize", () => {
    if (myChart.value) myChart.value.resize();
  })
  // 点击事件
  myChart.value.on('click', (mapParams) => {
    console.log('click', mapParams);
  });
  // 鼠标移入事件
  myChart.value.on('mouseover', (mapParams) => {
    console.log('mouseover', mapParams);
  });
  // 鼠标移出事件
  myChart.value.on('mouseout', (mapParams) => {
    console.log('mouseout', mapParams);
  });
  // 加载地图
  echarts.registerMap("map_area", geoJSON);
  myChart.value.setOption(option);
}

// 销毁
onBeforeUnmount(() => {
  window.removeEventListener("resize", () => {
    if (myChart.value) myChart.value.resize();
  })
  if (myChart.value) myChart.value.dispose()
})

// 子组件暴露
defineExpose({});

</script>

<template>
  <div id="mainMap" style="width: 100%;height: 100%;"></div>
</template>

<style lang="less" scoped>

</style>

5、其他扩展

5.1、加入事件

要在实例渲染之前执行

  // 点击事件
  myChart.value.on('click', (mapParams) => {
    console.log('click', mapParams);
  });
  // 鼠标移入事件
  myChart.value.on('mouseover', (mapParams) => {
    console.log('mouseover', mapParams);
  });
  // 鼠标移出事件
  myChart.value.on('mouseout', (mapParams) => {
    console.log('mouseout', mapParams);
  });
5.2、背景色/纹理填充

在这里插入图片描述

在这里插入图片描述

// 地图配置
const option = reactive({
  tooltip: {
    trigger: 'item',
    formatter: function (params) {
      return params.name + ':' + (params.value || 0);
    },
  },
  series: [
    // 地图配置
    {
      type: "map",
      map: "map_area",
      layoutCenter: ['50%', '50%'],
      layoutSize: '92%',
      z: 2,
      label: {
        show: true,
        fontSize: 13,
        color: '#1bfeff',
      },
      // itemStyle: {
      //   // borderColor: '#5ec8f3', // 图形的描边颜色
      //   // borderWidth: 1.8,
      //   // borderType: 'dotted', // 描边类型
      //   // opacity: .7,
      //   areaColor: '#9967FB'
      // },
      itemStyle: { // 地图区域的多边形 图形样式。
        borderColor: '#5ec8f3', // 图形的描边颜色
        borderWidth: 1.8,
        borderType: 'dotted', // 描边类型
        // color: "#010e3b", // 图形颜色
        opacity: .7,
        areaColor: {
          image: map_bg, // 支持为 HTMLImageElement, HTMLCanvasElement,不支持路径字符串
          repeat: 'repeat' // 是否平铺,可以是 'repeat-x', 'repeat-y', 'no-repeat'
        },
      },
      data: [{
        name: '杭州市',
        value: '333'
      },{
        name: '湖州市',
        value: '444'
      }],
    },
  ],
})
  • 5
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
基于echarts可以实现强大的可视化大屏展示,通过将数据以图形的方式展现出来,使得数据更加直观和易于理解。 首先,我们可以使用echarts的各种图表类型,如折线图、柱状图、饼图等来展示数据。可以根据不同的需求选择合适的图表类型,并通过数据的组织和配置,使得图表能够准确地展示数据的趋势、分布等信息。 其次,echarts提供了丰富的交互功能,使得大屏展示更加生动和灵活。我们可以通过鼠标滚动、拖拽等方式来对图表进行交互,改变视角和放大细节,从而更好地理解数据。同时,echarts还支持添加图例、数据标签、工具栏等元素,提高用户的交互体验和数据的可读性。 此外,echarts还支持数据的实时更新和动态展示。我们可以通过定时刷新数据,使得大屏展示能够实时地反映数据的变化。同时,我们还可以通过动画效果,使得数据的变化过程更加平滑和直观,增强大屏展示的吸引力和引导性。 最后,echarts支持跨平台的展示。我们可以将基于echarts可视化大屏展示运行在各种终端上,如PC、手机、平板等。这样方便了数据的展示和分享,在不同的场景和设备上都能够获得良好的可视化体验。 总的来说,基于echarts实现的可视化大屏展示可以帮助我们更好地理解和分析数据,使得数据变得更加有说服力和有影响力。无论是用于商业决策、数据分析、舆情监测等领域,都能够发挥重要的作用。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值