花里胡哨的排序图
配置项如下
option = commonEchartOption_4(
['#9fb9e3', 21, '链路利用率Top5', '5%'],
[
['15%', '10%', '53%', '5'],
['15%', '55%', '7%', '5'],
],
[
[1020, 0],
[1060, 1],
],
[
[
'category',
'left',
[-5, 0, 0, 0],
[-70, 0, 0, 12],
'#9FB9E3',
16,
35,
0,
'left',
[-32, -30, 0, 0],
14,
[true, [32, -30, 0, 0]],
],
[
'category',
'left',
[-5, 0, 0, 0],
[-70, 0, 0, 10],
'#9FB9E3',
16,
5,
1,
'left',
[-32, -20, 0, 0],
14,
[true, [32, -20, 0, 0]],
],
],
[
[
'一平面入口流量',
'8%',
'#00D4FF',
'#00D4FF',
0,
0,
['40%', ['80%', '100%'], ['0%', '0%']],
[true, '进', '#00D4FF'],
],
[
'一平面出口流量',
'8%',
'#34E598',
'#34E598',
0,
0,
['40%', ['80%', '100%'], ['0%', '0%']],
[true, '出', '#34E598'],
],
[
'二平面入口流量',
'8%',
'#00D4FF',
'#00D4FF',
1,
3,
['40%', ['80%', '100%'], ['0%', '0%']],
[true, '进', '#00D4FF'],
],
[
'二平面出口流量',
'8%',
'#34E598',
'#34E598',
1,
3,
['40%', ['80%', '100%'], ['0%', '0%']],
[true, '出', '#34E598'],
],
],
5,
'Mb',
true
);
option.yAxis[0].data = ['xx站(一平面)', 'xx站(一平面)', 'xx站(一平面)', 'xx站(一平面)', 'xx站(一平面)'];
option.series[0].data = [360, 420, 534, 635, 800];
option.series[1].data = [400, 434, 335, 260, 220];
option.yAxis[1].data = [360, 420, 534, 635, 800];
option.yAxis[2].data = [400, 434, 335, 260, 220];
option.yAxis[3].data = ['xx站(二平面)', 'xx站(二平面)', 'xx站(二平面)', 'xx站(二平面)', 'xx站(二平面)'];
option.series[2].data = [360, 420, 534, 635, 800];
option.series[3].data = [400, 434, 335, 260, 220];
option.yAxis[4].data = [360, 420, 534, 635, 800];
option.yAxis[5].data = [400, 434, 335, 260, 220];
function commonEchartOption_4(
titleobj,
gridobj,
xaisobj,
yaisobj,
seriesobj,
datalength,
dwval,
pmimgbool,
serieslabobj
) {
var option = {};
option['backgroundColor'] = {
type: 'radial',
x: 0.5,
y: 0.5,
r: 0.5,
colorStops: [
{
offset: 0,
color: '#0f2660',
},
{
offset: 1,
color: '#020712',
},
],
global: false,
};
option['title'] = {
text: titleobj[2] ? titleobj[2] : '统计分析图',
textStyle: { fontFamily: '宋体', fontWeight: 'bolder', color: titleobj[0], fontSize: titleobj[1] },
left: titleobj[5] ? titleobj[5] : 'center',
};
if (titleobj[3]) {
option.title.top = titleobj[3];
}
var gridarr = [];
for (var i = 0; i < gridobj.length; i++) {
gridarr.push({ top: gridobj[i][0], left: gridobj[i][1], right: gridobj[i][2], bottom: gridobj[i][3] });
}
option['grid'] = gridarr;
option['tooltip'] = { show: false };
var xaisarr = [];
for (var i = 0; i < xaisobj.length; i++) {
xaisarr.push({
type: 'value',
gridIndex: xaisobj[i][1],
axisLine: { show: false },
max: xaisobj[i][0],
splitLine: { show: false },
axisLabel: { show: false },
axisTick: { show: false },
});
}
option['xAxis'] = xaisarr;
serieslabobj = serieslabobj ? serieslabobj : [];
var yaisarr = [];
for (var i = 0; i < yaisobj.length; i++) {
yaisarr.push({
type: yaisobj[i][0],
offset: yaisobj[i][6],
splitLine: { show: false },
axisLine: { show: false },
axisLabel: {
show: true,
align: yaisobj[i][1],
padding: yaisobj[i][2],
textStyle: { color: yaisobj[i][4], fontSize: yaisobj[i][5] },
formatter: function (params, index) {
if (index == datalength - 1) {
return '{b|}' + '{name|' + params + '}';
} else {
return '{c|' + (datalength - index) + '}' + '{name|' + params + '}';
}
},
rich: {
b: {
backgroundColor: {
image:
'',
},
width: 29,
height: 29,
align: 'center',
},
c: {
color: '#FFFFFF',
width: 29,
height: 29,
align: 'center',
verticalAlign: 'center',
backgroundColor: {
image:
'',
},
fontSize: yaisobj[i][5],
},
name: { color: '#9FB9E3', fontSize: yaisobj[i][5], padding: yaisobj[i][3] },
},
},
axisTick: { show: false },
gridIndex: yaisobj[i][7] ? yaisobj[i][7] : 0,
position: yaisobj[i][8] ? yaisobj[i][8] : 'left',
});
yaisarr.push({
type: 'category',
gridIndex: yaisobj[i][7] ? yaisobj[i][7] : 0,
position: 'right',
axisTick: { show: false },
axisLine: { show: false },
axisLabel: {
show: true,
align: 'right',
fontSize: yaisobj[i][5],
formatter: function (params) {
return '{name|' + params + dwval + '}';
},
rich: { name: { color: '#9FB9E3', width: 100, fontSize: yaisobj[i][10], padding: yaisobj[i][9] } },
},
});
if (yaisobj[i][11] && yaisobj[i][11][0]) {
yaisarr.push({
type: 'category',
gridIndex: yaisobj[i][7] ? yaisobj[i][7] : 0,
position: 'right',
axisTick: { show: false },
axisLine: { show: false },
axisLabel: {
show: true,
align: 'right',
fontSize: yaisobj[i][5],
formatter: function (params) {
return '{name|' + params + dwval + '}';
},
rich: {
name: { color: '#9FB9E3', width: 100, fontSize: yaisobj[i][10], padding: yaisobj[i][11][1] },
},
},
});
}
}
option['yAxis'] = yaisarr;
var seriesarr = [];
for (var i = 0; i < seriesobj.length; i++) {
var objseriesv = {
name: seriesobj[i][0],
xAxisIndex: seriesobj[i][4],
yAxisIndex: seriesobj[i][5],
barGap: '220%',
barCategoryGap: '5%',
barWidth: seriesobj[i][1],
type: 'pictorialBar',
xAxisIndex: seriesobj[i][4],
yAxisIndex: seriesobj[i][5],
symbol: 'rect',
symbolMargin: seriesobj[i][6][0],
symbolSize: seriesobj[i][6][1],
symbolOffset: seriesobj[i][6][2],
symbolRepeat: true,
itemStyle: {
color: {
type: 'linear',
x: 0,
y: 0,
x2: 1,
y2: 0,
colorStops: [
{ offset: 0, color: seriesobj[i][2] },
{ offset: 1, color: seriesobj[i][3] },
],
global: false,
},
},
z: 2,
};
if (seriesobj[i][7] && seriesobj[i][7][0]) {
objseriesv['label'] = {
show: seriesobj[i][7][0],
position: 'left',
offset: serieslabobj[0] ? serieslabobj[0] : [-64, 0],
padding: serieslabobj[1] ? serieslabobj[1] : [0, 0, 0, 295],
borderWidth: 1,
borderColor: serieslabobj[2] ? serieslabobj[2] : '#1F2C83',
distance: serieslabobj[3] ? serieslabobj[3] : -370,
color: seriesobj[i][7][2] ? seriesobj[i][7][2] : '#9FB9E3',
fontSize: serieslabobj[4] ? serieslabobj[4] : 13,
formatter: seriesobj[i][7][1],
};
}
seriesarr.push(objseriesv);
}
option['series'] = seriesarr;
if (pmimgbool && option.yAxis.length >= 2) {
for (var j = 1; j < option.yAxis.length; j++) {
if (option.yAxis[j].position == 'left') {
option.yAxis[j].axisLabel.formatter = function (params, index) {
return '{name|' + params + '}';
};
}
}
}
return option;
}