Echarts实现自定义仪表盘

本文介绍sEcharts如何实现自定义仪表盘

之前写了一篇关于如何使用gpt来高效日常工作

在Echarts的官网找到一个来进行代替,对这个示例进行一下改造,可以我们的目标实现的效果是没有刻度和中间指针等效果的,所以第一步需要先去掉刻度和指针等参数

如果我们需要对仪表盘的某些配置进行查询,第一建议是直接使用GPT,因为你可以省去很多查文档的时间,但因为GPT的 智商也有待考验,所以某些配置描述的不是很清楚,第二步再去查询对应的文档,在配置项这个模块里面包含了各种配置的 一些参数,我们直接到仪表盘这个参数,series-gaugeData

kotlin 复制代码
找到三个参数pointer,anchor,axisLabel,splitLine并且把data值去掉,我们不需要data值
后续我们直接用detail来替代

分别表示 指针,原点,对于仪表盘来说他其实就是在画一个圆,axisLabel表示刻度的标签,spliLine表示刻度的分割线, 把这些都去掉之后就剩下一个光秃秃的圆盘了,现在需要根据设计来加上对应的功能

axisLine是整个曲线轴,其实图中这段圆弧分成了两部分,一部分是曲线轴,另一部分是进度,也就是另外一个参数 process参数,由于目标前后都是圆的,所以这里需要用到axisline的参数roundCap,

实现进度条渐变

对于进度条来说可能进度的颜色是一个UI常常需要你开发的点,这里我们用到线性渐变来对进度条的颜色做一个实现 要有进度的前提是需要先设置一下data的value,加上了data就会默认显示detail的数据,会有一个默认的data进度'50',出现在下方,这里只需要对detail的show改成false即可

js 复制代码
progress: {
    show: true,
    width: 16,
    roundCap: true,
    itemStyle: {
      color: {
        type: 'linear',
        x: 0,
        y: 0,
        x2: 0,
        y2: 1,
        colorStops: [
          { offset: 0, color: 'red' },// 0% 处的颜色
          { offset: 1, color: 'blue' }// 100% 处的颜色
        ]
      }
    },
},
data: [
    {
      value:50
    }
]

半圆弧实现

仪表盘其实是一个圆形,可以根据开始角度和结束角度来绘制想要的弧度。

现在上图线上的是一个150度的圆弧,可以看出起点是在三点钟方向,以顺时针方向开始绘制

所以当我们想实现一个180度的圆弧的时候,只需要去控制一下仪表盘的开始弧度,以及结束的弧度。

js 复制代码
series: [
        {
          type: 'gauge',
          startAngle: 180,
          endAngle: 0,

即可实现半圆的弧形,从参数可以看出我们的圆弧是从180度到0度的一个弧形。

文字定位实现

如果我们把detail的show属性设置为true,那么就会发现detail的位置是位于圆形的下方,

现在我们需要自定义样式,改成上下两行,并且调整他的位置,需要用到detail.rich属性

js 复制代码
detail: {
            formatter: '{line2|206236}\n{line3|在线用户数(人)}',
            rich: {
              line2: {
                fontSize: rtp * 0.45,
                fontWeight: 800,
                color: '#3A92E1'
              },
              line3: {
                fontSize: rtp * 0.35,
                color: '#60D0FD',
                borderColor: '#60D0FD',  // 边框颜色
                borderWidth: 1,       // 边框宽度
                padding: [rtp * 0.1, rtp * 0.2],
                borderRadius: 50
              }
            },
},

先来解析一下个formatter和rich

formatter是一个文字模版,包含了两行文字并且换行,rich则是一些文字的样式

然后解决文字的定位问题,让文字偏移到弧形的正下方。

当加上offsetCenter属性的时候,是一个数组[0,0]表示处于圆心处。

js 复制代码
    offsetCenter: [0, '-20%']

借助百分比实现到圆心的上方。

最终效果

🙏 感谢您花时间阅读这篇文章!如果觉得有趣或有收获,请关注我的更新,给个喜欢和分享。您的支持是我写作的最大动力!

往期好文推荐

相关推荐
人工智能训练2 小时前
【极速部署】Ubuntu24.04+CUDA13.0 玩转 VLLM 0.15.0:预编译 Wheel 包 GPU 版安装全攻略
运维·前端·人工智能·python·ai编程·cuda·vllm
会跑的葫芦怪2 小时前
若依Vue 项目多子路径配置
前端·javascript·vue.js
pas1365 小时前
40-mini-vue 实现三种联合类型
前端·javascript·vue.js
摇滚侠5 小时前
2 小时快速入门 ES6 基础视频教程
前端·ecmascript·es6
珑墨6 小时前
【Turbo】使用介绍
前端
军军君016 小时前
Three.js基础功能学习十三:太阳系实例上
前端·javascript·vue.js·学习·3d·前端框架·three
打小就很皮...7 小时前
Tesseract.js OCR 中文识别
前端·react.js·ocr
wuhen_n8 小时前
JavaScript内存管理与执行上下文
前端·javascript
Hi_kenyon8 小时前
理解vue中的ref
前端·javascript·vue.js
落霞的思绪9 小时前
配置React和React-dom为CDN引入
前端·react.js·前端框架