风琴的图表,只为了儿童的记忆
配置项如下
var barImg = 'image://';
var data = [];
var xData = [];
var lineData = [];
var barData = [];
for (var i = 0; i < 12; ++i) {
data.push({
month: Number(i) + 1 + '月',
value: Math.random() * 1000 + 100,
rate: (Math.random() * 999 / 100 + 10).toFixed(2),
});
}
function dealChats(data) {
data.map((value, index) => {
xData.push(value.month);
lineData.push(value.rate);
if (index === 0) {
barData.push({
value: value.value,
itemStyle: {
normal: {
barBorderRadius: [50, 50, 0, 35]
}
}
})
} else if (index === data.length - 1) {
barData.push({
value: value.value,
itemStyle: {
normal: {
barBorderRadius: [50, 50, 35, 0]
}
}
});
} else {
barData.push(value.value)
}
});
}
dealChats(data)
console.log(xData)
option = {
backgroundColor:'rgb(6,29,75)',
title:{
text:'实时监控图',
left:'center',
top:'10',
textStyle:{
color:"#fff",
}
},
legend: {
data: ['服务数量', '基准线'],
left:'center',
top:'50',
textStyle:{
color:"#fff",
}
},
grid: {
left: 10,
right: -35,
bottom: 40,
top: 100,
containLabel: true
},
tooltip: {
trigger: 'axis',
axisPointer: {
type: 'none'
},
"formatter": function(param) {
return param[0].name + ':' + '<br>' + param[0].seriesName + ":" + param[0].value + '<br>' +
'合格率:' + param[2].value + '%'
},
},
xAxis: {
offset: 35,
data: xData,
axisLine: {
show: false
},
splitLine: {
show: false
},
axisTick: {
show: false
},
axisLabel: {
show: true,
textStyle: {
color: "#b6b5ab",
},
interval: 0
},
},
yAxis: [{
axisLabel: {
show: true,
textStyle: {
color: "#b6b5ab"
}
},
axisLine: {
show: false
},
splitLine: {
show: false
},
axisTick: {
show: false
},
}, {
show: true,
splitLine: {
show: false
},
axisLine: {
show: false
},
axisTick: {
show: false
},
}, {
show: false,
}],
series: [{
type: 'bar',
name:'服务数量',
barWidth: '60%',
barGap: "-100%",
itemStyle: {
normal: {
color: {
type: 'linear',
x: 1,
y: 1,
x2: 0,
y2: 0,
colorStops: [{
offset: 0,
color: '#00c6f4' // 0% 处的颜色
}, {
offset: 1,
color: '#00db97' // 100% 处的颜色
}],
globalCoord: false // 缺省为 false
},
borderWidth: 0,
barBorderRadius: [50, 50, 0, 0]
}
},
data: barData
}, {
type: 'bar',
barWidth:'60%',
itemStyle: {
normal: {
color: {
type: 'linear',
x: 1,
y: 1,
x2: 0,
y2: 0,
colorStops: [{
offset: 0,
color: '#00c6f4' // 0% 处的颜色
}, {
offset: 1,
color: '#00db97' // 100% 处的颜色
}],
globalCoord: false // 缺省为 false
},
borderWidth: 0,
barBorderRadius: [-30, -30, 0, 0]
}
},
data: [{
value: 0,
itemStyle: {
normal: {
barBorderRadius: [0, -30, 0, 0]
}
}
}, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, {
value: 0,
itemStyle: {
normal: {
barBorderRadius: [-30, 0, 0, 0]
}
}
}],
}, {
name: '基准线',
type: 'line',
symbolSize: 6,
yAxisIndex: 1,
lineStyle: {
normal: {
color: '#eba538'
}
},
itemStyle: {
normal: {
color: '#eba538'
}
},
data: lineData
}, {
value: 60,
symbol: barImg,
type: 'pictorialBar',
barWidth: '60%',
// barGap: "-98%",
name: 'pictorial element',
symbolSize: ['100%', '100%'],
symbolPosition: 'center',
yAxisIndex: 2,
z: 10,
data: [1000, 1000, 1000, 1000, 1000, 1000, 1000, 1000, 1000, 1000, 1000, 1000]
}, ]
};