etestecharts pictorialBar配置项内容和展示

配置项如下
      var spiritEmpty =
    'image://';
var spiritBlue =
    'image://';
var spiritGreen =
    'image://';
var spiritYellow =
    'image://';
var spiritOringe =
    'image://';
var data = [891, 400, 1220, 1000, 660, 800, 1670, 1900];
var picArr = [spiritBlue, spiritBlue, spiritGreen, spiritGreen, spiritYellow, spiritYellow, spiritOringe, spiritOringe];

var color = [
    {
        type:'linear',
        colorStops:[
            {
                offset:0,
                color:'#5CC0FF'
            },
            {
                offset:1,
                color:'#5998FF'
            }
        ]
    },
    {
        type:'linear',
        colorStops:[
            {
                offset:0,
                color:'#48D69E'
            },
            {
                offset:1,
                color:'#70F3C2'
            }
        ]
    },
    {
        type:'linear',
        colorStops:[
            {
                offset:0,
                color:'#FFD18C'
            },
            {
                offset:1,
                color:'#FEAD5A'
            }
        ]
    },
    {
        type:'linear',
        colorStops:[
            {
                offset:0,
                color:'#FF977B'
            },
            {
                offset:1,
                color:'#FB6A66'
            }
        ]
    }
]


var yData = ['“双师型”教师比例','全国均值','具有研究生学位的专任教师比例','全国均值','学生体质健康达标率','全国均值','应届生初次就业率','全国均值']
var maxData = 2000;
var pictorialBarData = data.map((item, index) => {
    return {
        name:yData[index],
        value: item,
        symbol: picArr[index],
    };
});

option = {
    tooltip: {},
    xAxis: {
        show:false,
        max: maxData,
        splitLine: { show: false },
        offset: 10,
        axisLine: {
            lineStyle: {
                color: '#999',
            },
        },
        axisLabel: {
            margin: 10,
        },
    },
    yAxis: {
        show:false,
        data: data,
        inverse: true,
        axisTick: { show: false },
        axisLine: { show: false },
        axisLabel: {
            margin: 10,
            color: '#999',
            fontSize: 16,
        },
    },
    grid: {
        left:'2%',
        right:'10%',
        top:'5%',
        bottom:'4%',
        containLabel:true
    },
    series: [
        {
            // current data
            type: 'pictorialBar',
            // symbol: spirit,
            symbolRepeat: 'fixed',
            symbolMargin: '5%',
            symbolClip: true,
            symbolSize: [12, 20],
            symbolBoundingData: maxData,
            data: pictorialBarData,
            label:{
                show:true,
                formatter: item=>{
                    if(item.dataIndex % 2 == 0){
                        console.log(item.dataIndex/2)
                        return `{line${item.dataIndex/2}|}{pdr|}${item.name}`
                    }
                    return `{pdr|}${item.name}`
                    //item.name
                },
                position:'right',
                offset:[-200,-20],
                rich:{
                    line0:{
                        width:2,
                        height:12,
                        backgroundColor:color[0]
                    },
                    line1:{
                        width:2,
                        height:12,
                        backgroundColor:color[1]
                    },
                    line2:{
                        width:2,
                        height:12,
                        backgroundColor:color[2]
                    },
                    line3:{
                        width:2,
                        height:12,
                        backgroundColor:color[3]
                    },
                    pdr:{
                        width:5,
                        height:1
                    }
                }
            },
            z: 10,
        },
        {
            // full data
            type: 'pictorialBar',
            itemStyle: {
                normal: {
                    opacity: 0.2,
                },
            },
            label: {
                show: true,
                formatter: function (params) {
                    return ((params.value / maxData) * 100).toFixed(1) + ' %';
                },
                position: 'right',
                offset: [10, 0],
                color: 'green',
                fontSize: 18,
            },
            animationDuration: 0,
            symbolRepeat: 'fixed',
            symbolMargin: '5%',
            symbol: spiritEmpty,
            symbolSize: [12,20],
            symbolBoundingData: maxData,
            data: pictorialBarData,
            z: 5,
        },
    ],
};

    
截图如下