公寓宿舍

描述:当前是关于Echarts图表中的 柱状图 示例。
 
            var pic = ''
var room = ''
var data = [{
    name: '干部宿舍楼',
    total: 120,
    use: 60,
    empty: 60,
}, {
    name: '公寓住房',
    total: 110,
    use: 40,
    empty: 70,
}]



// 计算总数
var total = 0;
var seriesOption = []
data.map((item, index) => {
    total+=item.total
    seriesOption.push({
        name: '柱背景',
        type: 'bar',
        xAxisIndex: index,
        yAxisIndex: index,
        data: [{

        }, {
            name: item.name,
            value: item.total,
            rate: (item.use / item.total).toFixed(2) * 100 + '%',
        }],
        barWidth: 16,
        itemStyle: {
            normal: {
                barBorderRadius: 8,
                color: '#DFEEFF'
            }
        },
        label: {
            show: true,
            position: 'insideRight',
            formatter: params => {
                return `{pb|使用率:${params.data.rate}}`
            },
            rich: {
                pb: {
                    color: '#4B96F3',
                    padding: [0, 0, -30, 0]
                }
            }
        }
    })
    seriesOption.push({
        value: item.use,
        max: item.total,
        name: item.name,
        zlevel: 2,
        type: 'bar',
        yAxisIndex: index,
        xAxisIndex: index,
        data: [{

        }, {
            value: item.use,
            use:item.use,
            empty:item.empty,
            total:item.total
        }],
        label:{
            show:true,
            color:'transparent',
            position:'insideLeft',
            formatter:params=>{
                console.log(params)
                return `{pb|}\n{imgIcon|}  {normalText|房间:${params.data.total}间}
                \n\n{circleYellow|●}  {normalText|使用:${params.data.use}间}
                \n\n{circleGreen|●}  {normalText|空闲:${params.data.empty}间}`
            },
            rich:{
                circleYellow:{
                    color:'#FFA83E',
                    width:16,
                    height:16,
                    fontSize:20,
                    lineHeight:20,
                    padding:[0,0,0,4]
                },
                pb:{
                    padding:[0,0,200,0]  
                },
                circleGreen:{
                    color:'#36C78B',
                    fontSize:20,
                    width:16,
                    height:16,
                    lineHeight:20,
                    padding:[0,0,0,4]
                },
                imgIcon:{
                    backgroundColor:{
                        image:room,
                    },
                    width:20,
                    height:20,
                },
                normalText:{
                    fontSize:15,
                    height:20,
                    textVeticalAlign:'middle',
                    color:'#666666'
                }
            }
        },
        rate: item.total === 0 ? 0 : (item.use / item.total).toFixed() * 100 + '%',
        barGap: '-100%',
        barWidth: 16,
        itemStyle: {
            normal: {
                barBorderRadius: 8,
                color: '#4B96F3'
            }
        }

    })
})
option = {
    graphic: {
        elements: [{
            type: 'image',
            left: 'center',
            top: 25,
            style: {
                image: pic,
                width: 136,
                height: 136,
                textAlign: 'center'
            }
        }, {
            type: 'text',
            left: 'center',
            top: 180,
            style: {
                text: '房间总数',
                fill: '#333333',
                fontSize:16,
            }
        }, {
            type: 'rect',
            left: 'center',
            top: 200,
            textVeticalAlign:'middle',
            shape:{
                width:80,
                height:36,
            },
            style: {
                color:'#FFFFFF',
                fontSize:20,
                fontWeight:'bold',
                text:total,
                fill: '#4B96F3',
            }
        }]
    },
    grid: [{
        left: '5%',
        top: '5%',
        width: '30%',
        bottom: '5%',
        containLabel: true,
    }, {
        left: '35%',
        top: '5%',
        width: '30%',
        bottom: '5%',
        containLabel: true,
    }, {
        left: '65%',
        top: '5%',
        width: '30%',
        bottom: '5%',
        containLabel: true,
    }],
    yAxis: [{
        type: 'category',
        data: ['', '干部宿舍楼'],
        gridIndex: 0,
        axisLabel: {
            inside: true,
            padding: [0, 0, 48, 0],
            color: '#333333',
            fontWeight: 'bold'
        },
        axisTick: {
            show: false,
        },
        axisLine: {
            show: false,
        }
    }, {
        type: 'category',
        data: ['', '公寓住房'],
        gridIndex: 2,
        axisLabel: {
            inside: true,
            padding: [0, 0, 48, 0],
            color: '#333333',
            fontWeight: 'bold'
        },
        axisTick: {
            show: false,
        },
        axisLine: {
            show: false,
        }
    }],
    xAxis: [{
        type: 'value',
        gridIndex: 0,
        max: data[0].total,
        show: false,
    }, {
        type: 'value',
        gridIndex: 2,
        max: data[1].total,
        show: false,
    }],
    series: [...seriesOption]
}