用Echarts制作多段圆环图的过程及优化
Admin 2022-11-15 群英技术资讯 1263 次浏览
今天就跟大家聊聊有关“用Echarts制作多段圆环图的过程及优化”的内容,可能很多人都不太了解,为了让大家认识和更进一步的了解,小编给大家总结了以下内容,希望这篇“用Echarts制作多段圆环图的过程及优化”文章能对大家有帮助。
第一眼看的时候以为用echarts里的饼图做一些修改可以达到,但是效果都不太好,首先是每段弧段的边缘有一个圆角的处理,其次是弧度的宽度是不同,灰色最细,红色次之,绿色是最宽的.
第二时间又看到了一些圆环进度条的示例

本来以为这种图应该可以实现了,但去看了示例的代码发现这种图是echarts里的pie组件的一个叠加,一般叠加一次,有两个区域效果还算可以,但是3个区域的效果在不设置圆弧的宽度时还算可以接受,但是设置了宽度后总会有一些叠加后超出不太美观的问题.
最终在玫瑰图的网站上找到一个比较复杂的实现,通过修改各项配置基本完美的使用ehcarts实现了这个图形. 首先是echarts的一个option的配置代码,为了方便将series与option做了一个分离
const colorDataHandle = (data, total, width = 375) => {
let num = 0
let option = {
angleAxis: {
axisLine: {
show: false,
},
axisLabel: {
show: false,
},
splitLine: {
show: false,
},
axisTick: {
show: false,
},
min: 'dataMin',
max: 'dataMax',
startAngle: 135,
},
radiusAxis: {
type: 'category',
axisLine: {
show: false,
},
axisTick: {
show: false,
},
axisLabel: {
show: false,
},
},
polar: {
radius: '95%'
},
series: []
}
// option是对传入的数据的一个处理
const options = data.map((item, index) => {
num += item
const a = {
type: 'bar',
data: [0, 0, 0, num],
coordinateSystem: 'polar',
z: 9999 - index,
roundCap: true,
color: colors[index],
barGap: '-100%',
// barWidth: '30%',
itemStyle: {
// 控制弧的宽,弧的宽的控制并没有做太多的情况判断,简单的区分了一下
borderWidth: index === 0 ? 4 : index === 1 ? 2 : 0,
// shadowBlur: 5,
// color: 'transparent',
borderColor: colors[index],
shadowColor: colors[index],
},
}
return a
})
option.series = options
return option
}
然后是对3种颜色区域的一个处理
const colors = [
{
type: 'linear',
x: 0,
y: 0,
x2: 0,
y2: 1,
colorStops: [
{
offset: 0,
color: '#1DBC3F', // 0% 处的颜色
},
{
offset: 1,
color: '#1DBC3F', // 100% 处的颜色
},
],
},
{
type: 'linear',
x: 0,
y: 0,
x2: 0,
y2: 1,
colorStops: [
{
offset: 0,
color: '#CB3939', // 0% 处的颜色
},
{
offset: 1,
color: '#CB3939', // 100% 处的颜色
},
],
},
{
type: 'linear',
x: 0,
y: 0,
x2: 0,
y2: 1,
colorStops: [
{
offset: 0,
color: '#C0C0C0', // 0% 处的颜色
},
{
offset: 1,
color: '#C0C0C0', // 100% 处的颜色
},
],
},
];
这里是灵活使用了echarts type为linear的组件,具体的一个配置项是怎么实现我并没有深入探究.
最终实现的一个效果图在真机上的展示


既保证了每段弧的首尾的圆角的问题,也实现了每段弧宽的增加
echarts这个库确实博大进深,同时对一些没有做过的需求的评估需要谨慎再谨慎,我看到这个图形时觉得用echarts应该就ok了,但实际在开发的过程中,坑还是很多,同样机会也在不经意中就出现了,机会还是留给有准备的人的,如果想着图形太复杂随随便便用个环形图就去实现可能在页面的呈现上也没有这么好的效果了.
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:mmqy2019@163.com进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。
猜你喜欢
这篇文章主要为大家详细介绍了vue车牌输入组件的实现方法,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
jquery选定元素修改属性的方法:1、利用“$(指定元素)”语句获取指定元素对象;2、利用attr()方法来修改已获取到元素对象的属性 ,语法为“元素对象.attr(attribute,value)”。
这篇文章主要给大家介绍的关于vue路由懒加载的内容,很多刚接触vue的朋友,可能对于vue路由懒加载是什么以及实现方法不是很清楚,因此下面小编就带大家来了解一下。
增加方法:1、使用“$(".类名")”语句获取设置了某个指定类的元素节点;2、使用“元素节点.click(function(){...})”语句给获取的元素节点增加点击事件。
中国省市区三级联动Jquery插件经常被使用到,不管是网站还是app,这个都是需要掌握的,我们知道中国省市区三级联动的数据可以存储在mysql数据库中,也可以直接存储在distpicker.data.js这样的js文件中,下面来开始学习如何使用Jquery省市区三级联动插件。 下
成为群英会员,开启智能安全云计算之旅
立即注册Copyright © QY Network Company Ltd. All Rights Reserved. 2003-2020 群英 版权所有
增值电信经营许可证 : B1.B2-20140078 粤ICP备09006778号 域名注册商资质 粤 D3.1-20240008