象形图编辑,右边固定顶部显示
配置项如下
const fontColor = "#e5f1ff";
const colorArray = ['#1573ac', '#2595d3', '#f2c621', '#f09718', '#eb6712'];
const titleTextStyle = {
"color": fontColor,
'fontFamily': 'Microsoft YaHei',
'fontWeight': 'normal',
'fontSize': 16
};
let cheOrange = "image://";
let cheBackground = 'image://';
let cheYellow = 'image://';
let cheGreen = 'image://';
option = {
backgroundColor: '#2c343c',
"title": {
"text": "五大商圈车场停车饱和度",
"left": "center",
"y": "23",
"textStyle": titleTextStyle
},
"grid": {
"left": "17%",
"top": "22%",
'right': "22%",
"bottom": 26
},
"tooltip": {
"trigger": "item",
"textStyle": {
"fontSize": 14
},
"formatter": "{b0}:{c0}"
},
"xAxis": {
"max": 300,
"splitLine": {
"show": false
},
"axisLine": {
"show": false
},
"axisLabel": {
"show": false
},
"axisTick": {
"show": false
}
},
"yAxis": [{
"type": "category",
"inverse": false,
"data": [
"小寨商圈",
"小寨商圈",
"小寨商圈",
"小寨商圈",
"小寨商圈",
],
"axisLine": {
"show": false
},
"axisTick": {
"show": false
},
"axisLabel": {
"margin": -10,
"textStyle": {
"color": fontColor,
"fontSize": 14
}
}
}
/* {
show: true,
inverse: true,
data: [683, 234, 234, 523, 345],
axisLabel: {
"margin": 30,
textStyle: {
fontSize: 14,
color: '#fff',
},
},
axisLine: {
show: false
},
splitLine: {
show: false
},
axisTick: {
show: false
},
}*/
],
"series": [{
"type": "pictorialBar",
"symbol": cheOrange,
//"symbol": "image://",
"symbolRepeat": "fixed",
"symbolMargin": "13%",
"symbolClip": true,
"symbolSize": [13, 25],
"symbolPosition": "start",
"symbolOffset": [
20,
0
],
"symbolBoundingData": 300,
"data": [
13,
42,
67,
81,
{
"symbol": cheYellow,
'value': 22
}
],
"z": 10
},
{
"type": "pictorialBar",
"itemStyle": {
"normal": {
// "opacity": 0.3
}
},
"label": {
"normal": {
show: true,
formatter: function(params) {
return (params.value / 300 * 100).toFixed(1) + ' %';
},
position: 'right',
offset: [5, 0],
// margin: 30,
textStyle: {
fontSize: 14,
color: fontColor
},
}
},
"animationDuration": 0,
"symbolRepeat": "fixed",
"symbolMargin": "13%",
"symbol": cheBackground,
"symbolSize": [13, 25],
"symbolBoundingData": 300,
"symbolPosition": "start",
"symbolOffset": [
20,
0
],
"data": [
13,
42,
67,
81,
86,
],
"z": 5
}
]
}
const maxData = 300;
setInterval(function() {
let dynamicData = [random(), random(), random(), random(), random()];
let mock = dynamicData.slice();
let data = [],
bgData = [],
textData = [];
/*{
"symbol": '',
'value':''
};*/
/*50= - 80= 黄色
* 50以下 绿色
* 80以上 红色
* (params.value / 300 * 100).toFixed(1) + ' %';
* */
let s = 0;
for (let i in mock) {
s = (mock[i] / maxData * 100).toFixed(1);
if (s >= 50 && s <= 80) {
data.push({
value: mock[i],
symbol: cheYellow
});
textData.push({
value: mock[i],
textStyle: {
color: 'Yellow'
}
});
} else if (s < 50) {
data.push({
value: mock[i],
symbol: cheGreen
});
textData.push({
value: mock[i],
textStyle: {
color: 'Green'
}
});
} else if (s > 80) {
data.push({
value: mock[i],
symbol: cheOrange
});
textData.push({
value: mock[i],
textStyle: {
color: 'Orange'
}
});
}
bgData.push(mock[i]);
}
myChart.setOption({
/* yAxis:[{},{data:textData.reverse()}],*/
series: [{
data: data
}, {
data: bgData
}]
})
}, 3000);
function random() {
return +(Math.random() * (maxData - 10)).toFixed(1);
}