echarts pictorialBar配置项内容和展示

配置项如下
      
let get_gradual_by_horizontal = (c1,c2) => {
    return new echarts.graphic.LinearGradient(0, 0, 1, 0, [
        {
            offset: 0,
            color: c1
        }, {
            offset: 1,
            color: c2
        }
    ])
}
let  get_arr_by_key = (data, k) => {
    let key = k || "value"
    if (data.length) {
        return data.map(item => {
            return item[key]
        })
    }
    return [];
}
let  get_symbol_data = (data) => {
    return data.map(item => {
        return {
            value: item.value,
            symbolPosition: 'end'
        }
    })
}
data = [{
        name: '尾随',
        value: 10,
        sum: 10,
        c1: 'rgba(212, 22, 22, .2)',
        c2: 'rgba(212, 22, 22, 1)'
    },
    {
        name: '反传',
        value: 15,
        sum: 10,
        c1: 'rgba(255, 126, 0, 0.2)',
        c2: 'rgba(255, 126, 0, 1)'
    },
    {
        name: '胁迫',
        value: 16,
        sum: 10,
        c1: 'rgba(255, 216, 0, 0.2)',
        c2: 'rgba(255, 216, 0, 1)'
    },
    {
        name: '多卡刷门',
        value: 12,
        sum: 10,
        c1: 'rgba(0, 147, 255, 0.2)',
        c2: 'rgba(0, 147, 255, 1)'
    },
    {
        name: '陪同卡',
        value: 8,
        sum: 10,
        c1: 'rgba(45, 254, 235, 0.2)',
        c2: 'rgba(45, 254, 235, 1)'
    }
]
option = {
    grid: {
        top: '5%',
        bottom: '5%',
        right: '0%',
        left: '15%',
        containLabel: true
    },
    xAxis: {
        show: false
    },
    yAxis: [{
        triggerEvent: true,
        show: true,
        inverse: true,
        data: get_arr_by_key(data, 'name'),
        axisLine: {
            show: false
        },
        splitLine: {
            show: false
        },
        axisTick: {
            show: false
        },
        axisLabel: {
            show: false,
            interval: 0,
            color: '#A5B8B9',
            align: 'left',
            margin: 80,
            fontSize: 13,
            formatter: function(value, index) {
                return '{title|' + value + '}'
            },
            rich: {
                title: {
                    width: 165
                }
            }
        },
    }, {
        triggerEvent: true,
        show: true,
        inverse: true,
        data: get_arr_by_key(data, 'name'),
        axisLine: {
            show: false
        },
        splitLine: {
            show: false
        },
        axisTick: {
            show: false
        },
        axisLabel: {
            interval: 0,
            shadowOffsetX: '-20px',
            color: '#A5B8B9',
            align: 'right',
            verticalAlign: 'center',
            lineHeight: 30,
            fontSize: 12,
            margin: 30,
            formatter: function(value, index) {
                return (data[index].value / data[index].sum) * 100
            },
        }
    }],
    series: [{
        name: 'XXX',
        type: 'pictorialBar',
        symbol: 'image://',
        symbolSize: [50, 50],
        symbolOffset: [25, 0],
        z: 12,
        data: get_symbol_data(data)
    }, 
    {
        name: '条',
        type: 'bar',
        showBackground: true,
        yAxisIndex: 0,
        barWidth: 7,
        data:  data.map((item)=>{
            let {c1,c2} = item
            return {
                value: item.value,
                itemStyle: {
                    color: get_gradual_by_horizontal(c1,c2)
                },
                label: {
                    color: '#A5B8B9',
                    show: true,
                    position: ['-40px', '0px'],
                    textStyle: {
                        fontSize: 12
                    },
                    formatter: function(a, b) {
                        return a.name
                    }
                }
                
            }
        }),
        label: {
            normal: {
                color: '#A5B8B9',
                show: true,
                position: ['-40px', '0px'],
                textStyle: {
                    fontSize: 12
                },
                formatter: function(a, b) {
                    return a.name
                }
            }
        }
    }
    ]
}

    
截图如下