let bgSvg = ''
var category = [
"东北",
"华东",
"华中",
"西南",
"华北"
];
var barData = [{
"name": "低危",
"color": "#3ca418",
"value": [10,41,22,92,72]
},
{
"name": "中危",
"color": "#31d0e9",
"value": [64,40,24,97,39]
},
{
"name": "高危",
"color": "#ed902c",
"value": [69,36,58,49,90]
},
{
"name": "危急",
"color": "#d8436b",
"value": [94,7,67,33,20]
}
]
let seriesData = barData.map((d, i) => {
let arr = []
if (i > 0) {
let before = barData[i - 1]
arr = d.value.map((v, j) => {
let res = v
res += before.value[j]
d.value[j] = res
return res
})
} else {
arr = d.value
}
console.log(arr)
return {
name: d.name,
data: arr,
type: 'pictorialBar',
symbol: 'rect',
symbolSize: [40, 8],
barWidth: 10,
itemStyle: {
normal: {
barBorderRadius: 52,
color: d.color
}
},
stack: 'all',
symbolRepeat: true,
animationEasing: 'elasticOut',
animationDelay: function(dataIndex, params) {
return params.index * 30 * 1.1;
},
z: -i
}
})
let backgroundData = [280, 280, 280, 280, 280]
option = {
backgroundColor: '#0A1934',
grid: {
top: 30,
left: 30,
right: 30,
bottom: 90
},
xAxis: {
data: category,
show: true,
axisLabel: {
color: '#fff',
formatter: (value, index) => {
return [
'{title|'+ value + '}'
].join('\n')
},
rich: {
title: {
color: '#eee',
align: 'center',
lineHeight: 40
},
}
},
axisLine: {
show: false
},
splitLine: {
show: false
},
},
yAxis: {
show: false,
splitLine: {
show: false
},
axisLine: {
show: false
},
axisLabel: {
color: '#fff'
}
},
series: [].concat(
{
data: backgroundData,
type: 'pictorialBar',
symbol: 'image://' + bgSvg,
symbolOffset: ['-45%', 10],
z: -100
},
seriesData),
animation: true
};