条纹背景柱状图
配置项如下
var salvProName = ["上海", "四川", "重庆", "西安", "云南"];
var dataArray = [22000, 15000, 9000, 8000, 7000];
var maxValue = []; //背景按最大值
var barImage = '';
var PatternImgA = new Image();
PatternImgA.src = barImage;
for (let i = 0; i < dataArray.length; i++) {
maxValue.push(dataArray[0])
}
option = {
backgroundColor: "#fff",
grid: {
left: '2%',
right: '2%',
bottom: '0%',
top: '5%',
containLabel: true
},
title: {
left: 'center',
text: '城市分布',
top: 15,
textStyle: {
fontSize: '15',
fontWeight: 500
}
},
tooltip: {
trigger: 'axis',
axisPointer: {
type: 'none'
},
formatter: function(params) {
return params[0].name + ' : ' + params[0].value
}
},
xAxis: {
show: false,
type: 'value'
},
yAxis: [{
type: 'category',
inverse: true,
axisLabel: {
show: true,
textStyle: {
// color: 'red',
fontSize: 13,
fontWeight: 500
},
},
splitLine: {
show: false
},
axisTick: {
show: false
},
axisLine: {
show: false
},
data: salvProName
}, {
type: 'category',
inverse: true,
axisTick: 'none',
axisLine: 'none',
show: true,
axisLabel: {
textStyle: {
color: '#4B4B4B',
fontSize: '12'
},
formatter: function(value) {
return (value * 10 / 10).toLocaleString() + '人';
},
},
data: dataArray
}],
series: [{
name: '值',
type: 'bar',
zlevel:1,
barCategoryGap: 23,
itemStyle: {
normal: {
barBorderRadius: 10,
color: new echarts.graphic.LinearGradient(0, 0, 1, 0, [{
offset: 0,
color: 'rgb(253,188,121)'
}, {
offset: 1,
color: 'rgb(249,131,71)'
}]),
},
},
barWidth: 16,
data: dataArray
},
{
//这里设置包含关系,只需要这一句话
barGap: "-100%",
type: 'bar',
zlevel:1,
data: dataArray,
barWidth: 16,
barCategoryGap: 23,
itemStyle: {
//此处引入条纹背景
color: {
image: PatternImgA,
repeat: 'repeat'
},
barBorderRadius: [16, 16, 0, 0],
xAxisIndex: 2,
yAxisIndex: 2,
zlevel: 2
}
},
{
name: '背景',
type: 'bar',
barWidth: 15,
barGap: '-100%',
data: maxValue,
itemStyle: {
normal: {
color: 'rgba(24,31,68,0.1)',
barBorderRadius: 30,
}
},
},
]
};