echarts画四川地图并交互

news2024/9/25 11:10:31

先看成果,点击地图中间点位做相应交互(如弹框详细信息等,这里不做演示)

具体步骤如下

一、具体在DataV.GeoAtlas地理小工具系列 (aliyun.com)这个地址获取数据如图即可下载出对应地址的json数据

二、vue中template里相关代码

<div id="chartDom" ref="chartDom" v-correctZoom></div>

三、js相关代码

3.1 获取地图数据


import * as echarts from 'echarts';
import * as sichuan from "@/assets/map/sichuan.json"

3.2在onMounted生命周期调用画地图的函数

 getMapData() {
        if (!chartDom.value) {
          chartDom.value = document.getElementById('chartDom')
        }
        maps.ecIns = echarts.init(chartDom.value)
        echarts.registerMap('sichuan', sichuan.default);
        maps.ecIns.setOption(maps.option)
        maps.ecIns.on('click',(e)=>{
          e.data.info.deviceList.forEach((item,index)=>{
            item.xu_hao=index+1
          })
          maps.layer.project.tableData=e.data.info.deviceList
          maps.layer.project.title.name=e.data.info.name
          maps.layer.show=true
        })
      },

3.2.1画地图函数中的option

option: {
        legend:{

        },
        tooltip: {
          trigger: 'item',
        },


        geo: [
          {
            map: 'sichuan',
            roam: false,
            layoutCenter: ['50%', '50%'],
            layoutSize: '90%',
            selectedMode: 'single',
           /* tooltip: {
              show: true,
              confine: true,
              formatter: function (params) {
                return [
                  'This is the introduction:',
                  'xxxxxxxxxxxxxxxxxxxxx',
                  'xxxxxxxxxxxxxxxxxxxxx',
                  'xxxxxxxxxxxxxxxxxxxxx',
                  'xxxxxxxxxxxxxxxxxxxxx',
                  'xxxxxxxxxxxxxxxxxxxxx',
                  'xxxxxxxxxxxxxxxxxxxxx',
                  'xxxxxxxxxxxxxxxxxxxxx',
                  'xxxxxxxxxxxxxxxxxxxxx',
                  'xxxxxxxxxxxxxxxxxxxxx',
                  'xxxxxxxxxxxxxxxxxxxxx'
                ].join('<br>');
              }
            },*/
            label: {
              show: false, // 显示城市名称
              color: '#909399'
            },
            itemStyle: {
              areaColor: '#1964FD',
              borderColor: '#269cfd', //线

            },
            emphasis: {
              label: {
                show: false, // 显示城市名称
                color: '#fff'
              },
              itemStyle: {
                areaColor: '#003FC0', //悬浮区背景
                borderColor: '#269cfd', //线
                color:'#fff',
              },
            },
            select: {
              itemStyle: {
                color: '#0a2dae'
              },
              label: {
                show: false
              }
            },
          }
        ],
        series: {
          name: '',
          type: 'scatter',//即相应散点位
          coordinateSystem: 'geo',
          color: ['#003FC0'],
          itemStyle:{
            borderColor:'#fff',
          },
          tooltip: {
            position: "right",
            color: "#000",
            formatter(d) {
              return `<div style="padding: 5px 10px;">【${d.data.name}】</div>`;
            },
          },
          data: [],//至少需要name和value:名字和点位,其它数据自己携带见getMapData方法中对此进行设置。
        },
      },

3.2.2 获取点位数据

async getMapData(){
        let res = await elevator.getMapData()
        if(res?.code===requestCode){
          maps.option.series.data=res.data.map((item,index)=>{
            return {
              name:item.name,
              value:[item.longitude,item.latitude],
              info:item,//携带数据,当点击点位的时候可以交互获取数据
            }
          })
        }
      },

3.2.3随屏幕自适应大小

onMounted(async () => {
      await request.getMapData()
      maps.getMapData()//需要在后面,因为option的数据需要在前面获取
      window.addEventListener('resize', maps.echartsResize)

    })
    onUnmounted(() => {
      window.removeEventListener("resize", maps.echartsResize)

    })
    onActivated(() => {
      window.addEventListener('resize', maps.echartsResize)
    })

    onDeactivated(() => {
      window.removeEventListener("resize", maps.echartsResize)
    })

4. 地图完成。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/638268.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

传统测试将被取代?AI测试现状及发展之思

近年来&#xff0c;我一直关注AI相关的测试&#xff0c;并积极参与多个全国性测试社区和社群。在这些社区中&#xff0c;我与不同公司和领域的测试专家交流探讨AI测试相关话题&#xff0c;包括业界顶尖公司的专家和国内知名测试学者。我也参加了多个大会&#xff0c;聆听了许多…

【c++】动态联编和静态联编

动态联编和静态联编 动态联编条件&#xff1a;虚函数 基类指针/引用 静态联编条件&#xff1a;重载 动态联编代码 class A { public:virtual void print(){cout << "void printA()" << endl;} protected:int a; };class B :public A { public:void pri…

制作 initramfs 后,缺少部分驱动,可能导致系统无法启动

问题现象&#xff1a; 通过 mkinitrd 制作出来的 initrd.img 镜像&#xff0c;替换到 ISO 中&#xff0c;系统无法正常启动&#xff0c;从日志上看 mount ‘iso9668’ 失败&#xff0c;怀疑是小系统中缺少 isofs 驱动导致 问题复现&#xff1a; 装机报错&#xff0c;等一会&am…

KW 新闻 | KaiwuDB 亮相数字中国并发布离散制造场景解决方案

4月26-30日&#xff0c;以“加快数字中国建设&#xff0c;推进中国式现代化”为主题的第六届数字中国建设峰会在福州市圆满召开。KaiwuDB 受邀亮相大会参展并发布“离散制造场景解决方案”&#xff0c;旨在以数字化方案驱动生产方式、治理方式变革&#xff0c;推进离散制造业物…

vue 使用JSON 编辑器: vue-json-editor

这里写目录标题 1、安装插件2、引入插件并注册3、使用示例4、实现效果 1、安装插件 npm install vue-json-editor --save 2、引入插件并注册 import vueJsonEditor from vue-json-editor export default {components: { vueJsonEditor }, }3、使用示例 <template><…

Jackson、gson官方文档以及下载地址

1. 官网文档 json中文官网&#xff1a;http://www.json.org/json-zh.html json官网&#xff1a;http://www.json.org/ json参考手册&#xff1a;(译) JSON-RPC 2.0 规范(中文版) Jackson官网地址&#xff1a;https://github.com/FasterXML/jackson Jackson文档地址&#xff1a…

【电路】电路与电子技术基础 课堂笔记 第15章 时序逻辑电路的分析与设计

15.1 时序逻辑电路的分析 第一步&#xff0c;写方程&#xff1a;时钟方程、驱动方程和状态方程&#xff08;将驱动方程代入特征方程中得到&#xff09; 第二步&#xff0c;列出状态表&#xff0c;画状态转移图 第三步&#xff0c;根据提供的时钟图像&#xff0c;画出时序图 第四…

android adb 获取电池信息以及设置

本文主要包含 1、设置adb 无线调试桥连接步骤 2、打印设备电池状态(当前电量、充电状态、充放电电流大小、电池种类等&#xff09; 3、更改电池充电状态、电量百分比、电池还原命令 4、断开adb 远程调试桥 -----------------------------------------------------------------…

软件测试最重要的事之【编写用例】

软件测试用例得出软件测试用例的内容&#xff0c;其次&#xff0c;按照软件测试写作方法&#xff0c;落实到文档中&#xff0c;两者是形式和内容的关系&#xff0c;好的测试用例不仅方便自己和别人查看&#xff0c;而且能帮助设计的时候考虑的更周。 一个好的测试用例必须包含…

windows 服务程序和桌面程序集成(四)桌面程序

系列文章目录链接&#xff1a; windows 服务程序和桌面程序集成&#xff08;一&#xff09;概念介绍windows 服务程序和桌面程序集成&#xff08;二&#xff09;服务程序windows 服务程序和桌面程序集成&#xff08;三&#xff09;UDP监控工具windows 服务程序和桌面程序集成&…

试用了市面上95%的报表工具,终于找到这款万能报表工具,太牛了!

经常有粉丝问我有“哪个报表工具好用易上手&#xff1f;”或者是“有哪些适合绝大多数普通职场人的万能报表工具&#xff1f;” 从这里我大概总结出了大家选择报表工具最期望满足的3点&#xff1a; &#xff08;1&#xff09;简单易上手&#xff1a;也就是所谓的学习门槛要低…

上位机开发:必备的关键知识和技能

上位机开发涉及多个方面的知识和技能。以下是您在学习上位机开发时可能需要关注的一些关键领域&#xff1a; 编程语言&#xff1a;选择一种适合上位机开发的编程语言。常用的选择包括C/C、Python和Java等。您需要学习该语言的语法、数据结构、面向对象编程等基本概念。 界面设…

Mysql8.0常用命令

提示&#xff1a;文章写完后&#xff0c;目录可以自动生成&#xff0c;如何生成可参考右边的帮助文档 文章目录 一、登录二、查看端口三、修改端口四、重启Mysql五、创建新用户六、修改密码七、给指定用户分配权限八、删除用户九、远程链接 访问权限 安装参考的&#xff1a;添加…

C++ 超市商品管理系统

题目3 超市商品管理系统设计 1、问题描述 超市中商品分为四类&#xff0c;分别是食品、化妆品、日用品和饮料。每种商品都包含商品名称价格、库存量和生产厂家、品牌等信息 主要完成对商品的销售、统计和简单管理 2、功能要求 (1) 销售功能。购买商品时&#xff0c;先输入类别&…

Linux基础知识点1

Linux概述 Linux的特点&#xff1a; 多用户多任务、开源、安全、稳定 Linux系统的开发模型&#xff1a; 集市模型 Linux的版本&#xff1a; 内核版本和发行版本 内核版本和发行版本含义或区别&#xff1f; 答&#xff1a; 内核版本&#xff1a;Linux 操作系统的内核程序版…

【深入探讨】区块链是工业物联网发展的基石

发表时间&#xff1a;2023年4月6日 区块链技术能否成为工业物联网的基石&#xff1f;最近在巴厘岛举办的物联网和智能系统&#xff08;IoTAIS&#xff09;活动上&#xff0c;nChain首席科学家Craig S. Wright博士解答了这个问题。 Wright博士谈到了在BSV交易账本上运行的工业互…

VirusTotal——您身边的企业安全专家

【本文由 Cloud Ace 整理发布。Cloud Ace 是谷歌云全球战略合作伙伴&#xff0c;拥有 300 多名工程师&#xff0c;也是谷歌最高级别合作伙伴&#xff0c;多次获得 Google Cloud 合作伙伴奖。作为谷歌托管服务商&#xff0c;我们提供谷歌云、谷歌地图、谷歌办公套件、谷歌云认证…

你真的会写软件测试简历吗?为什么面试约不到,测试老鸟的建议...

目录&#xff1a;导读 前言一、Python编程入门到精通二、接口自动化项目实战三、Web自动化项目实战四、App自动化项目实战五、一线大厂简历六、测试开发DevOps体系七、常用自动化测试工具八、JMeter性能测试九、总结&#xff08;尾部小惊喜&#xff09; 前言 写好一份简历的三…

python---函数(2)

函数的递归 递归代码的两个要素: 1.递归结束条件 2.递归递推公式 递归的缺点: 1.执行过程非常复杂,难以理解 2.容易出现栈溢出的情况 3.递归代码一般可以转换成等价的循环代码,并且循环比递归快 递归的有点: 代码简洁,尤其是处理问题本身就是通过递归的方式定义的时候 函数…

动态NAT实验:配置和验证动态网络地址转换

动态NAT实验&#xff1a;配置和验证动态网络地址转换 【实验目的】 部署动态NAT。熟悉动态NAT的应用方法。验证配置。 【实验拓扑】 实验拓扑如图所示。 实验拓扑 设备参数如表所示。 设备参数表 设备 接口 IP地址 子网掩码 默认网关 R1 f0/0 192.168.10.1 255.25…