首页 > 其他分享 >vue3+vite+echarts集成中国地图

vue3+vite+echarts集成中国地图

时间:2024-09-05 16:14:32浏览次数:11  
标签:map false color 地图 rgba vue3 data echarts vite

前段时间我们的项目有使用到echarts集成中国地图的功能,实际上这个功能我进项目组的时候人家就已经完成了,我这边只是简单复刻了一遍,先看看效果图;

上代码,走起

<template>
  <!-- 第一步:设置地图容器 -->
  <div id="map" style="width: 100vw; height: 100vh"></div>
</template>

<script setup lang="ts">
// 第二步:导入模块
import * as echarts from 'echarts'
import { onMounted, ref, reactive } from 'vue'
import { getCityJson } from '@/apis/map'
import { options } from './index'

// 第三步:存储中国地图JSON数据
let mapData = ref([])
// 第三步:存放echarts实例
let myMap = reactive({})

// 第三步:Vue挂载DOM后执行回调
onMounted(async () => {
  initMap() // 第四步:初始化地图

  // 点击中国地图的事件回调
  myMap.on('click', function (event) {
    if (event?.data?.adcode) {
      switch (event.data.level) {
        // 国/省/市/区
        case 'nation':
        case 'country':
        case 'province':
        case 'city':
          uploadMapData(event.data.adcode + '_full')
          break
        // 县
        case 'district':
          uploadMapData(event.data.adcode)
          break
        // 其他
        default:
          break
      }
    }
  })

  // 空白区域点击回调
  myMap.getZr().on('click', function (event) {
    // 没有 target 意味着鼠标/指针不在任何一个图形元素上,它是从“空白处”触发的。
    if (!event.target) {
      // 点击在了空白处,做些什么。
      uploadMapData()
    }
  })

  // 视图变化既重新渲染
  window.addEventListener('resize', function () {
    myMap.resize()
  })
})

// 第六步:加载地图数据,注册地图
const loadMapData = async (id: string = '100000_full'): Promise<any> => {
  const mapJson = await getCityJson(id) // 获取json数据
  echarts.registerMap('china', mapJson) // 注册地图
  mapData = mapJson.features.map(item => item.properties) // 获取地图数据(一定要加上,不加上的话,通过点击事件下钻时,event内的data数据会是空的)
  myMap.setOption(options(mapData)) //数据渲染
}

// 第五步:更新数据
const uploadMapData = async (id: string = '100000_full'): Promise<void> => {
  await loadMapData(id)
}

// 地图初始化
const initMap = () => {
  // 基于准备好的dom,初始化echarts实例
  myMap = echarts.init(document.getElementById('map'))
  uploadMapData() // 第五步:更新数据(这个方法可以写一些其他逻辑,比如loading,或者加载一些其他数据)
}
</script>

<style scoped lang="scss"></style>

options文件,都是echarts的option配置属性,常量属性symbol 是一个icon来着,你可以删掉

const symbol =
  'image://'

export const options = (
  data: any,
  layoutCenter: string[] = ['50%', '50%'],
  layoutSize: string = '130%'
) => {
  return {
    backgroundColor: 'transparent',
    visualMap: {
      type: 'continuous',
      show: false,
      inRange: {
        color: ['#1858a3', '#1b549f', '#2aa7d1'],
      },
      outOfRange: {
        color: ['#1858a3'],
      },
      splitNumber: 0,
    },
    geo: [
      {
        aspectScale: 0.8,
        layoutCenter: ['50%', '50%'], // 地图中心
        layoutSize, // 地图大小
        show: true,
        map: 'china', // 地图类型-与registerMap注册地图的名字相同
        roam: false, // 是否开启鼠标缩放和平移漫游
        zoom: 0.65, // 当前视角的缩放比例
        label: {
          show: false, // 是否显示标签
          color: '#fff', // 标签字体颜色
        },
        itemStyle: {
          areaColor: '#1b549f',
          borderColor: '#c0f3fb', // 地图边框颜色
          borderWidth: 1.5, // 地图边框宽度
          shadowColor: 'rgba(44, 171, 213, 0.3)',
          shadowOffsetY: 10,
          shadowBlur: 10,
        },
        emphasis: {
          itemStyle: {
            areaColor: 'rgba(0,254,233,0.6)',
          },
        },
        regions: [
          {
            name: '南海诸岛',
            itemStyle: {
              areaColor: 'rgba(0, 10, 52, 1)',
              borderColor: 'rgba(0, 10, 52, 1)',
              normal: {
                opacity: 0,
                label: {
                  show: false,
                  color: '#009cc9',
                },
              },
            },
            label: {
              show: false,
              color: '#FFFFFF',
              fontSize: 12,
            },
          },
        ],
      },
      {
        type: 'map',
        map: 'china',
        zlevel: -2,
        aspectScale: 0.8,
        zoom: 0.65,
        layoutCenter: ['50%', '53%'],
        layoutSize,
        roam: false,
        silent: true,
        itemStyle: {
          borderWidth: 1,
          borderColor: 'rgba(58,149,253,0.6)',
          shadowColor: 'rgba(27,84,159,1)',
          shadowOffsetY: 5,
          shadowBlur: 15,
          areaColor: '#0c235b',
        },
        regions: [
          {
            name: '南海诸岛',
            itemStyle: {
              areaColor: 'rgba(0, 10, 52, 1)',
              borderColor: 'rgba(0, 10, 52, 1)',
              normal: {
                opacity: 0,
                label: {
                  show: false,
                  color: '#009cc9',
                },
              },
            },
            label: {
              show: false,
              color: '#FFFFFF',
              fontSize: 12,
            },
          },
        ],
      },
    ],
    series: [
      {
        type: 'map', // 系列类型-地图
        map: 'china', // 地图类型-与registerMap注册地图的名字相同
        geoIndex: 0,
        roam: true, // 是否开启鼠标缩放和平移漫游
        zlevel: 0,
        aspectScale: 0.8,
        zoom: 0.65, // 当前视角的缩放比例
        animation: false,
        layoutCenter,
        layoutSize,
        data,
      },
      {
        type: 'map', // 系列类型-地图
        map: '中国', // 地图类型-与registerMap注册地图的名字相同
        geoIndex: 0,
        aspectScale: 0.8,
        zoom: 0.65,
        showLegendSymbol: true,
        roam: true,
        label: {
          color: '#fff',
          fontSize: '120%',
          show: true,
        },
        // select: {
        //   disabled: true, // 数据项图形是否能被选中
        // },
        itemStyle: {
          // areaColor: {
          //   type: 'linear',
          //   x: 1200,
          //   y: 0,
          //   x2: 0,
          //   y2: 0,
          //   colorStops: [
          //     {
          //       offset: 0,
          //       color: 'rgba(3,27,78,0.75)',
          //     },
          //     {
          //       offset: 1,
          //       color: 'rgba(58,149,253,0.75)',
          //     },
          //   ],
          //   global: true,
          // },
          borderColor: '#fff',
          borderWidth: 0.2,
        },
        layoutCenter,
        layoutSize, // 地图大小
        animation: false,
        markPoint: {
          symbol: 'none',
        },
        data: [],
      },
      {
        type: 'scatter',
        coordinateSystem: 'geo', // 对应上面定义的地图
        geoIndex: 0,
        zlevel: 5,
        label: {
          show: true,
          formatter: '',
          color: '#54f7f9',
          fontSize: 16,
          fontWeight: 'bold',
        },
        itemStyle: {
          opacity: 1,
        },
        symbol: symbol,
        symbolSize: [20, 20],
        symbolOffset: [0, -20],
        z: 999,
        // data: [[113.280637, 23.125178]],
      },
    ],
  }
}

加载中国地图的json接口

import require from '@/utils/require'

export const getCityJson = (id: string) => {
  return require({
    url: `https://geo.datav.aliyun.com/areas_v3/bound/${id}.json`,
    method: 'GET',
  })
}

目录结构

标签:map,false,color,地图,rgba,vue3,data,echarts,vite
From: https://www.cnblogs.com/i-my-handsome/p/18398711

相关文章

  • 计算机毕业设计springboot+vue3便民医疗服务预约系统 原生微信小程序
    目录博主介绍技术栈开发核心技术具体实现截图前端后端java类核心代码部分展示可行性论证技术可行性详细视频演示系统测试实现思路源码获取博主介绍......
  • 这应该是全网最详细的Vue3.5版本解读kh
    合集-vue3代码修炼秘籍(16)1.答应我,在vue中不要滥用watch好吗?02-292.一文搞懂Vue3defineModel双向绑定:告别繁琐代码!02-043.没有虚拟DOM版本的vue(VueVapor)01-264.有了CompositionAPI后,有些场景或许你不需要pinia了01-235.你不知道的vue3:使用runWithContext实现在非setup期......
  • react中使用echarts关系图
     一,工作需求,展示几类数据关系,可缩放大小,可拖拽位置,在节点之间的连线上展示相关日期,每个节点展示本身信息,并且要求每个关系节点能点击。实现情况如图所示:二,实现过程中遇到的问题: 关系图完美呈现,但关系节点点击后,整个关系图会杂乱无章的浮动,导致不知道点击了哪个关系节点。 ......
  • 这应该是全网最详细的Vue3.5版本解读
    前言Vue3.5正式版在这两天发布了,网上已经有了不少关于Vue3.5版本的解读文章。但是欧阳发现这些文章对3.5中新增的功能介绍都不是很全,所以导致不少同学有个错觉,觉得Vue3.5版本不过如此,选择跳过这个版本等下个大版本再去更新。所以欧阳写了这篇超级详细的Vue3.5版本解读文章,小伙伴......
  • vue3.2 v-model 双向数据绑定实现
    代码实现示例子组件实现双向绑定<template><divclass="component-name"><inputtype="text":value="modelValue"@input="handleChange"/></div></template><scriptsetuplang=&qu......
  • 推荐一款:简单、易懂、功能强大的Vue3可拖拽插件
    第一步:安装npm使用以下命令安装npminstallvue-grid-layout--saveyarn使用以下命令安装yarnaddvue-grid-layout第二步:配置全局变量import{createApp}from'vue'importAppfrom'./App.vue'importVueGridLayoutfrom'vue-grid-layout'//引入layout......
  • 写给懒人的Vue3快速查阅宝典 转载
    原文链接:https://juejin.cn/post/7332435905925890098作者:radawn写了多年React,但是新入职的公司技术栈是Vue,部门后续会升级到Vue3。并且发现身边不少小伙伴是React转Vue,因项目原因需要快速上手,所以输出了一篇学习笔记,方便快速上手查阅。Vue3相对于Vue2有许多改进和新功......
  • Vue3 组件封装的一些技巧和心得 转载
    在日常开发的过程中,使用Vue的组件进行业务拆分,代码解耦是一个很好的选择;今天就来分享一下我在使用Vue3进行组件封装的一些技巧和心得,希望能够帮助到大家;1.组件特性在Vue中组件是一个独立的实例,每个组件都有共通点,就是:属性、插槽、事件、方法;在日常我们使用第三方组件库的时候......
  • Vue3 动态子页面和菜单栏同步
    动态子页面<router-view></router-view>显示子页面的内容main.vue<template><a-layoutid="components-layout-demo-top-side"><the-header-view></the-header-view><a-layoutstyle="padding:24px0;background......
  • React18+TypeScript4+Vue3:‌入门到实战,‌灵活技术选型指南
    React18+TypeScript4+Vue3:‌入门到实战,‌灵活技术选型指南在当今的前端开发领域,‌React、‌TypeScript和Vue是三大热门技术,‌它们各自拥有独特的优势和广泛的应用场景。‌掌握这些技术,‌不仅能够提升你的开发效率,‌还能帮助你在不同项目中做出更加合适的技术选型。‌本文将带......