配置项如下
var xData = ["电子信息工程", "智能工程", "汽车工程", "物理网工程", "商学院", "建筑工程", '艺术设计', '士官']
var data = [{
name: '理论课',
value: ["13", "25", "84", "68", "89", "45", 23, 23]
},
{
name: '理实一体课',
value: ["13", "25", "84", "68", "89", "45", 23, 23]
},
{
name: '实践课',
value: ["13", "25", "84", "68", "89", "45", 23, 23]
},
]
var barWidth = 30
var imgurl = ''
//背景图片不接受百分比,只接受数值,获取图表的宽度实现动态背景宽度
var imgwidth = myChart.getWidth()
// console.log(myChart.getWidth())
var colorsTop = {
'理论课':new echarts.graphic.LinearGradient(0, 0, 0, 1, [{
offset: 0,
color: "rgba(128, 195, 255, 1)"
},
{
offset: 1,
color: "rgba(128, 195, 255, 1)"
}
]),
'理实一体课':new echarts.graphic.LinearGradient(0, 0, 0, 1, [{
offset: 0,
color: "rgba(122, 240, 205, 1)"
},
{
offset: 1,
color: "rgba(122, 240, 205, 1)"
}
]),
'实践课':new echarts.graphic.LinearGradient(0, 0, 0, 1, [{
offset: 0,
color: "rgba(255, 209, 155, 1)"
},
{
offset: 1,
color: "rgba(255, 209, 155, 1)"
}
])
}
var colorsBottom = {
'理论课':'rgba(10, 121, 223, 1)',
'理实一体课':'rgba(97, 233, 193, 1)',
'实践课':'rgba(255, 189, 111, 1)'
}
// var colorsTop = [
// new echarts.graphic.LinearGradient(0, 0, 0, 1, [{
// offset: 0,
// color: "rgba(128, 195, 255, 1)"
// },
// {
// offset: 1,
// color: "rgba(128, 195, 255, 1)"
// }
// ]), new echarts.graphic.LinearGradient(0, 0, 0, 1, [{
// offset: 0,
// color: "rgba(122, 240, 205, 1)"
// },
// {
// offset: 1,
// color: "rgba(122, 240, 205, 1)"
// }
// ]), new echarts.graphic.LinearGradient(0, 0, 0, 1, [{
// offset: 0,
// color: "rgba(255, 209, 155, 1)"
// },
// {
// offset: 1,
// color: "rgba(255, 209, 155, 1)"
// }
// ])
// ]
// var colorsBottom = [
// 'rgba(10, 121, 223, 1)', 'rgba(97, 233, 193, 1)', 'rgba(255, 189, 111, 1)'
// ]
var colors = [
new echarts.graphic.LinearGradient(0, 1, 0, 0, [{
offset: 0,
color: "rgba(10, 121, 223, 1)"
},
{
offset: 1,
color: "rgba(78, 164, 243, 1)"
}
]), new echarts.graphic.LinearGradient(0, 1, 0, 0, [{
offset: 0,
color: "rgba(97, 233, 193, 1)"
},
{
offset: 1,
color: "rgba(11, 201, 145, 1)"
}
]), new echarts.graphic.LinearGradient(0, 1, 0, 0, [{
offset: 0,
color: "rgba(255, 189, 111, 1)"
},
{
offset: 1,
color: "rgba(255, 161, 38, 1)"
}
])
]
var option = chuliData(data, barWidth)
function chuliData(data, barWidth) {
let baseWidth = data.length == 3 ? 0 :1.5 / data.length
console.log(data)
var seriesData = []
data.forEach((item, i) => {
var item = {
name: data[i].name,
type: 'bar',
barWidth: barWidth,
barGap: '50%',
data: data[i].value,
}
var itemBottom = { //柱底圆片
name: data[i].name,
type: "pictorialBar",
symbolSize: [barWidth, barWidth * 0.5],
symbolOffset: [baseWidth*barWidth + (i - 1) * barWidth * 1.5, barWidth * 0.25],
z: 12,
silent: true,
// color: colorsBottom,
itemStyle: {
"normal": {
color: colorsBottom[item.name]
}
},
data: data[i].value
}
//柱顶圆片
var itemTop = {
name: data[i].name,
type: "pictorialBar",
symbolSize: [barWidth, barWidth * 0.5],
symbolOffset: [baseWidth*barWidth + (i - 1) * barWidth * 1.5, -barWidth * 0.25],
z: 12,
symbolPosition: "end",
silent: true,
itemStyle: {
"normal": {
color: colorsTop[item.name]
}
},
data: data[i].value
}
seriesData.push(itemTop)
seriesData.push(item)
seriesData.push(itemBottom)
})
var option = {
color: colors,
tooltip: {
// show:true,
trigger: 'item',
// trigger: 'axis',
// axisPointer: {
// type: 'shadow'
// },
// formatter(params) {
// const data = []
// params.map(item => {
// if (item.seriesType === 'bar') {
// data.push(item)
// }
// })
// var text = data[0].name + '</br>' +
// data[0].seriesName + ':' + data[0].value + '</br>' +
// data[1].seriesName + ':' + data[1].value + '</br>' +
// data[2].seriesName + ':' + data[2].value
// return text
// }
},
grid: {
top: 100,
right: 0,
left: 0,
bottom: 0,
containLabel: true
},
legend: {
show: true,
selectedMode: true,
orient: 'horizontal',
top: 0,
left: 0,
itemWidth: 16,
itemHeight: 16,
textStyle: {
color: 'rgba(102, 102, 102, 1)',
fontSize: 14
},
data: [{
name: '理论课',
icon: 'rect',
},
{
name: '理实一体课',
icon: 'rect',
},
{
name: '实践课',
icon: 'rect',
},
]
},
graphic: {
type: 'image',
id: 'logo',
left: 22,
bottom: 44,
z: 0,
left: 'center',
style: {
image: imgurl,
width: imgwidth,
height: 50,
}
},
xAxis: [{
data: xData,
axisLabel: {
textStyle: {
color: '#aaaaaa',
fontSize: 14
},
margin: 30, //刻度标签与轴线之间的距离。
},
axisLine: {
show: false //不显示x轴
},
axisTick: {
show: false //不显示刻度
},
boundaryGap: true,
splitLine: {
show: false,
width: 0.08,
lineStyle: {
type: "solid",
color: "#03202E"
}
}
}],
yAxis: [{
splitLine: {
// show: false,
lineStyle: {
color: 'rgba(216, 216, 216, 1)',
type: 'solid'
}
},
axisTick: {
show: false
},
axisLine: {
show: false
},
axisLabel: {
textStyle: {
color: '#888'
},
}
}],
series: seriesData
};
return option
}
// console.log(seriesData)
myChart.setOption(option);
myChart.on('legendselectchanged', function(obj) {
const selectedList = []
data.forEach((item,i) => {
if (obj['selected'][item['name']]) {
selectedList.push(item)
}
})
var option = chuliData(selectedList, 30)
myChart.setOption(option);
});