配置项如下
var uploadedDataURL = "";
var option = {
graphic: {
elements: [{
type: 'image',
style: {
image: uploadedDataURL,
width: 70,
height: 70
},
left: 'center',
top: 'center'
}]
},
backgroundColor: '#ffffff',
series: [
//最外层圆环
{
type: 'pie',
zlevel: 3,
silent: true,
radius: ['67%', '68%'],
startAngle: -65,
label: {
normal: {
show: false
},
},
itemStyle: {
color: 'red'
},
labelLine: {
normal: {
show: false
}
},
data: _pie2()
},
//背景圆环
{
type: 'pie',
zlevel: 1,
silent: true,
radius: ['40%', '60%'],
hoverAnimation: false,
// animation:false, //charts3 no
label: {
normal: {
show: false
},
},
labelLine: {
normal: {
show: false
}
},
data: _pie1()
},
{
zlevel: 2,
name: '中间环形图',
type: 'pie',
radius: ['45%', '55%'],
avoidLabelOverlap: false,
hoverAnimation: false,
label: {
normal: {
show: false,
position: 'center',
},
emphasis: {
show: true,
textStyle: {
fontSize: '30',
fontWeight: 'bold'
}
}
},
labelLine: {
normal: {
show: false
}
},
data: [{
value: "25",
name: "2",
},
{
value: "25",
name: "3",
},
{
value: "25",
name: "4",
},
{
value: "25",
name: "5",
},
{
value: "25",
name: "6",
}
]
},
{
name: '最里层环形',
type: 'pie',
startAngle: 315,
hoverAnimation: false,
radius: ["30%", "31%"],
label: {
normal: {
show: false,
position: 'center'
},
emphasis: {
show: true,
textStyle: {
fontSize: '10',
fontWeight: 'bold'
}
}
},
labelLine: {
normal: {
show: false
}
},
data: [{
value: 25,
itemStyle: {
normal: {
color: "rgba(0,0,0,0)"
}
}
},
{
value: 70,
itemStyle: {
normal: {
color: "rgba(20,198,249,1)"
}
}
},
]
}
]
};
function _pie1() {
let dataArr = [];
for (var i = 0; i < 8; i++) {
dataArr.push({
name: (i + 1).toString(),
value: 20,
itemStyle: {
normal: {
color: "rgba(88,142,197,0.1)",
borderWidth: 0,
borderColor: "rgba(0,0,0,0)"
}
}
})
}
return dataArr
}
function _pie2() {
let dataArr = [];
var index = 0;
for (var i = 0; i < 8; i++) {
if (i % 2 === 0) {
var temp = new echarts.graphic.LinearGradient(
0, 0, 1, 1,
[{
offset: 0,
color: '#3ac26e'
},
{
offset: 0.2,
color: '#dab344'
},
{
offset: 0.4,
color: '#0CB9FF'
},
{
offset: 0.6,
color: '#e72b7c'
},
{
offset: 0.8,
color: '#1976b9'
},
{
offset: 1,
color: '#620fa0'
}
]
)
dataArr.push({
name: (i + 1).toString(),
value: 25,
itemStyle: {
normal: { //颜色渐变
color: temp,
borderWidth: 0,
borderColor: "rgba(0,0,0,0)"
}
}
})
} else {
dataArr.push({
name: (i + 1).toString(),
value: 5,
itemStyle: {
normal: {
color: "rgba(0,0,0,0)",
borderWidth: 0,
borderColor: "rgba(0,0,0,0)"
}
}
})
}
}
return dataArr
}