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

相关文章

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

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

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

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

使用Python在Excel中插入、修改、提取和删除超链接

《使用Python在Excel中插入、修改、提取和删除超链接》超链接是Excel中的常用功能,通过点击超链接可以快速跳转到外部网站、本地文件或工作表中的特定单元格,有效提升数据访问的效率和用户体验,这... 目录引言使用工具python在Excel中插入超链接Python修改Excel中的超链接Python

python修改字符串值的三种方法

《python修改字符串值的三种方法》本文主要介绍了python修改字符串值的三种方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学... 目录第一种方法:第二种方法:第三种方法:在python中,字符串对象是不可变类型,所以我们没办法直接

Mysql8.0修改配置文件my.ini的坑及解决

《Mysql8.0修改配置文件my.ini的坑及解决》使用记事本直接编辑my.ini文件保存后,可能会导致MySQL无法启动,因为MySQL会以ANSI编码读取该文件,解决方法是使用Notepad++... 目录Myhttp://www.chinasem.cnsql8.0修改配置文件my.ini的坑出现的问题

无人叉车3d激光slam多房间建图定位异常处理方案-墙体画线地图切分方案

墙体画线地图切分方案 针对问题:墙体两侧特征混淆误匹配,导致建图和定位偏差,表现为过门跳变、外月台走歪等 ·解决思路:预期的根治方案IGICP需要较长时间完成上线,先使用切分地图的工程化方案,即墙体两侧切分为不同地图,在某一侧只使用该侧地图进行定位 方案思路 切分原理:切分地图基于关键帧位置,而非点云。 理论基础:光照是直线的,一帧点云必定只能照射到墙的一侧,无法同时照到两侧实践考虑:关

两个月冲刺软考——访问位与修改位的题型(淘汰哪一页);内聚的类型;关于码制的知识点;地址映射的相关内容

1.访问位与修改位的题型(淘汰哪一页) 访问位:为1时表示在内存期间被访问过,为0时表示未被访问;修改位:为1时表示该页面自从被装入内存后被修改过,为0时表示未修改过。 置换页面时,最先置换访问位和修改位为00的,其次是01(没被访问但被修改过)的,之后是10(被访问了但没被修改过),最后是11。 2.内聚的类型 功能内聚:完成一个单一功能,各个部分协同工作,缺一不可。 顺序内聚:

如何在运行时修改serialVersionUID

优质博文:IT-BLOG-CN 问题 我正在使用第三方库连接到外部系统,一切运行正常,但突然出现序列化错误 java.io.InvalidClassException: com.essbase.api.base.EssException; local class incompatible: stream classdesc serialVersionUID = 90314637791991

android系统源码12 修改默认桌面壁纸--SRO方式

1、aosp12修改默认桌面壁纸 代码路径 :frameworks\base\core\res\res\drawable-nodpi 替换成自己的图片即可,不过需要覆盖所有目录下的图片。 由于是静态修改,则需要make一下,重新编译。 2、方法二Overlay方式 由于上述方法有很大缺点,修改多了之后容易遗忘自己修改哪些文件,为此我们采用另外一种方法,使用Overlay方式。

hibernate修改数据库已有的对象【简化操作】

陈科肇 直接上代码: /*** 更新新的数据并并未修改旧的数据* @param oldEntity 数据库存在的实体* @param newEntity 更改后的实体* @throws IllegalAccessException * @throws IllegalArgumentException */public void updateNew(T oldEntity,T newEntity