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%']

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

最终效果

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

往期好文推荐

相关推荐
QQ1__8115175158 小时前
Spring boot名城小区物业管理系统信息管理系统源码-SpringBoot后端+Vue前端+MySQL【可直接运行】
前端·vue.js·spring boot
钛态8 小时前
前端微前端架构:大项目的救命稻草还是自找麻烦?
前端·vue·react·web
一粒黑子8 小时前
【实战解析】阿里开源 PageAgent:纯前端 GUI Agent,一行JS让网页支持自然语言操控
前端·javascript·开源
独角鲸网络安全实验室8 小时前
2026微信小程序抓包全解析:从实操落地到合规风控,解锁前端调试新范式
前端·微信小程序·小程序·抓包·系统代理绕过·https证书严格校验·进程隔离
紫微AI8 小时前
前端文本测量成了卡死一切创新的最后瓶颈,pretext实现突破了
前端·人工智能·typescript
GISer_Jing8 小时前
AI前端(From豆包)
前端·aigc·ai编程
IT枫斗者8 小时前
前端部署后如何判断“页面是不是最新”?一套可落地的版本检测方案(适配 Vite/Vue/React/任意 SPA)
前端·javascript·vue.js·react.js·架构·bug
测试修炼手册8 小时前
[测试技术] 深入理解 JSON Web Token (JWT)
前端·json
AI老李8 小时前
2026 年 Web 前端开发的 8 个趋势!
前端
里欧跑得慢8 小时前
15. Web可访问性最佳实践:让每个用户都能平等访问
前端·css·flutter·web