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); });