配置项如下
var nationalImg = ''
let bgSvg = ''
var category = [
"淮安",
"南京",
"宿迁",
"镇江",
"连云港",
"大连",
"南通",
"苏州",
"扬州",
"无锡",
"盐城",
"泰州",
"常州",
];
var barData = [{
"name": "农房楼龄5年",
"color": "#0f4636",
"value": [
10,
41,
22,
92,
72,
10,
41,
22,
92,
72,
92,
72,
10,
]
},
{
"name": "楼龄5-10年",
"color": "#12AF7B",
"value": [
64,
40,
24,
97,
39,
10,
41,
22,
92,
72,
10,
41,
22,
]
},
{
"name": "楼龄10年以上",
"color": "#31d0e9",
"value": [
64,
40,
24,
97,
39,
10,
41,
22,
92,
72,
10,
41,
22,
]
},
{
"name": "危房",
"color": "#C29B10",
"value": [
64,
40,
24,
97,
39,
10,
41,
22,
92,
72,
10,
41,
22,
]
}
]
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: [10, 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: '#09252e',
legend: {
data: barData.map((d) => d.name),
textStyle: {
color: '#fff'
}
},
grid: {
top:100,
left: 50,
right: 10,
bottom:90
},
xAxis: {
data: category,
show: true,
axisLabel: {
color: '#fff',
formatter: (value, index) => {
return [
'{national|}',
'{title|'+ value + '}'
].join('\n')
},
rich: {
title: {
color: '#eee',
align: 'center',
lineHeight: 10
},
national: {
height: 20,
lineHeight:10
},
}
},
axisLine: {
show: false
},
splitLine: {
show: false
},
},
yAxis: {
show: true,
splitLine: {
show: false
},
axisLine: {
show: false
},
axisLabel: {
show: true,
color: '#1381c9'
}
},
series:seriesData,
animation: true
};