echarts地图绘制并实现下钻功能

本文参考网址

使用echarts地图需要先准备好echarts地图渲染需要的json数据,数据可以从阿里云地址中下载自己需要的,下载之后直接引入即可使用,本文针对全国地图做一个简单的demo

阿里云界面如图
在这里插入图片描述

// 1、准备echarts地图容器<div class="map" ref="myChart" style="width:500px;height:500px;"></div>
// js部分import * as echarts from 'echarts'// 阿里云地址里下载下来全国的json数据,存储为china.jsonimport china from './china.json'
let map_level = 'china'
data() {return {myChart: null,option: {}}},mounted() {this.initMap();},methods: {initMap() {this.myChart = echarts.init(document.querySelector('.map'));echarts.registerMap('china', china);this.myChart.hideLoading();this.option = {animation : false,backgroundColor: 'transparent',geo: {map: 'china',layoutCenter: ["50%", "50%"], //地图位置// aspectScale: 1.55, //长宽比// layoutSize: '140%',zoom: 1,// center: [109.975625,39.654296],left: 0,right: 0,top: 0,bottom: 0,roam: false,// 是否开启鼠标缩放和平移漫游label:{show: true,// 设为false时不显示区域名称color:'#1EBAA4',fontSize: 10},itemStyle: {areaColor: {type: 'radial',x: 0.5,y: 0.5,r: 0.8,colorStops: [{offset: 0,color: 'transparent' // 0% 处的颜色}, {offset: 1,color: 'transparent' // 100% 处的颜色}],globalCoord: true // 缺省为 false},borderColor: 'red',shadowColor: 'transparent',shadowOffsetX: 10,shadowOffsetY: 11},emphasis: {itemStyle: {areaColor: 'transparent'},label:{show: false,color:'#1EBAA4'},},},series: []};this.myChart.setOption(this.option, true);let that = this;// 添加下钻功能this.myChart.on('click', function (params) {// console.log(params);// 判断地图类型,中国地图则变为省地图,省地图变为市区地图map_level = map_level === 'china' ? 'province' : map_level === 'province' ? 'city' : null;if (!map_level) returnif (map_level === 'province') {that.createMap('geometryProvince', that.getProvinceId(mapList, params.name), params.name)} else if (map_level === 'city') {that.createMap('geometryCouties', that.getcityId(cityinfo, params.name), params.name)}})},createMap(url, id, name) {if (map_level === 'province') {// let newJson = provinceList[id];// cityinfo = chinaJsonthis.option.geo.map = name;echarts.registerMap(name, provinceList[id]);// provinceList为省份数据集合,格式为{// '省份1id': data1,// '省份2id': data2// }this.myChart.setOption(this.option, true);} else {}},// 获取省份idgetProvinceId(mapList, name) {// mapList为从阿里云下载下来的具体某个省份的经纬度数据,具体逻辑根据自己的实际情况修改for (let i in mapList) {if (name.indexOf(mapList[i].label)!==-1) {return mapList[i].value}}},// 获取市区idgetcityId(cityinfo, name) {// 具体逻辑根据自己的实际情况修改for (let i in cityinfo.features) {if (cityinfo.features[i].properties.name == name) {return cityinfo.features[i].properties.id + '00'}}}}

最终效果如下
在这里插入图片描述
此时会发现,地图下方有个南海诸岛,有时候不需要它需要把它去掉,
使用geo时,可以在geo中设置

regions: [ // 对某块地区的特殊处理,此处可以隐藏掉南海诸岛{name: '南海诸岛', value: 0,itemStyle: {normal: {opacity: 0, //透明度label: {show: false}}}}],
除了使用geo来实现外,还可以使用series来实现,关键代码如下:
// option中的geo去掉,使用series
series: [{name: 'map',type: "map",mapType: 'china',roam: false,zoom: 1,label: {normal: {show: true,textStyle: {color: "#000",},},},itemStyle: {normal: {borderColor: "#B79891",borderWidth: "1",areaColor: "transparent",},emphasis: {areaColor: 'transparent',}},// 去掉南海诸岛data: [{ name: "南海诸岛", value: 0, itemStyle: { normal: { opacity: 0, label: { show: false } },emphasis: { opacity: 0, label: { show: false } } } }]}]

此时效果如下图
在这里插入图片描述
如想把底部边界线也给去掉,可以在china.json中找到以下代码,给注释掉或删除掉
在这里插入图片描述
删除之后效果如下:
在这里插入图片描述

注意

使用series来实现时,下钻时的方法需要修改下,createMap中的
this.option.geo.map = name;需要改为this.option.series[0].mapType = name;

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

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

相关文章

【python面向对象】

一、魔术函数 在Python中&#xff0c;xx()的函数叫做魔法函数&#xff0c;指的是具有特殊功能或者有特殊含义的函数&#xff0c;而且这些函数都是在某种情况下自动调用的。 eg: init函数 __init__() :对象的初始化函数&#xff0c;在创建一个对象的时默认被调用&#xff0c;…

RabbitMQ本地Ubuntu系统环境部署与无公网IP远程连接服务端实战演示

文章目录 前言1.安装erlang 语言2.安装rabbitMQ3. 安装内网穿透工具3.1 安装cpolar内网穿透3.2 创建HTTP隧道 4. 公网远程连接5.固定公网TCP地址5.1 保留一个固定的公网TCP端口地址5.2 配置固定公网TCP端口地址 &#x1f4a1; 推荐 前些天发现了一个巨牛的人工智能学习网站&am…

基于飞桨paddle2.6.1+cuda11.7+paddleRS开发版的目标提取-道路数据集训练和预测代码

基于飞桨paddle2.6.1cuda11.7paddleRS开发版的目标提取-道路数据集训练和预测代码 预测结果&#xff1a; 预测影像&#xff1a; &#xff08;一&#xff09;准备道路数据集 下载数据集地址&#xff1a; https://aistudio.baidu.com/datasetdetail/56961 mass_road.zip …

通过 pnpm 安装依赖包会发生什么

通过 pnpm 安装依赖包会发生什么 通过 pnpm 下载的包都是放在一个全局目录&#xff08;.pnpm-store&#xff09;下&#xff0c;默认是在 ${os.homedir}/v3/.pnpm-store&#xff0c;如果我们不确定在哪里&#xff0c;可以输入下面的命令手动配置&#xff1a; pnpm set store-d…

若依 Vue3的前后端分离系统管理 创建 使用

RuoYi 若依官方网站 |后台管理系统|权限管理系统|快速开发框架|企业管理系统|开源框架|微服务框架|前后端分离框架|开源后台系统|RuoYi|RuoYi-Vue|RuoYi-Cloud|RuoYi框架|RuoYi开源|RuoYi视频|若依视频|RuoYi开发文档|若依开发文档|Java开源框架|Java|SpringBoot|SrpingBoot2.0…

IP/TCP/UDP协议的关键知识点

导语&#xff1a;网络协议是理解网络情况的基础&#xff0c;当遇到网络问题时&#xff0c;首先可以从网络协议入手&#xff0c;熟悉的网络协议可以有效帮助小伙伴们排查或者说定位大概的问题方面。本文整理了目前最常用的网络通信协议&#xff0c;相信对小伙伴们肯定都有帮助。…

cookie实战案例-自动登录网站

在写爬虫的时候&#xff0c;要伪装成真实用户请求。可能需要大量的IP地址&#xff0c;那么大量的IP地址从哪里来呢&#xff1f;这里就需要用代理IP来解决了&#xff0c;有的网站专门通过提供代理IP池服务作为主要的经营业务&#xff0c;只要注册相关网站开通对应套餐就可以了。…

Java笔试面试题AI答之JDBC(1)

文章目录 1. 什么是JDBC&#xff1f;2. 驱动(Driver)在JDBC中的角色&#xff1f;3. JDBC PreparedStatement比Statement有什么优势&#xff1f;1. 预编译和性能提升2. 参数化查询和安全性3. 更好的可读性和可维护性4. 支持批量操作5. 缓存机制&#xff08;特定数据库环境&#…

2024 高教社杯 数学建模国赛 (A题)深度剖析|“板凳龙” 闹元宵|数学建模完整代码+建模过程全解全析

当大家面临着复杂的数学建模问题时&#xff0c;你是否曾经感到茫然无措&#xff1f;作为2022年美国大学生数学建模比赛的O奖得主&#xff0c;我为大家提供了一套优秀的解题思路&#xff0c;让你轻松应对各种难题&#xff01; CS团队倾注了大量时间和心血&#xff0c;深入挖掘解…

2024 年高教社杯全国大学生数学建模竞赛题目-D 题 反潜航空深弹命中概率问题

应用深水炸弹&#xff08;简称深弹&#xff09;反潜&#xff0c;曾是二战时期反潜的重要手段&#xff0c;而随着现代军事技术 的发展&#xff0c;鱼雷已成为现代反潜作战的主要武器。但是&#xff0c;在海峡或浅海等海底地形较为复杂的 海域&#xff0c;由于价格低、抗干扰能力…

读懂以太坊源码(4)-详细解析节点配置文件geth.toml

要读懂以太坊源码&#xff0c;先熟悉配置文件的每个配置项也是非常有必要的&#xff0c;以下代码是以太坊主网配置文件(geth.toml)的完整内容&#xff0c;后面是对每个配置项的说明&#xff1a; [Eth] NetworkId 0 SyncMode "snap" EthDiscoveryURLs [] SnapDisc…

14 C语言实现平衡二叉树

//LL型失衡 右旋 //RR型失衡 左旋 //RL型失衡 先右旋 再左旋 //LR型失衡 先左旋 再右旋 #include "stdio.h" #include "stdlib.h"typedef int ElemType; typedef struct node {ElemType data;int height;struct node *left;struct node *right; } Node;Nod…

SpringBoot生成ETH和ERON钱包

首先大家需要先引入相关依赖包&#xff0c;这个maven里面是没有的&#xff0c;需要我们自行导入才可以。在项目路径下面创建lib&#xff0c;将所有需要使用的包导入即可。给大家一个包的下载链接&#xff1a;https://download.csdn.net/download/qq_38935605/89715772 因为放在…

scrapy 爬取微博(一)【最新超详细解析】:创建微博爬取工程

本项目属于个人学习记录&#xff0c;爬取的数据会于12小时内销毁&#xff0c;且不可用于商用。 1 初始化环境 首先我们需要有python环境&#xff0c;先安装一下python&#xff0c;然后配置环境变量&#xff0c;这边给出windows的配置&#xff1a; 我这边的安装目录是D:\pyt…

关于SPI通信失败的一种情况(CRC校验不匹配的问题)

问题 该项目中&#xff0c;使用外置的ADC芯片采集电压电流&#xff0c;主控MCU通过SPI与ADC芯片通信。调试时&#xff0c;SPI通信一直失败&#xff0c;与之前成功的项目对比&#xff0c;发现是SPI配置的问题。 void MX_SPI2_Init(void) {/* USER CODE BEGIN SPI2_Init 0 *//*…

WIFI贴项目到底是不是“骗局”呢?由我来揭秘!

各位亲爱的朋友们&#xff0c;大家好&#xff01;我是你们的老朋友鲸天科技千千&#xff0c;一直在这片互联网的热土上耕耘。相信你们对我都不会陌生&#xff0c;因为我常常分享一些互联网上的新奇项目和实用技巧。如果你对我的内容感兴趣&#xff0c;别忘了点个关注哦&#xf…

【案例67】Npart批量启动服务卡顿严重分析过程

问题现象 通过Npart启动NC服务&#xff0c;发现只启动一个&#xff0c;大概3min左右即可启动成功。但是批量启动服务需要几十分钟才可以把服务启动成功&#xff0c;启动卡在获取“wenjian”图标处。 绕过Npart直接写脚本并行启动相关服务&#xff0c;发现也需要30min 问题分析…

数组与贪心算法——605、121、122、561、455、575(5简1中)

605. 种花问题&#xff08;简单&#xff09; 假设有一个很长的花坛&#xff0c;一部分地块种植了花&#xff0c;另一部分却没有。可是&#xff0c;花不能种植在相邻的地块上&#xff0c;它们会争夺水源&#xff0c;两者都会死去。 给你一个整数数组 flowerbed 表示花坛&#xf…

网络传输加密及openssl使用样例(客户端服务器)

文章目录 背景常用加密方式SSLOpenSSL主要功能 库结构 交互流程证书生成生成 RSA 私钥私钥的主要组成部分私钥的格式 创建自签名证书: 签发证书服务器端代码客户端代码常见错误版本问题证书问题证书格式 背景 网络传输中为保证数据安全&#xff0c;通常需要加密 常用加密方式…

1.初识ChatGPT:AI聊天机器人的革命(1/10)

引言 在当今的数字化世界中&#xff0c;人工智能&#xff08;AI&#xff09;正以其独特的方式重塑我们的生活和工作。其中&#xff0c;AI聊天机器人作为人机交互的前沿技术&#xff0c;已经成为企业与客户沟通、提供个性化服务的重要工具。这些机器人通过模拟人类的对话方式&a…