五大商圈车场停车饱和度echarts 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配置项内容和展示

象形图编辑,右边固定顶部显示

配置项如下
      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);
}
    
截图如下