//var getname=<#=GRID60.A1$#>; //var getseries = ['学院(部)转出比率', '学院(部)转入比率']; //var getvalue=[<#=GRID60.B1$#>,<#=GRID60.C1$#>]; //源数据 var getname = ["教育", "心理", "政法", "经管", "商学院", "建筑工程", '艺术设计', '士官'] var getseries = ['学院(部)转出比率', '学院(部)转入比率'] var getvalue = [ [11, 22, 33, 44, 55, 66, 77, 88], [55, 44, 66, 25, 44, 13, 22,80] ] //转换为map操作 var data = getseries.map((item, index) => { return { name: getseries[index], value: getvalue[index] } }) var barWidth = 20 //var imgurl = '' var imgurl = '' var imgwidth = myChart.getWidth()*0.96 //柱图body颜色 var colorsBottom = { '学院(部)转出比率': new echarts.graphic.LinearGradient(0, 0, 0, 1, [ { offset: 0, color: "#61E9C1" }, { offset: 1, //color: "rgba(122, 240, 205, 1)" color:"#0BC991" } ]), '学院(部)转入比率': new echarts.graphic.LinearGradient(0, 0, 0, 1, [ { offset: 0, color: "#4EA4F3" }, { offset: 1, //color: "rgba(128, 195, 255, 1)" color: "#0A79DF" } ]) } //柱图顶 淡色圆圈 var colorsTop = { '学院(部)转出比率': 'rgba(122, 240, 205, 1)', '学院(部)转入比率': 'rgba(128, 195, 255, 1)', /* '学院(部)转出比率': 'rgba(97, 233, 193, 1)', '学院(部)转入比率': 'rgba(10, 121, 223, 1)',*/ } var colorsTip = { '学院(部)转出比率': 'rgba(122, 240, 205, .2)', '学院(部)转入比率': 'rgba(128, 195, 255, .2)', /* '学院(部)转出比率': 'rgba(97, 233, 193, 1)', '学院(部)转入比率': 'rgba(10, 121, 223, 1)',*/ } //线图颜色变量 var colorsTopLine = { '学院(部)转出比率': 'orange', '学院(部)转入比率': '#db4040', } var colorsLineColor = { '学院(部)转出比率': 'orange', '学院(部)转入比率': '#db4040', } //获取legend:对map中的每一个元素,设定一个legend,并衍生出其它的legend function getLegend(){ let legendData = [] getseries.map(item=>{ legendData.push({ name:item, icon:'roundRect', }) legendData.push({ name:item.replace('学院(部)','')+'均值', icon:'line', }) }) return legendData } //未知用途数组 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, itemStyle:{ normal:{ barBorderRadius: [0, 0, 9, 9], color: colorsBottom[data[i].name], //柱图顶显示数据 label: { show: true, position: 'top', align: 'center', lineHeight: 28, textStyle: { //数值样式 fontSize: 16, }, formatter: item => { return `{circle|${item.data}}` }, rich: { circle: { width: 28, //柱图顶数字颜色控制 backgroundColor: colorsTip[data[i].name], color: '#FFFFFF', // backgroundColor: colorssumbac[data[i].name], color:colorsTop[data[i].name], borderRadius: 3, fontSize: 14, padding: [0, 0, 2, 0] } } }, } } } //柱底圆片 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, barWidth:20, itemStyle: { "normal": { color: colorsBottom[item.name] } }, data: data[i].value } //柱顶圆片 var itemTop = { name: data[i].name, type: "pictorialBar", symbolSize: [barWidth, barWidth * 0.75], symbolOffset: [baseWidth * barWidth + (i - 1) * barWidth * 1.5, -barWidth * 0.45], z: 12, symbolPosition: "end", silent: true, itemStyle: { "normal": { color: colorsTop[item.name] } }, data: data[i].value } //下面顺序会影响标题的颜色 seriesData.push(item) seriesData.push(itemTop) //seriesData.push(itemBottom) }) //线图详细设计 let lineSeries = data.map(item => { return { name: item.name.replace('学院(部)','')+'均值', type: 'line', xAxisIndex: 0, data: item.value, lineStyle: { type: 'dashed', color: 'rgba(0,0,0,0)' }, symbolSize: 0.0000001, silent: true, label: { show: false }, //图例颜色控制 //color: '#FFA387', color: colorsTopLine[item.name], symbol: 'none', markLine: { silent: true, data: [{ type: 'average', name: '平均值' }], lineStyle: { //color: '#FFA387', color: colorsLineColor[item.name], textStyle: { color: 'red', } }, symbol: 'none', label: { show: true, position: 'end', align: 'center', lineHeight: 28, padding: [-10, 0, 0, -50], textStyle: { //数值样式 fontSize: 16, }, formatter: item => { console.log('markLine', item) return `{circle|${item.value}}\n` }, rich: { circle: { //不同线不同颜色 //backgroundColor: 'rgba(255, 99, 136, 1)', backgroundColor: colorsTopLine[item.name], color: '#FFFFFF', borderRadius: 3, fontSize: 14, padding: [0, 5, 2, 5] }, mb: { padding: [0, 0, 20, 0] } } } }, markArea: { data: [ [{ yAxis: 'average', itemStyle: { color: '#FFA387', opacity: 0.1 } }, { yAxis: '0' }] ], } } }) var sum1 = 0; var sum2 = 0; for (var i = 0; i < lineSeries[0].data.length; i++) { sum1 = sum1+lineSeries[0].data[i]; } for (var i = 0; i < lineSeries[1].data.length; i++) { sum2 = sum2+lineSeries[1].data[i]; } var average1 = sum1 / lineSeries[0].data.length; var average2 = sum2 / lineSeries[1].data.length; var option = { color: colors, //鼠标显示 tooltip: { show:true, //trigger: 'item', trigger: 'axis', axisPointer: { type: 'none' }, backgroundColor : 'rgba(21, 64, 92, 0.9)', formatter: function(params) { var str = ''; //声明一个变量用来存储数据 str += '<div>' + params[0].name + '</div>'; for (var i = 0; i < params.length; i++) { str = '<span>' + params[0].name + '</span></br>'+ '<span style="display:inline-block;float:left;width:12px;height:12px;margin-top:5px;background:#61E9C1;color:#fff;border-radius:30%;"></span>'+ '<span>  学院(部)转出比率:</span>'+ '<span style="display:block;width:60px;float:right;text-align:right;color:rgba(0, 255, 252, 1);">'+ getvalue[0][params[i].dataIndex]+ '</span></br>'+ '<span style="display:inline-block;float:left;width:12px;height:12px;margin-top:5px;background:#0A79DF;color:#fff;border-radius:30%;"></span>'+ '<span>  学院(部)转入比率:</span>'+ '<span style="display:block;width:60px;float:right;text-align:right;color:rgba(0, 255, 252, 1);">'+ getvalue[1][params[i].dataIndex]+ '</span></br>'+ '<span style="display:inline-block;float:left;width:12px;height:12px;margin-top:5px;background:orange;color:#fff;border-radius:30%;"></span>'+ '<span>  转出比率均值:</span>'+ '<span style="display:block;width:60px;float:right;text-align:right;color:rgba(0, 255, 252, 1);">'+ average1.toFixed(2)+ '</span></br>'+ '<span style="display:inline-block;float:left;width:12px;height:12px;margin-top:5px;background:#db4040;color:#fff;border-radius:30%;"></span>'+ '<span>  转入比率均值:</span>'+ '<span style="display:block;width:60px;float:right;text-align:right;color:rgba(0, 255, 252, 1);">'+ average2.toFixed(2)+ '</span></br>'; } return str; } }, grid: { top: '33', right: '15', left: '50', bottom: '55' }, //图标详细设置 legend: { show: true, selectedMode: true, orient: 'horizontal', right: 20, itemWidth: 16, itemHeight: 16, textStyle: { //图例文字颜色 color: 'rgba(102, 102, 102, 1)', fontSize: 14 }, data: getLegend() }, graphic: { type: 'image', id: 'logo', left: 50, right:30, bottom: 45, z: -1, style: { image: imgurl, width: imgwidth, height: 50, } }, xAxis: [{ data: getname, axisLabel: { formatter: function(value) { var ret = ""; //拼接加\n返回的类目项 var maxLength = 4; //每项显示文字个数 var valLength = value.length; //X轴类目项的文字个数 var rowN = Math.ceil(valLength / maxLength); //类目项需要换行的行数 if (rowN > 1) //如果类目项的文字大于3, { for (var i = 0; i < rowN; i++) { var temp = ""; //每次截取的字符串 var start = i * maxLength; //开始截取的位置 var end = start + maxLength; //结束截取的位置 //这里也可以加一个是否是最后一行的判断,但是不加也没有影响,那就不加吧 temp = value.substring(start, end) + "\n"; ret += temp; //凭借最终的字符串 } return ret; } else { return value; } }, margin: 20, color: '#666666', textStyle: { fontSize: 13 }, axisLine: { lineStyle: { color: '#B0C5DB', } }, axisTick: { show: false }, }, axisLine: { show: false //不显示x轴 }, axisTick: { show: false //不显示刻度 }, boundaryGap: true, splitLine: { show: false, width: 0.08, lineStyle: { type: "solid", color: "#03202E" } } }], yAxis: [{name: '%', nameTextStyle: { color: '#999999', fontSize: 13, padding: [0, 0, 0, 20] }, axisLabel: { color: '#666666', textStyle: { fontSize: 13 }, }, axisLine: { show: false }, axisTick: { show: false }, splitLine: { lineStyle: { color: '#CCDBEB', type: 'dashed', opacity: 0.5 } } }], series: [...seriesData, ...lineSeries] }; 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); });