堆叠象形柱图

描述:当前是关于Echarts图表中的 象形柱图 示例。
 
            var barData = [{
        name: "设备1",
        normal: 120,
        alarm: 40
    },
    {
        name: "设备2",
        normal: 180,
        alarm: 20
    },
    {
        name: "设备3",
        normal: 20,
        alarm: 150
    }
]
var blueBar =
    "";
var yellowBar =
    "";
var barname = [];
var sum = []
barData.forEach(el => {
    barname.push(el.name);
    sum.push(el.normal + el.alarm)
    el.sum = el.normal + el.alarm
});
var max = Math.max(...sum)
var bigMax = max
var normalData = []
var alarmData = []
barData.forEach((el, index) => {
    var symbolY = (el.sum / max).toFixed(2) * 100 + "%"
    var alarmValue = NaN
    normalData[index] = {
        name: el.name,
        value: el.normal,
        symbolSize: ["100%", symbolY]
    }
    if (el.alarm / el.sum < 0.1 && el.alarm !== 0) {

        alarmValue = parseInt(el.sum) * 1.2
        if (alarmValue > max) {
            bigMax = alarmValue
        }
    } else {
        alarmValue = el.sum
    }
    alarmData[index] = {
        name: el.name,
        value: alarmValue,
        symbolSize: ["100%", symbolY]
    }

})
option = {
    tooltip: {
        show: false
    },
    grid: {
        left: "2%",
        right: "2%",
        width: "98%",
    },
    xAxis: {
        data: barname,
        axisTick: {
            show: false
        },
        axisLine: {
            show: false
        },
        axisLabel: {
            textStyle: {
                color: "#fff"
            },
            margin: 20,
        }
    },
    yAxis: {
        splitLine: {
            show: false
        },
        axisTick: {
            show: false
        },
        axisLine: {
            show: false
        },
        axisLabel: {
            show: false
        }
    },
    series: [{
            name: "normal",
            type: "pictorialBar",
            barWidth: "115",
            silent: true,
            barGap: '-100%',
            label: {
                show: true,
                color: "#fff",
                position: 'insideBottom'
            },
            symbolBoundingData: bigMax,
            symbol: "image://" + blueBar,
            symbolClip: true,
            data: normalData,
            z: 9,
        },
        {

            name: "alarm",
            type: "pictorialBar",
            barWidth: "115",
            silent: true,
            label: {
                show: true,
                position: 'insideTop',
                formatter: (params) => {
                    return barData[params.dataIndex].alarm
                },

            },
            barCategoryGap: 200,
            symbolBoundingData: bigMax,
            symbol: "image://" + yellowBar,
            symbolClip: false,
            data: alarmData
        },
        {

            name: "alarm",
            type: "pictorialBar",
            barWidth: "115",
            silent: true,
            label: {
                show: true,
                position: 'top',
                color: "#fff",
                textBorderColor: "#2a87a1",
                textBorderWidth: 2,
                formatter: (params) => {
                    return barData[params.dataIndex].sum
                },

            },
            barCategoryGap: 200,
            symbolBoundingData: bigMax,
            symbol: "none",
            symbolClip: false,
            data: alarmData
        }
    ]
};