python 动态仪表盘_使用Echarts3实现渐变仪表盘需求

2023-11-07

Echarts 仪表盘实践

项目过程中遇到一个这样的需求:

bVXBAU?w=249&h=153

这明显是一个仪表盘类型的图表,打开echarts的官方文档,可以看到有一个默认的实现,如下:

bVXBAZ?w=337&h=262

使用了默认的参数

option = {

tooltip : {

formatter: "{a}
{b} : {c}%"

},

toolbox: {

feature: {

restore: {},

saveAsImage: {}

}

},

series: [

{

name: '业务指标',

type: 'gauge',

detail: {formatter:'{value}%'},

data: [{value: 50, name: '完成率'}]

}

]

};

分析需求后,我们从以下几个方面入手

轴线类别

从第一张图我们可以看出,需求中的轴线不是连续的,而是被分割成了一个个的长条形状。

从官方示例来看,轴线被白色的刻度分成了很多小段,如果刻度的宽度变大,刻度变密集的话是可以达到我们想要的效果的

option = {

...

series: [

{

name: '业务指标',

type: 'gauge',

// 去掉多余的分段

splitNumber: 1,

axisLine: {

lineStyle: {

width: 20

}

},

splitLine: {

show: false

},

axisTick: {

// 刻度长度与轴线宽度一致,达到分隔的效果

length: 20,

// 增加刻度密度

splitNumber: 100,

lineStyle: {

// 增加刻度宽度

width: 3

}

},

detail: {formatter:'{value}%'},

data: [{value: 50, name: '完成率'}]

}

]

};

经过这样修改的话,确实初步达到了我们要的效果。

bVXBA4?w=293&h=260

但是仔细看的话,会发现一个问题,指针的指向是空白处。原因就是空白的地方是刻度,而有颜色的地方是轴线。

这样的话最终指针指向的数据是不准确的,而且这个方案还有一个问题就是渐变颜色的处理。

[[0.2, '#91c7ae'], [0.8, '#63869e'], [1, '#c23531']]

官方提供的接口是分段颜色,想要做成渐变还不是很好处理。

接下来呢,考虑第二种实现方式

首先,轴线肯定是连续的,那我先把轴线隐藏掉,然后刻度加粗,拉长

option = {

...

series: [

{

name: '业务指标',

type: 'gauge',

splitNumber: 1,

axisLine: {

lineStyle: {

width: 20,

// 透明度设置为0

opacity: 0

}

},

splitLine: {

show: false

},

axisTick: {

length: 20,

splitNumber: 100,

lineStyle: {

width: 3,

// 给点颜色

color: '#555'

}

},

detail: {formatter:'{value}%'},

data: [{value: 50, name: '完成率'}]

}

]

};

bVXBA6?w=305&h=242

可以看到效果有了,而且指针位置正确。

渐变颜色

需求中轴线的颜色是渐变的,但是文档中给定的接口是分段式的颜色,没有办法使用,再者轴线透明度已经被设置为0了。

所以只能从刻度的颜色入手。

官方文档中,刻度的颜色是如下这样的:

// 线性渐变,前四个参数分别是 x0, y0, x2, y2, 范围从 0 - 1,相当于在图形包围盒中的百分比,如果 globalCoord 为 `true`,则该四个值是绝对的像素位置

color: {

type: 'linear',

x: 0,

y: 0,

x2: 0,

y2: 1,

colorStops: [{

offset: 0, color: 'red' // 0% 处的颜色

}, {

offset: 1, color: 'blue' // 100% 处的颜色

}],

globalCoord: false // 缺省为 false

}

// 径向渐变,前三个参数分别是圆心 x, y 和半径,取值同线性渐变

color: {

type: 'radial',

x: 0.5,

y: 0.5,

r: 0.5,

colorStops: [{

offset: 0, color: 'red' // 0% 处的颜色

}, {

offset: 1, color: 'blue' // 100% 处的颜色

}],

globalCoord: false // 缺省为 false

}

// 纹理填充

color: {

image: imageDom, // 支持为 HTMLImageElement, HTMLCanvasElement,不支持路径字符串

repeat: 'repeat' // 是否平铺, 可以是 'repeat-x', 'repeat-y', 'no-repeat'

}

默认支持两种渐变,线性和径向渐变,从效果上看都不符合我们的要求:线性是直线方向的渐变,而径向渐变是由内而外的。即使可以勉强实现,效果肯定不好。

所以可以尝试一下使用图片纹理。

首先用PS画一个和画布一样大小的渐图案

bVXBBb?w=240&h=240

在配置中使用image选项

option = {

...

series:[{

...

axisTick: {

length: 20,

splitNumber: 100,

lineStyle: {

color: {

image: document.getElementById('linear-pic'),

repeat: 'no-repeat'

},

width: 3

}

}

}]

这样项目中的需求就可以完美解决了

bVXBBf?w=202&h=157

颜色分段

颜色渐变完成了,看一下效果的话,会发现有一个明显的问题。需求中指针指向的位置之前的刻度是有渐变颜色的,后面一段则都是灰色。

而我们现在仪表盘无论指向哪里,刻度都是有颜色的。

在解决这个问题的过程中,想了很多方案,使用遮罩、修改渐变图片等等,都不能很好的解决问题。最后突然想起来一个配置项中可以使用多个仪表盘的,

我只要在数据前半段使用带渐变色的仪表盘,后半段全部用灰色的仪表盘补充,这样就可以解决问题。

这里还需要注意以下两点:

由于仪表盘的值是动态的,所以每个仪表盘的开始结束位置、刻度的个数都要根据值来计算

由于有两个仪表盘,最好把内容部分全部都写在一个上,另外一个确保只有轴线部分,避免出现重叠等问题

代码如下:

calculateOption: function (params) {

var offsetAngle = -35;

var totalAngle = 250;

var split = 75;

var series = [];

var asisWidth = 11;

var fontSize = 30;

// Defaults

params = $.extend({

min: 0,

max: 100,

value: 0,

name: 'DOWNLOAD SPEED',

type: 'gauge',

data: [{

value: 0,

name: ''

}]

}, params);

var startAngle = totalAngle + offsetAngle;

var endAngle = startAngle - Math.floor((parseInt(params.value, 10) / (params.max - params.min)) * totalAngle);

series.push({

name: params.name,

type: params.type,

startAngle: startAngle,

endAngle: endAngle,

splitNumber: 1,

// 轴线样式

axisLine: {

show: false,

lineStyle: {

width: asisWidth,

opacity: 0

}

},

// 分段样式

splitLine: { show: false },

// 刻度样式

axisTick: {

length: asisWidth,

splitNumber: Math.floor((params.value / (params.max - params.min)) * split),

lineStyle: {

color: {

image: $('#xx')[0],

repeat: 'no-repeat'

},

width: 2

}

},

axisLabel: { show: false },

pointer: { show: false },

// 指针样式

itemStyle: {},

title: {

fontSize: 8,

offsetCenter: [0, '-35%'],

color: '#999'

},

detail: {

color: '#36444b',

fontSize: fontSize,

offsetCenter: [0, '20%'],

formatter: function (val) {

return val.toFixed(2) + '\n{unit|Mbps}'

},

rich: {

unit: {

fontSize: 10,

color: '#999',

lineHeight: 30

}

}

},

data: [{

value: params.value,

name: params.name

}]

});

series.push({

name: '',

type: params.type,

startAngle: endAngle,

endAngle: offsetAngle,

splitNumber: 1,

axisLine: {

show: false,

lineStyle: {

width: asisWidth,

opacity: 0

}

},

splitLine: { show: false },

axisTick: {

length: asisWidth,

splitNumber: split - Math.floor((params.value / (params.max - params.min)) * 80),

lineStyle: {

color: '#999',

width: 2

}

},

axisLabel: { show: false },

pointer: { show: false },

// 指针样式

itemStyle: {},

title: { show: false },

detail: { show: false }

});

return series;

}

效果如下:

bVXBBi?w=202&h=165

指针类型

最后,我们需要做的就是把指针改为需求中的样子,本来我以为这个应该是最简单的部分,看完官方文档后发现并没有修改指针的接口。

{

color: 'auto',

borderColor: '#000',

borderWidth: 0,

borderType: 'solid',

shadowBlur: ...,

shadowColor: ...,

shadowOffsetX: 0,

shadowOffsetY: 0,

opacity: ...

}

如上,指针配置项应该是没有办法实现类似刻度的样子。

目前还在实验中,考虑使用markline画一条指针,是否可行还有待验证。

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

python 动态仪表盘_使用Echarts3实现渐变仪表盘需求 的相关文章

  • 分享个Java低代码开发平台,免费好用

    概要 1 免费低代码平台 2 天翎低代码平台特色 薅羊毛 免费领低代码平台 在找好用实惠的低代码平台撸毕设 这里有 天翎诚意之作 免费送你低代码平台 为了回馈客户 天翎MyApps平台正式上线了会员系统 用户在会员中心 https mall
  • 1.1 cout/cin/函数 练习

    1 1 cout cin 函数 练习 1 程序 Author may Date 2017 04 21 Function 输入输出 cin cout 练习 函数练习 include
  • (java 基础知识)java序列化和反序列话总结

    序列化 将java对象转换为字节序列的过程叫做序列化 反序列化 将字节对象转换为java对象的过程叫做反序列化 通常情况下 序列化有两种用途 1 把对象的字节序列永久的保存在硬盘中 2 在网络上传输对象的字节序列 相应的API java i
  • 6_sleuth-zipkin-spring_boot_admin 链路追踪

    文章目录 Sleuth zipkin SpringBootAdmin 邮件通知 钉钉通知 如果能跟踪每个请求 中间请求经过哪些微服务 请求耗时 网络延迟 业务逻辑耗时等 我们就能更好地分析系统瓶颈 解决系统问题 Sleuth span 跨度
  • 软件人才从这里飞翔——访北京大学软件学院院长陈钟博士

    还是春寒料峭的季节 一年一度的研究生招生工作正在紧张进行中 从北京大学软件学院传出消息 虽然今年招生人数较多 但生源仍然非常充足 现在软件学院软件工程硕士研究生的报考人数已经是北京大学最集中报考的几个专业之一 所以 今年报考北大软件学院的难
  • C标准时间与时间戳的相互转换

    什么是时间戳 时间戳是指格林威治时间自1970年1月1日 00 00 00 GTM 至当前时间的总秒数 它也被称为Unix时间戳 Unix Timestamp 时间戳是能够表示一份数据在一个特定时间点已经存在的完整的可验证的数据 通常是一个
  • Python 16.OpenCV 腐蚀,膨胀,开运算, 闭运算,礼帽,黑帽

    import cv2 import numpy as np img cv2 imread pic7 PNG 0 img1 cv2 imread pic8 PNG 0 img2 cv2 imread pic9 PNG 0 kernel np
  • CISSP一次通过指南(文末附福利)

    CISSP相关资料 考试机构的复习题 中英文教材 思维导图 点击文章末尾卡片 扫描二维码加我耗油免费领取资料哦 CISSP 英文全称 Certified Information Systems Security Professional 中
  • 网页参考资料

    1 w3school 2 蓝色理想 http www blueidea com 3 web前端开发 http www candoudou com
  • 福禄克铜缆测试参数:近端串扰和远端串扰参数之间的区别

    串扰指的是网线在传输网络信号中 产生了彼此的互相干扰 严重的时候会影响到网络传输得质量 网线的双绞程度越紧密 绞距越均匀时 其抗干扰的能力也会越强 且内部的串扰也会越小 在长距离网络传输中 效果也就越好 串扰会对具体的一对导线或整根电缆形成
  • linux 文件扫描程序 性能,Linux性能优化(三)——sysstat性能监控工具

    一 sysstat简介 1 sysstat简介 sysstat提供了Linux性能监控工具集 包括sar sadf mpstat iostat pidstat等 用于监控Linux系统性能和使用情况 iostat 提供CPU统计 存储I O
  • MFC异形对话框

    基本原理 获取窗体区域 指定一个颜色为透明色 遍历位图 将图上所有该色区域从窗体区域中去除 这样最后就得到了一个异形窗体 然后把背景图绘制在该窗体上 注意绘制的时候 作为透明的部分依然会被以原色绘制 但是由于绘制的地方并没有窗体 故而是显示
  • Java用链表实现队列

    链表实现队列 public class LinkedQueue class Node int val Node next public Node int val this val val public Node int val Node n
  • JQuery全部过滤选择器详细介绍上

    文章目录 JQuery全部过滤选择器详细介绍 上 基础过滤选择器 基础过滤选择器介绍 基础过滤选择器 应用实例 代码演示 内容过滤选择器 内容过滤选择器应用实例 代码演示 可见度过滤选择器 可见度过滤选择器 应用实例 代码演示 JQuery
  • 解决position:sticky元素有父盒子时不生效的问题

    当使用粘性定位的盒子出现 当滚动条滚动一段距离有效 然后就跟着滚动条滚出视口 不起作用了 要考虑看你是否设置了 html body height 100 这个代码会影响html和body的高度 不是整个视口的高度 参考 彻底理解粘性定位 p
  • Python期末大作业(学生成绩管理系统)

    学生成绩管理系统共分为五个主要功能 1 用户登陆和注册模块和退出 a 注册存入文件中 见文件 账号密码 csv b 用户登陆在文件中进行查询 见文件 账号密码 csv c 退出可以退出程序 2 新增学生数据 a 通过录入学生的姓名 学号 科
  • Thinkphp5进阶——02 日志

    1 存储位置 index php入口文件定义一个常量LOG PATH log php配置文件的path定义为常量LOG PATH index php 日志目录 define LOG PATH DIR log log php return 日
  • Vue使用Echarts在父子组件中传值问题

    最近项目上需要使用到Echarts做数据可视化 在写项目过程中发现在子组件中通过Echarts点击事件传值给父组件不起作用 研究了一下 发现是作用域问题 解决方法如下 原代码 通过保存外部作用域this得以解决 修改后代码
  • 刷题day68:零钱兑换

    题意描述 给你一个整数数组 coins 表示不同面额的硬币 以及一个整数 amount 表示总金额 计算并返回可以凑成总金额所需的 最少的硬币个数 如果没有任何一种硬币组合能组成总金额 返回 1 你可以认为每种硬币的数量是无限的 完全背包思

随机推荐

  • 一图曝光互联网大佬高考分数,厉害了

    往 期 趣 闻 程序员生日送什么蛋糕好 每日趣闻 人间真实 Java 版 后浪 每日趣闻 如何鉴别 996 公司 每日趣闻 一图读懂程序员 35 岁怎么转型 每日趣闻 程序员的难 领导不懂 每日趣闻 你点的每个 在看 我都认真当成了喜欢
  • How to resolve '_DllMain@12 already defined in xxx.obj' ?

    转自 http blog csdn net psusong article details 5858388 用Visual C 编写DLL 如果在new project时选了MFC DLL 而后又想写成Regular DLL 即拥有自己的D
  • 使用ksniff分析k8s pod的抓包分析

    使用ksniff分析k8s pod的抓包分析 ksniff是一个kubectl插件 利用tcpdump和Wireshark对Kubernetes集群中的任何pod进行远程捕获 可以得到Wireshark的全部功能 而对你正在运行的pods影
  • table表格中使用插槽

    效果图如下 实现代码如下
  • js 解决回调地狱的方法

    异步编程作为JavaScript中的一部分 具有非常重要的位置 它帮助我们避免同步代码带来的线程阻塞的同时 也为编码与阅读带来了一定的困难 过多的回调嵌套很容易会让我们陷入 回调地狱 中 使代码变成一团乱麻 为了解决 回调地狱 我们可以使用
  • “数字水印”来临,一波“反ChatGPT”的技术开始冒头

    数科星球 原创 作者丨数数 编辑丨十里香 ChatGPT爆火 对于这项技术来说 似乎无所不能 从作曲 小说 文章再到编剧 人们这些天为该项技术忙活的不亦乐乎 但事情很快得到了反转 有些人开始担心这项新的技术会被坏人所利用 而在版权界 生成式
  • 区块链学习笔记12——BTC思考

    区块链学习笔记12 BTC思考 学习视频 北京大学肖臻老师 区块链技术与应用 笔记参考 北京大学肖臻老师 区块链技术与应用 公开课系列笔记 目录导航页 哈希指针 BTC系统中很多地方用到了哈希指针 比如区块的块头就包含指向前一个区块的哈希指
  • MAC笔记本上搭建Vue环境

    1 安装Node js 打开终端 Terminal 在终端中输入以下命令安装Node js brew install node 如果你没有安装Homebrew 你可以在终端中输入以下命令安装 bin bash c curl fsSL htt
  • 计算机网络(二)

    目录 一 网络编程基础 1 1 为什么需要网络编程 1 2 什么是网络编程 1 3 网络编程中的基本概念 二 Socket套接字 2 1 概念 2 2 分类 2 3 Java数据报套接字通信模型 2 4 Java流套接字通信模型 2 5 U
  • springboot2.0整合logback日志(详细)

    文章转载于 https www cnblogs com zhangjianbing p 8992897 html
  • 1055 The World's Richest (25 point(s))

    题解 很容易超时 各种优化 最后还出现段错误 心态爆炸的一道题 include
  • Intellij IDEA--Pycharm插件开发

    Intellij IDEA开发 Pycharm插件开发 开发android用Android Studio 开发java用intelluj IDEA 开发python用Pycharm 其实三者都是jetbrains公司的产品 三者任何一个开发
  • 1.mbedtls移植到STM32

    mbedtls学习笔记 1 关于mbedtls 2 STM32移植方法 2 1STM32cubemx移植 2 2手动移植1 2 3移植总结 2 4手动移植2 2 4 1移植方式2 2 4 2测试SHA1加密 1 关于mbedtls 1 主要
  • 链表的实现

    在学习链表之前我们要看看前面的顺序表的缺陷 1 中间 头部的插入删除 时间复杂度为O N 2 增容需要申请新空间 拷贝数据 释放旧空间 会有不小的消耗 3 增容一般是呈2倍的增长 势必会有一定的空间浪费 例如当前容量为100 满了以后增容到
  • python随机函数random要导入哪个包_python学习之随机函数random

    文章目录 python学习之随机函数random 提示 以下是本篇文章正文内容 下面案例可供参考 一 随机函数模块 要想使用随机数 需先导入随机数模块 导入模块 import random 也就是在开头写上import random 二 六
  • Spring源码分析之如何开始Spring源码分析

    一 概述 对于大多数第一次看spring源码的人来说 都会感觉不知从哪开始看起 因为spring项目源码由多个子项目组成 如spring beans spring context spring core spring aop spring
  • 程序员成熟的标志

    http www cnblogs com n216 archive 2011 05 16 2047327 html 程序员成长路线图 从入门到优秀 成熟篇 节选3 程序员在经历了若干年编程工作之后 很想知道自己水平到底如何 自己是否已经成为
  • spring boot社区养老医疗服务平台 毕业设计源码041148

    springboot社区养老医疗服务平台 摘 要 随着社会的发展 社会的各行各业都在利用信息化时代的优势 计算机的优势和普及使得各种信息系统的开发成为必需 社区养老医疗服务平台 主要的模块包括查看首页 站点内容 轮播图 公告栏 系统用户 管
  • 关于工业4.0和智能制造的总结以及背后的思考

    工业4 0是德国首先提出来的 美国叫 工业互联网 我国叫 中国制造2025 这三者其实本质都是一样的 核心都是智能制造 在即将过去的2015年里 互联网 这个概念已经是家户喻晓了 大众创业 万众创新 上升到国家战略 此时又恰逢工业4 0来袭
  • python 动态仪表盘_使用Echarts3实现渐变仪表盘需求

    Echarts 仪表盘实践 项目过程中遇到一个这样的需求 这明显是一个仪表盘类型的图表 打开echarts的官方文档 可以看到有一个默认的实现 如下 使用了默认的参数 option tooltip formatter a b c toolb