**
效果图:
**
代码:
注意:光圈发光有光晕,文字在指示线的上方
let _that = this
var chartDom = document.getElementById('course')
var myChart = echarts.init(chartDom)
var option
var img =
""
let arrD = []
for (const key in _that.numX) {
if (Object.hasOwnProperty.call(_that.numX, key)) {
const element = _that.numX[key]
arrD.push({
name: key,
value: element,
})
}
}
let xname = []
this.echartsList.forEach(r=>{
xname.push(r.name)
})
var trafficWay = this.echartsList || arrD
var data = []
var color = [
"#00ffff",
"#00cfff",
"#006ced",
"#ffe000",
"#ffa800",
"#ff5b00",
"#ff3000",
]
for (var i = 0; i < trafficWay.length; i++) {
data.push(
{
value: trafficWay[i].value,
name: trafficWay[i].name,
itemStyle: {
normal: {
borderWidth: 5,
shadowBlur: 20,
borderColor: color[i],
shadowColor: color[i],
},
},
},
{
value: 2,
name: "",
itemStyle: {
normal: {
label: {
show: false,
},
labelLine: {
show: false,
},
color: "rgba(0, 0, 0, 0)",
borderColor: "rgba(0, 0, 0, 0)",
borderWidth: 0,
},
},
}
)
}
// console.log(data)
var seriesOption = [
{
type: "pie",
// clockWise: false,
radius: [105, 109],
// hoverAnimation: false,
label:{
color: "#ddd",
alignTo: 'edge',
edgeDistance: 10,
minMargin: 5,
lineHeight: 25,
formatter: function (params) {
if (params.name !== "") {
return (
params.name +
":" + params.value + '\n'
)
} else {
return ""
}
},
padding:[0,10]
},
labelLine: {
length: 25,
length2: 0,
maxSurfaceAngle: 80
},
itemStyle: {
borderColor: '#fff',
borderWidth: 1
},
labelLayout: (params) => {
const isLeft = params.labelRect.x < myChart.getWidth() / 2;
const points = params.labelLinePoints;
// Update the end point.
points[2][0] = isLeft
? params.labelRect.x
: params.labelRect.x + params.labelRect.width;
return {
labelLinePoints: points
};
},
data: data,
},
]
option = {
backgroundColor: "rgba(255,255,255,0)",
color: color,
title: [
{
text: this.title,
top: "50%",
textAlign: "center",
left: "49%",
textStyle: {
color: "#fff",
fontSize: 22,
fontWeight: "400",
},
},
{
text: this.allCount,
top: "40%",
textAlign: "center",
left: "49%",
textStyle: {
color: "#1FD6F0",
fontSize: 22,
fontWeight: "400",
},
}
],
graphic: {
elements: [
{
type: "image",
z: 3,
style: {
image: img,
width: 178,
height: 178,
},
left: "center",
top: "center",
position: [100, 100],
},
],
},
tooltip: {
show: false,
},
legend: {
show: false,
icon: "circle",
orient: "horizontal",
// x: 'left',
data: xname,
right: 10,
bottom: 0,
align: "right",
textStyle: {
color: "#fff",
},
itemGap: 10,
},
toolbox: {
show: false,
},
series: seriesOption,
}
option && myChart.setOption(option)