echarts地图修改图例

2024-06-19 13:12
文章标签 修改 地图 图例 echarts

本文主要是介绍echarts地图修改图例,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

要求:根据数据排名,前三名点亮橙色,其他地区根据数值分配不同颜色,并且要加上单位
效果图如下:
在这里插入图片描述
实现方法如下:

visualMapFormat(list) {//先将数据按从大到小的顺序排列//当list长度为1时,点亮这1个//当list长度为1-3时,点亮第一个//当list长度为3-8时,判断并列第三名的个数,当第三名超过2个时,只有前2名是橙色,否则点亮前三名//当list长度大于8时,点亮前三名list.sort((a, b) => {return b.value - a.value;});let VMOptions = [];if (list.length === 1) {VMOptions = [{gt: this.numToCeil(list[0].value, false), color: color},];} else if (list.length > 1 && list.length <= 3) {VMOptions = [{gte: this.numToCeil(list[0].value, false), color: color},{lt: this.numToCeil(list[0].value, false), color: "#1360D3"},];} else if (list.length > 3 && list.length <= 8) {let thirdNum = list.filter(item => item.value === list[2].value).length;  //获取第三名的个数//当第三名超过2个时,只有前2名是橙色if(thirdNum>=2){VMOptions = [{min: Math.round(list[2].value), color: color},{min: this.numToCeil(list[2].value / 2, false),max: Math.round(list[2].value),color: "#79CBFF",},{max: this.numToCeil(list[2].value / 2, false), color: "#023280"},];}else{VMOptions = [{min: this.numToCeil(list[1].value, false), color: color},{min: this.numToCeil(list[2].value / 2, false),max: this.numToCeil(list[1].value, false),color: "#79CBFF",},{max: this.numToCeil(list[2].value / 2, false), color: "#023280"},];}} else if (list.length == 0) {return} else {let single = this.numToCeil(list[4].value / 5, false);VMOptions = [{min: this.numToCeil(list[2].value, false), color: color},{min: single * 5,max: this.numToCeil(list[2].value, false),color: "#79CBFF",},{min: single * 4, max: single * 5, color: "#79CBFF"},{min: single * 3, max: single * 4, color: "#3996FF"},{min: single * 2, max: single * 3, color: "#1360D3"},{min: single, max: single * 2, color: "#0A49A8"},{max: single, color: "#023280"},];}this.chinaOption.visualMap.pieces = VMOptions;//处理显示格式this.chinaOption.visualMap.formatter = (start, end) => {if (start === -Infinity) {let array = this.setUnit(end)return '< ' + array[0] + array[1]} else if (end === Infinity) {let array = this.setUnit(start)return '>' + array[0] + array[1]} else {let array1 = this.setUnit(start)let array2 = this.setUnit(end)return array1[0] + '-' + array2[0] + array2[1]}}},
//根据数值设置相应的单位setUnit(num) {let unit = ''if (num * 3 > 100000000) {num = Math.round(num / 100000000)unit = '亿人'} else if (num * 3 > 10000) {num = (num / 10000).toFixed(2)unit = '万人'} else {unit = '人'}return [num, unit]},
// 数据取整numToCeil(num, type) {let outPut = 0;if (0 < num && num <= 10) {outPut = num;} else if (10 < num && num < 100) {outPut = type ? Math.ceil(num / 5) * 5 : Math.floor(num / 5) * 5;} else if (num >= 100 && num < 10000) {outPut = type ? Math.ceil(num / 10) * 10 : Math.floor(num / 10) * 10;} else if (num >= 10000) {outPut = type? Math.ceil(num / 100) * 100: Math.floor(num / 100) * 100;}return Math.round(outPut);},

完成。

这篇关于echarts地图修改图例的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1075122

相关文章

Python实现无痛修改第三方库源码的方法详解

《Python实现无痛修改第三方库源码的方法详解》很多时候,我们下载的第三方库是不会有需求不满足的情况,但也有极少的情况,第三方库没有兼顾到需求,本文将介绍几个修改源码的操作,大家可以根据需求进行选择... 目录需求不符合模拟示例 1. 修改源文件2. 继承修改3. 猴子补丁4. 追踪局部变量需求不符合很

Linux修改pip和conda缓存路径的几种方法

《Linux修改pip和conda缓存路径的几种方法》在Python生态中,pip和conda是两种常见的软件包管理工具,它们在安装、更新和卸载软件包时都会使用缓存来提高效率,适当地修改它们的缓存路径... 目录一、pip 和 conda 的缓存机制1. pip 的缓存机制默认缓存路径2. conda 的缓

Linux修改pip临时目录方法的详解

《Linux修改pip临时目录方法的详解》在Linux系统中,pip在安装Python包时会使用临时目录(TMPDIR),但默认的临时目录可能会受到存储空间不足或权限问题的影响,所以本文将详细介绍如何... 目录引言一、为什么要修改 pip 的临时目录?1. 解决存储空间不足的问题2. 解决权限问题3. 提

Linux文件名修改方法大全

《Linux文件名修改方法大全》在Linux系统中,文件名修改是一个常见且重要的操作,文件名修改可以更好地管理文件和文件夹,使其更具可读性和有序性,本文将介绍三种在Linux系统下常用的文件名修改方法... 目录一、引言二、使用mv命令修改文件名三、使用rename命令修改文件名四、mv命令和rename命

使用Folium在Python中进行地图可视化的操作指南

《使用Folium在Python中进行地图可视化的操作指南》在数据分析和可视化领域,地图可视化是一项非常重要的技能,它能够帮助我们更直观地理解和展示地理空间数据,Folium是一个基于Python的地... 目录引言一、Folium简介与安装1. Folium简介2. 安装Folium二、基础使用1. 创建

mybatis-plus 实现查询表名动态修改的示例代码

《mybatis-plus实现查询表名动态修改的示例代码》通过MyBatis-Plus实现表名的动态替换,根据配置或入参选择不同的表,本文主要介绍了mybatis-plus实现查询表名动态修改的示... 目录实现数据库初始化依赖包配置读取类设置 myBATis-plus 插件测试通过 mybatis-plu

Linux下修改hostname的三种实现方式

《Linux下修改hostname的三种实现方式》:本文主要介绍Linux下修改hostname的三种实现方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录linux下修改ho编程stname三种方式方法1:修改配置文件方法2:hFvEWEostnamectl命

Git如何修改已提交人的用户名和邮箱

《Git如何修改已提交人的用户名和邮箱》文章介绍了如何修改Git已提交人的用户名和邮箱,包括注意事项和具体步骤,确保操作正确无误... 目录git修改已提交人的用户名和邮箱前言第一步第二步总结git修改已提交人的用户名和邮箱前言需注意以下两点内容:需要在顶层目录下(php就是 .git 文件夹所在的目

修改若依框架Token的过期时间问题

《修改若依框架Token的过期时间问题》本文介绍了如何修改若依框架中Token的过期时间,通过修改`application.yml`文件中的配置来实现,默认单位为分钟,希望此经验对大家有所帮助,也欢迎... 目录修改若依框架Token的过期时间修改Token的过期时间关闭Token的过期时js间总结修改若依

MySQL修改密码的四种实现方式

《MySQL修改密码的四种实现方式》文章主要介绍了如何使用命令行工具修改MySQL密码,包括使用`setpassword`命令和`mysqladmin`命令,此外,还详细描述了忘记密码时的处理方法,包... 目录mysql修改密码四种方式一、set password命令二、使用mysqladmin三、修改u