echarts横向立体3D柱状图

实现原理:series中包含两个普通的柱状图bar,其宽度各占一半且设置间距barGap为0,再添加一个象形柱状图pictorialBar,symbol设为菱形diamond,调整其位置大小层级等数据以达到覆盖在柱状图顶部的立体效果。

运行效果


代码

javascript 复制代码
function getEcharts3DBar () {
    let yAxisData = ['标题1', '标题2', '标题3', '标题4', '标题5', '标题6'];
    let seriesData = [5, 36, 10, 20, 15, 25];
    var barWidth = 30, constData = [], showData = [];
    seriesData.forEach(item => {
      if (item) {
          constData.push(1);
          showData.push(item);
      } else {
          constData.push(0);
          showData.push(
           {
              value: 1,
              itemStyle: {
                normal: {
                  borderColor: "rgba(0,0,0,0)",
                  borderWidth: 2,
                  color: "rgba(0,0,0,0)",
                },
              },
           }
          );
      }
    });
    return {
        xAxis: {
            type: 'value',
            splitLine: {
              lineStyle: {
                color: '#3AA8E2'
              }
            }
        },
        yAxis: {
            type: 'category',
            data: yAxisData,
            axisLine: { show: false },
            axisTick: { show: false }
        },
        series: [
            {
	            name: '数据',
	            type: "bar",
	            barWidth: barWidth / 2,
	            barGap: "0%",
	            data: seriesData,
	            color: '#57F1FF',
	            label: {
	              show: true,
	              position: 'right',
	              offset: [barWidth / 3, barWidth / 3]
	            }
            },
            {
	            name: '数据',
	            type: "bar",
	            barWidth: barWidth / 2,
	            data: seriesData,
	            color: '#0090B4',
            },
            {
	            z: 3,
	            name: '数据',
	            type: "pictorialBar",
	            symbolPosition: "end",
	            data: showData,
	            symbol: "diamond",
	            symbolOffset: ["50%", "0%"],
	            symbolSize: [barWidth / 2, barWidth],
	            color: '#017592'
            },
        ],
    };
}
option = getEcharts3DBar();
相关推荐
小二·44 分钟前
Python Web 开发进阶实战 :AI 原生数字孪生 —— 在 Flask + Three.js 中构建物理世界实时仿真与优化平台
前端·人工智能·python
Whisper_Sy1 小时前
Flutter for OpenHarmony移动数据使用监管助手App实战 - 网络状态实现
android·java·开发语言·javascript·网络·flutter·php
新缸中之脑2 小时前
Weave.js:开源实时白板库
开发语言·javascript·开源
Amumu121382 小时前
Vue组件化编程
前端·javascript·vue.js
We་ct2 小时前
LeetCode 6. Z 字形变换:两种解法深度解析与优化
前端·算法·leetcode·typescript
小二·3 小时前
Python Web 开发进阶实战(终章):从单体应用到 AI 原生生态 —— 45 篇技术演进全景与未来开发者生存指南
前端·人工智能·python
m0_637256583 小时前
vue-baidu-map添加了类型组件导致非常卡顿的问题
前端·javascript·vue.js
雨季6663 小时前
基于设备特征的响应式 UI 构建:Flutter for OpenHarmony 中的智能布局实践
javascript·flutter·ui
挂机且五杀3 小时前
为什么在React地图组件里,memo 不是优化,而是生存?
前端·react.js·前端框架
RFCEO3 小时前
HTML编程 课程七、:HTML5 新增表单标签与属性
前端·html·html5·搜索框·手机号·邮箱验证·日期选择