vue+echarts ----中国地图 下拉选择省份地图中的省份区域高亮显示以及飞线图的效果

vue+echarts ----中国地图 下拉选择省份地图中的省份区域高亮显示以及飞线图的效果

1、父组件核心代码:【@/utils/area的详细数据】、【@/utils/china详细数据】

<template><div class="center"><div class="digital"><el-selectpopper-class="selectz"v-model="areaValue"placeholder="请选择":popper-append-to-body="false"><el-optionv-for="item in areaListOptions":key="item.value":label="item.label":value="item.label"></el-option></el-select></div><!-- 中国地图 --><ChinaMapAnimation :chartData="chartData" :provinceName="areaValue"></ChinaMapAnimation></div></template>
<script>
import "@/utils/china"; //在[https://datav.aliyun.com/portal/school/atlas/area_selector]中下载全国的json数据
import areaList from '@/utils/area'; //下拉框的数据 
import ChinaMapAnimation from "./components/chinaMapAnimation.vue";
export default {components: {ChinaMapAnimation,},data() {return {areaListOptions: areaList, //中国区域数据areaValue: "全国",}},mounted() {this.areaListOptions.unshift({ value: "all", label: "全国" });},}</script><style scoped lang="scss">
.digital {// width: 350px;width: 100%;height: auto;position: absolute;// left: 28%;top: 2%;z-index: 99;text-align: center;::v-deep .el-input__inner {background-color: transparent;border: none;font-size: 36px;line-height: 50px;height: 50px;caret-color: transparent;letter-spacing: 6px;text-align: center;// font-weight: bold;color: #6690ff;text-shadow: 2px 2px #eee;padding: 0;}::v-deep .el-select .el-input .el-select__caret {font-size: 24px;color: #6690ff;text-shadow: 1px 1px #eee;}::v-deep .el-cascader {.el-input__icon:before {content: "\e78f";}}::v-deep .el-select {.el-select__caret:before {content: "\e78f";}}::v-deep .el-input__suffix {left: 0;top: 30px;}::v-deep .el-select-dropdown__item {color: #eee;}::v-deep .el-select-dropdown__item.hover {background-color: #5483d3;color: #eee;}::v-deep .el-scrollbar__wrap {margin-bottom: -8px !important;margin-right: -6px !important;}::v-deep .el-popper[x-placement^="bottom"] .popper__arrow::after {border-bottom-color: #5483d3;display: none;}::v-deep .el-popper[x-placement^=bottom] .popper__arrow{display: none;}//::v-deep .el-select-dropdown {background-color: transparent;border-color: #5483d3;}
</style>

2.地图子组件的全部代码

<template><divclass="centerMap"id="echartsMap"style="width: 100%; height: 600px"></div>
</template><script>
// 引入echarts
import * as echarts from "echarts";export default {props: {provinceName: {//父组件传入地图名称type: String,default: "北京市",},},components: {},data() {// 这里存放数据return {myChart: null,};},watch: {provinceName(newvalue, oldValue) {if (newvalue != oldValue) {this.init();}},immediate: false},mounted() {this.init();},beforeDestroy() {if (this.myChart) {this.myChart.dispose();}},// 方法集合methods: {init() {let chartDom = document.getElementById("echartsMap");const myChart = echarts.init(chartDom);this.myChart = myChart;const chinaGeoCoordMap = {黑龙江: [127.9688, 45.368],内蒙古: [110.3467, 41.4899],吉林: [125.8154, 44.2584],宜宾市: [104.630825, 28.760189],辽宁: [123.1238, 42.1216],河北: [114.4995, 38.1006],北京: [116.405285, 39.904989],天津: [117.4219, 39.4189],山西: [112.3352, 37.9413],陕西: [109.1162, 34.2004],甘肃: [103.5901, 36.3043],宁夏: [106.3586, 38.1775],青海: [101.4038, 36.8207],新疆: [87.9236, 43.5883],西藏: [91.11, 29.97],四川: [103.9526, 30.7617],重庆: [108.384366, 30.439702],山东: [117.1582, 36.8701],河南: [113.4668, 34.6234],江苏: [118.8062, 31.9208],安徽: [117.29, 32.0581],湖北: [114.3896, 30.6628],浙江: [119.5313, 29.8773],福建: [119.4543, 25.9222],江西: [116.0046, 28.6633],湖南: [113.0823, 28.2568],贵州: [106.6992, 26.7682],云南: [102.9199, 25.4663],广东: [113.12244, 23.009505],广西: [108.479, 23.1152],海南: [110.3893, 19.8516],上海: [121.4648, 31.2891],};// 散点const chinaDatas = [];const mapObject = { name: "", value: null };// 飞线const lineObject = { coords: [[117.4219, 39.4189]] };const linesCoord = [];for (const key in chinaGeoCoordMap) {mapObject.name = key;mapObject.value = chinaGeoCoordMap[key];chinaDatas.push(JSON.parse(JSON.stringify(mapObject)));if (key !== "天津") {lineObject.coords[1] = chinaGeoCoordMap[key];linesCoord.push(JSON.parse(JSON.stringify(lineObject)));}}const option = {  geo: {map: "china",show: true,roam: false,layoutCenter: ["50%", "68%"], //地图位置layoutSize: "128%",label: {emphasis: {show: false,},},// 选中的地区域高亮颜色**********重点regions: [{name: this.provinceName,itemStyle: {areaColor: "#FFB800",},},],// 地图的背景色itemStyle: {normal: {areaColor: "#09184F",borderColor: "#00ffff",shadowColor: "#6690FF",shadowBlur: 10,},emphasis: {areaColor: "#477BFF",},},},series: [{type: "effectScatter",coordinateSystem: "geo",// 要有对应的经纬度才显示,先经度再维度data: chinaDatas,showEffectOn: "render",rippleEffect: {scale: 4, // 波纹的最大缩放比例brushType: "stroke",},hoverAnimation: true,label: {normal: {show: true,formatter: "{b}",position: "right",fontWeight: 500,fontSize: 14,},},itemStyle: {normal: {color: "#00e3ff",shadowBlur: 10,shadowColor: "#333",},},emphasis: {itemStyle: {color: "#FFB800", // 高亮颜色},},zlevel: 1,},{type: "lines",coordinateSystem: "geo",zlevel: 1,effect: {show: true,period: 5,trailLength: 0,symbol: "arrow",color: "#01AAED",symbolSize: 8,},lineStyle: {normal: {width: 1.2,opacity: 0.6,curveness: 0.2,color: "#FFB800",},},data: linesCoord,},],};myChart.setOption(option);// 省份高亮函数// if (this.provinceName) {//   myChart.dispatchAction({//     type: "downplay",//     seriesIndex: 0,//     name: this.provinceName,//   });//   myChart.dispatchAction({//   type: "highlight",//   seriesIndex: 0,//   dataIndex: myChart//     .getOption()//     .series[0].data.findIndex((item) => item.name === this.provinceName),//   name: this.provinceName,// });// }},},
};
</script>
<style lang="scss" scoped>
.centerMap {width: 100%;height: 600px;// position: absolute !important;margin: 0 auto;margin-top:-10px;::v-deep canvas {width: 100% !important;}
}
</style>

效果图展示:

在这里插入图片描述
在这里插入图片描述

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

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

相关文章

STM32学习笔记(十一)--SPI总线协议详解

概述&#xff1a;Serial Peripheral Interface&#xff0c;一组多从 传输速率比I2C快 但是线多 无应答 是一种同步&#xff08;具有时钟线需要同步时钟SCL&#xff09;、串行&#xff08;一位一位的往一个方向发送&#xff09;、全双工&#xff08;发送接收同时&#xff09;通…

Rocky9使用cockpitweb登陆时root用户无法登陆

Rocky9使用cockpitweb登陆时root用户无法登陆 [rootlvs ~]# vim /etc/cockpit/disallowed-users [rootlvs ~]# systemctl restart cockpit 取消disallowed-users中的root&#xff0c;即可访问 ip:9090 登陆。

计算机网络 —— 应用层(万维网)

计算机网络 —— 应用层&#xff08;万维网&#xff09; 万维网核心组成部分特点 URLHTTP版本请求消息结构响应消息结构工作流程 Cookie如何工作主要用途安全与隐私类型 Web缓存客户端缓存&#xff08;浏览器缓存&#xff09;服务器端缓存 今天我们来了解万维网&#xff1a; 万…

螺蛳粉店外卖配送小程序商城的效果为何

螺蛳粉是广西地区的特色美食&#xff0c;在当地有着大量实体餐饮店或品牌商&#xff0c;其单品消费率非常高&#xff0c;在外地也不乏自创品牌或加盟店等&#xff0c;其特殊的味道及吸引力也同样复购率高&#xff0c;客户除了线下到店外&#xff0c;也会购买袋/桶装螺蛳粉到家自…

构建有效的财务规划合作伙伴关系

在这个日益注重分类、定义和正规化的时代&#xff0c;财务规划与分析作为企业环境中发展最快的功能之一&#xff0c;已经从典型的数据管理角色逐步演变成企业框架中必不可少的身份。与其他新兴趋势一样&#xff0c;财务规划也开始采用更加创新的理念来吸引高技能投资&#xff0…

神经压缩文本训练:提升大型语言模型效率的新方法

随着大型语言模型&#xff08;LLMs&#xff09;在各个领域的广泛应用&#xff0c;其训练和部署的效率问题日益凸显。传统的子词标记化方法&#xff0c;如Byte Pair Encoding (BPE) 或 Unigram&#xff0c;虽然能够在一定程度上压缩文本&#xff0c;但其压缩率通常只有4倍左右。…

Kubernetes部署Kanboard看板管理平台

【云原生】Kubernetes部署Kanboard项目管理平台 文章目录 【云原生】Kubernetes部署Kanboard项目管理平台介绍资源列表基础环境一、检查k8s环境1.1、检查工作节点状态1.2、检查系统pod状态 二、编辑kanboard.yaml文件2.1、创建项目目录2.2、编辑kanboard.yaml文件 三、部署Kanb…

日常工作中常用的管理工具

日常工作中常用的管理工具 SWOT分析法&#xff1a; 帮你清晰地把我全局&#xff0c;分析自己在资源方面的优势域劣势&#xff0c;把握环境提供的机会&#xff0c;防范可能存在的风险与威胁&#xff0c;对我们的成功有非常重要的意义 PDCA循环规则&#xff1a; 每一项工作&#…

如何使用LiveTargetsFinder生成实时活动主机URL列表

关于LiveTargetsFinder LiveTargetsFinder是一款功能强大的实时活动主机生成工具&#xff0c;该工具可以为广大研究人员以自动化的形式生成可供分析和测试的实时活动主机URL列表&#xff0c;并通过MassDNS、Masscan和Nmap自动过滤出无法访问的主机。 我们只需要提供一个域名作…

代码随想录第30天|贪心算法

122.买卖股票的最佳时机II 给你一个整数数组 prices &#xff0c;其中 prices[i] 表示某支股票第 i 天的价格。 在每一天&#xff0c;你可以决定是否购买和/或出售股票。你在任何时候 最多 只能持有 一股 股票。你也可以先购买&#xff0c;然后在 同一天 出售。 返回 你能获得…

SAP PP学习笔记23 - 生产订单(制造指图)的元素2 - 决济规则(结算规则)

上一章讲了生产订单&#xff08;制造指图&#xff09;画面的基本元素。 SAP PP学习笔记22 - 生产订单&#xff08;制造指图&#xff09;的元素1-CSDN博客 本章继续讲生产订单上面的其他元素。 1&#xff0c;Settlement rule&#xff08;决济规则(结算规则)&#xff09;概要 M…

springboot容器功能

springboot容器 容器功能Spring注入组件的注解Component&#xff0c;Controller&#xff0c;Service&#xff0c;Repository案例演示 Configuration应用实例传统方式使用Configuration 注意事项和细节 Import应用实例 ConditionalConditional介绍应用实例 ImportResource应用实…

Microsoft Office免费下载安装

文章目录 前言一、下载Office Tool Plus二、部署步骤1.移除本机低版本office2.部署设置3.开始部署 前言 本人一直支持国产WPS&#xff08;因为正版Microsoft Office需要花钱&#xff09;。直到某天接触到一款免费部署Microsoft Office的软件——Office Tool Plus&#xff0c;简…

C++ //CCF-CSP计算机软件能力认证 202406-1 矩阵重塑(其一)

CCF-CSP计算机软件能力认证 202406-1 矩阵重塑&#xff08;其一&#xff09; 题目背景 矩阵&#xff08;二维&#xff09;的重塑&#xff08;reshape&#xff09;操作是指改变矩阵的行数和列数&#xff0c;同时保持矩阵中元素的总数不变。 题目描述 矩阵的重塑操作可以具体…

BEV端到端视觉论文合集|从不同的视角解析BEV感知技术

随着自动驾驶技术的不断发展&#xff0c;基于摄像头的感知系统已成为关键&#xff0c;而Bird’s Eye View (BEV)大模型在其中发挥着重要作用。BEV大模型是一种将摄像头捕捉到的2D图像转换为自上而下视角的3D感知的技术&#xff0c;使得车辆能够更好地理解周围环境。 BEV大模型…

高职人工智能专业实训课之“图像识别基础”

一、前言 随着人工智能技术的迅猛发展&#xff0c;高职院校对人工智能专业实训课程的需求日益迫切。唯众人工智能教学实训平台作为一所前沿的教育技术平台&#xff0c;致力于为学生提供高效、便捷的人工智能实训环境&#xff0c;特别在“图像识别基础”这一关键课程中&#xf…

ubuntu多版本cuda如何指定cuda版本

本文作者&#xff1a; slience_me ubuntu多版本cuda如何指定cuda版本 文章目录 ubuntu多版本cuda如何指定cuda版本1. 关于cuda设置1.1 查看当前安装的 CUDA 版本1.2 下载并安装所需的 CUDA 版本1.3 设置环境变量1.4 验证切换1.5 安装对应的 NVIDIA 驱动程序 2. 设置环境变量2.1…

【机器学习 复习】第5章 朴素贝叶斯分类器

一、概念 1.贝叶斯定理&#xff1a; &#xff08;1&#xff09;就是“某个特征”属于“某种东西”的概率&#xff0c;公式就是最下面那个公式。 2.朴素贝叶斯算法概述 &#xff08;1&#xff09;是为数不多的基于概率论的分类算法&#xff0c;即通过考虑特征概率来预测分类。 …

如何使用DeadFinder寻找失效链接

关于DeadFinder DeadFinder是一款功能强大的链接分析工具&#xff0c;该工具可以帮助广大研究人员快速地寻找目标页面中的无效链接&#xff08;死链&#xff09;。所谓死链&#xff0c;即一个页面中存在的无法被连接的一条链接。这些链接如果一直保留在页面中的话&#xff0c;…

【论文笔记】LoRA LOW-RANK ADAPTATION OF LARGE LANGUAGE MODELS

题目&#xff1a;LoRA: LOW-RANK ADAPTATION OF LARGE LANGUAGE MODELS 来源: ICLR 2022 模型名称: LoRA 论文链接: https://arxiv.org/abs/2106.09685 项目链接: https://github.com/microsoft/LoRA 文章目录 摘要引言问题定义现有方法的问题方法将 LORA 应用于 Transformer 实…