echarts-棱柱图,带背景图表,custom

我要冲啦个人网站建设2025-01-08web前端

var dataList = [

        {

            name: '第一季度',

            value: 73,

            max: 100,

            leftColors: [

                {

                    offset: 0,

                    color: 'rgba(88, 118, 230, 1)'

                },

                {

                    offset: 1,

                    color: 'rgba(73, 109, 244, 1)'

                }

            ],

            rightColors: [

                {

                    offset: 0,

                    color: 'rgba(15, 46, 163, 1)'

                },

                {

                    offset: 1,

                    color: 'rgba(49, 86, 220, 1)'

                }

            ],

            topColors: 'rgba(65, 103, 244, 1)',

            barColor: 'rgba(73, 109, 244, 0.4)'

        },

        {

            name: '第二季度', value: 18, max: 100,

            leftColors: [

                {

                    offset: 0,

                    color: 'rgba(238, 206, 110, 1)'

                },

                {

                    offset: 1,

                    color: 'rgba(213, 173, 49, 1)'

                }

            ],

            rightColors: [

                {

                    offset: 0,

                    color: 'rgba(157, 120, 11, 1)'

                },

                {

                    offset: 1,

                    color: 'rgba(189, 148, 23, 1)'

                }

            ],

            topColors: 'rgba(243, 196, 55, 1)',

            barColor: 'rgba(213, 173, 49, 0.4)'

        },

        {

            name: '第三季度', value: 43, max: 100,

            leftColors: [

                {

                    offset: 0,

                    color: 'rgba(23, 204, 117, 1)'

                },

                {

                    offset: 1,

                    color: 'rgba(8, 139, 76, 1)'

                }

            ],

            rightColors: [

                {

                    offset: 0,

                    color: 'rgba(3, 112, 59, 1)'

                },

                {

                    offset: 1,

                    color: 'rgba(5, 112, 60, 1)'

                }

            ],

            topColors: 'rgba(66, 244, 157, 1)',

            barColor: 'rgba(8, 139, 76, 0.4)'

        },

        {

            name: '第四季度', value: 28, max: 100,

            leftColors: [

                {

                    offset: 0,

                    color: 'rgba(38, 166, 218, 1)'

                },

                {

                    offset: 1,

                    color: 'rgba(28, 129, 175, 1)'

                }

            ],

            rightColors: [

                {

                    offset: 0,

                    color: 'rgba(5, 94, 153, 1)'

                },

                {

                    offset: 1,

                    color: 'rgba(16, 84, 113, 1)'

                }

            ],

            topColors: 'rgba(0, 231, 239, 1)',

            barColor: 'rgba(28, 129, 175, 0.4)'

        },

    ];

    var valueList = dataList.map(item => item.value);

    var maxList = dataList.map(item => item.max);

const CubeBack = echarts.graphic.extendShape({

        shape: {

            x: 0,

            y: 0

        },

        buildPath: function (ctx, shape) {

            const xAxisPoint = shape.xAxisPoint;

            const c0 = [shape.x + 20, shape.y - 5]; //右上

            const c1 = [shape.x - 20, shape.y - 5]; //左上

            const c4 = [shape.x, shape.y - 15]; //上中点

            const c2 = [xAxisPoint[0] - 20, xAxisPoint[1] - 5]; //左下

            const c5 = [xAxisPoint[0], xAxisPoint[1]]; //下中点

            const c3 = [xAxisPoint[0] + 20, xAxisPoint[1] - 5]; //右下

            ctx.moveTo(c0[0], c0[1])

                .lineTo(c4[0], c4[1])

                .lineTo(c1[0], c1[1])

                .lineTo(c2[0], c2[1])

                .lineTo(c5[0], c5[1])

                .lineTo(c3[0], c3[1])

                .closePath();

        }

    });

    const CubeLeft = echarts.graphic.extendShape({

        shape: {

            x: 0,

            y: 0

        },

        buildPath: function (ctx, shape) {

            const xAxisPoint = shape.xAxisPoint;

            const c0 = [shape.x, shape.y];

            const c1 = [shape.x - 20, shape.y - 7]; //左上角

            const c2 = [xAxisPoint[0] - 20, xAxisPoint[1] - 6]; //右上角

            const c3 = [xAxisPoint[0], xAxisPoint[1]];

            ctx.moveTo(c0[0], c0[1])

                .lineTo(c1[0], c1[1])

                .lineTo(c2[0], c2[1])

                .lineTo(c3[0], c3[1])

                .closePath();

        }

    });

    const CubeRight = echarts.graphic.extendShape({

        shape: {

            x: 0,

            y: 0

        },

        buildPath: function (ctx, shape) {

            const xAxisPoint = shape.xAxisPoint;

            const c1 = [shape.x, shape.y];

            const c2 = [xAxisPoint[0], xAxisPoint[1]];

            const c3 = [xAxisPoint[0] + 20, xAxisPoint[1] - 6]; //右下

            const c4 = [shape.x + 20, shape.y - 6];

            ctx.moveTo(c1[0], c1[1])

                .lineTo(c2[0], c2[1])

                .lineTo(c3[0], c3[1])

                .lineTo(c4[0], c4[1])

                .closePath();

        }

    });

    const CubeTop = echarts.graphic.extendShape({

        shape: {

            x: 0,

            y: 0

        },

        buildPath: function (ctx, shape) {

            const c1 = [shape.x, shape.y];

            const c2 = [shape.x + 20, shape.y - 7]; //右下  右

            const c3 = [shape.x, shape.y - 15]; //右上  上

            const c4 = [shape.x - 20, shape.y - 7];

            ctx.moveTo(c1[0], c1[1])

                .lineTo(c2[0], c2[1])

                .lineTo(c3[0], c3[1])

                .lineTo(c4[0], c4[1])

                .closePath();

        }

    });

    echarts.graphic.registerShape('CubeBack', CubeBack);

    echarts.graphic.registerShape('CubeLeft', CubeLeft);

    echarts.graphic.registerShape('CubeRight', CubeRight);

    echarts.graphic.registerShape('CubeTop', CubeTop);

    var imgUrl = [

        'image://',

        'image://',

        'image://',

        'image://',

    ];

option = {

   //你的代码

   backgroundColor: 'rgb(5, 33, 65)',

        grid: {

            bottom: '18%',

            top: '16%',

            right: '0%',

            left: '0%'

        },

        xAxis: {

            data: ['第一季度', '第二季度', '第三季度', '第四季度'],

            position: 'bottom',

            axisTick: {

                show: false

            },

            axisLine: {

                show: false

            },

            axisLabel: {

                show: true,

                textStyle: {

                    color: '#fff',

                    fontSize: 18,

                    fontweight: '500',

                    padding: [30, 0, 0, 0]

                },

                margin: 30 //刻度标签与轴线之间的距离。

            },

        },

        yAxis: {

            splitLine: {

                show: false

            },

            axisTick: {

                show: false

            },

            axisLine: {

                show: false

            },

            axisLabel: {

                show: false

            }

        },

        series: [

            {

                type: 'custom',

                tooltip: {

                    show: false

                },

                renderItem: (params, api) => {

                    const location = api.coord([api.value(0), api.value(1)]);

                    return {

                        type: 'group',

                        children: [

                            {

                                type: 'CubeLeft',

                                shape: {

                                    api,

                                    xValue: api.value(0),

                                    yValue: api.value(1),

                                    x: location[0],

                                    y: location[1],

                                    xAxisPoint: api.coord([api.value(0), 0])

                                },

                                style: {

                                    fill: new echarts.graphic.LinearGradient(0, 0, 0, 1, [

                                        {

                                            offset: 0,

                                            color: 'rgba(4, 51, 71, 1)'

                                        },

                                        {

                                            offset: 1,

                                            color: 'rgba(3, 82, 89, 0.6)'

                                        },

                                    ])

                                }

                            },

                            {

                                type: 'CubeRight',

                                shape: {

                                    api,

                                    xValue: api.value(0),

                                    yValue: api.value(1),

                                    x: location[0],

                                    y: location[1],

                                    xAxisPoint: api.coord([api.value(0), 0])

                                },

                                style: {

                                    fill: new echarts.graphic.LinearGradient(0, 0, 0, 1, [

                                        {

                                            offset: 0,

                                            color: 'rgba(4, 61, 66, 0.4)'

                                        },

                                        {

                                            offset: 1,

                                            color: 'rgba(1, 117, 127, 0.4)'

                                        },

                                    ])

                                }

                            },

                            {

                                type: 'CubeTop',

                                shape: {

                                    api,

                                    xValue: api.value(0),

                                    yValue: api.value(1),

                                    x: location[0],

                                    y: location[1],

                                    xAxisPoint: api.coord([api.value(0), 0])

                                },

                                style: {

                                    fill: 'rgba(24, 109, 117, 0.6)'

                                }

                            }

                        ]

                    };

                },

                data: maxList

            },

            {

                zlevel: 1,

                z: -1,

                color: '#3d98df',

                type: 'custom',

                name: '',

                renderItem: (params, api) => {

                    const location = api.coord([api.value(0), api.value(1)]);

                    return {

                        type: 'group',

                        children: [

                            {

                                type: 'CubeLeft',

                                shape: {

                                    api,

                                    xValue: api.value(0),

                                    yValue: api.value(1),

                                    x: location[0],

                                    y: location[1],

                                    xAxisPoint: api.coord([api.value(0), 0])

                                },

                                style: {

                                    fill: new echarts.graphic.LinearGradient(0, 0, 0, 1, dataList[params.dataIndexInside].leftColors)

                                }

                            },

                            {

                                type: 'CubeRight',

                                shape: {

                                    api,

                                    xValue: api.value(0),

                                    yValue: api.value(1),

                                    x: location[0],

                                    y: location[1],

                                    xAxisPoint: api.coord([api.value(0), 0])

                                },

                                style: {

                                    fill: new echarts.graphic.LinearGradient(0, 0, 0, 1, dataList[params.dataIndexInside].rightColors)

                                }

                            },

                            {

                                type: 'CubeTop',

                                shape: {

                                    api,

                                    xValue: api.value(0),

                                    yValue: api.value(1),

                                    x: location[0],

                                    y: location[1],

                                    xAxisPoint: api.coord([api.value(0), 0])

                                },

                                style: {

                                    fill: dataList[params.dataIndexInside].topColors

                                }

                            }

                        ]

                    };

                },

                data: valueList,

            },

            { // 放图片

                name: '',

                type: 'pictorialBar',

                z: 13,

                label: {

                    show: true,

                    position: [70, -60],

                    color: '#74D3FF',

                    formatter: function (params) {

                        return '{a|' + params.data.val + '} {b|%}'

                    },

                    rich: {

                        a: {

                            fontSize: 22,

                            verticalAlign: 'bottom',

                            fontWeight: 'bolder',

                        },

                        b: {

                            fontSize: 12,

                            verticalAlign: 'bottom',

                            fontWeight: 'bolder',

                        }

                    }

                },

                data: dataList.map((item, index) => {

                    return {

                        name: '',

                        value: item.max,

                        val: item.value,

                        symbol: imgUrl[index],

                        symbolPosition: 'start',

                        symbolOffset: [0, 40],

                        symbolSize: [168, 196],

                        color: 'red'

                    }

                }),

            },

        ]

};

 

文章关键词