echerts横向一根柱子不同参数不同色的斜切式柱状图的做法

news2024/11/21 2:28:20

思路:网上搜寻了许久,最终参照官网的斜切样式制作出来了,这种方法采用的是遮盖原有柱状图顶端造成视觉上看起来是斜切的效果。目前这是我能想到最好的办法了,也欢迎大家提供其他的方法。

参照echerts图表网:

echarts图表集

效果图:

完整源代码:

<template>
  <!-- 横向柱状图 -->
  <div class="index" ref="lineStyle"></div>
</template>

<script>
export default {
  name: "index",
  components: {},
  props: {
    obj: {
      type: Object,
      default() {
        return {
          ydata: ["第一天", "第二天", "第三天"],
          legend: ["双床房", "大床房", "商务房"],
          barData: [
            {
              name: "双床房",
              data: [10, 5, 20]
            },
            {
              name: "大床房",
              data: [3, 6, 9]
            },
            {
              name: "商务房",
              data: [5, 4, 3]
            }
          ],
          legendDate: "center" //对齐方式
        };
      }
    },
    // 渐变色从深色到浅色
    colors: {
      type: Object,
      default() {
        return {
          colors: [
            { color1: "#0F949B", color2: "#1bf3fe" },
            { color1: "#1794FF", color2: "#79b2f8" },
            { color1: "#19C278", color2: "#90f9bb" }
          ]
        };
      }
    }
  },
  data() {
    return {
      serData: [],
      myChart1: ""
    };
  },
  computed: {},
  watch: {
    data: {
      handler() {
        this.$nextTick(() => {
          this.init();
        });
      },
      deep: true
    }
  },
  created() {},
  mounted() {
    this.init();
  },
  beforeDestroy() {},
  methods: {
    init() {
      // console.log(this.obj.legendDate);
      if (this.myChart1) this.myChart1.dispose();
      let ref = this.$refs.lineStyle;
      this.myChart1 = echarts.init(ref);

      let arr = []; //存储房间数数组
      let arrData = []; //大床房数据
      let list = []; //双床房数据
      let room = []; //存储房间数据

      this.obj.barData.forEach((item, i) => {
        // 计算房间总数
        arr.push(this.sum(item.data));
        room.push(item.name);

        this.serData.push(
          {
            name: item.name,
            type: "bar",
            stack: "all",
            // color: item.color, //柱状图颜色
            barWidth: 14,
            data: item.data,
            showBackground: true,
            backgroundStyle: {
              color: "#1344791a"
            }
          },
            //斜切效果设置
          {
            type: "pictorialBar",
            data: item.data.map((items, j) => {
              if (i > 0 && item.name == room[i]) {
                arrData.push(items + list[j]);
                if (item.name == "商务房") {
                  return items + arrData[j];
                }
                return items + list[j];
              } else {
                list.push(items);
                return items;
              }
            }),
            xAxisIndex: 0,
            yAxisIndex: 0,
            zlevel: 99,
            symbol:
              "image://",
            symbolRotate: 0,
            symbolSize: [15, 14],
            symbolPosition: "end",
            symbolOffset: [8, 0],
            itemStyle: {
              color: "#1280eb",
              shadowColor: "#1280eb",
              shadowBlur: 10
            },
            tooltip: {
              show: false
            }
          }
        );
        // });
      });
      //渐变色操作
      let colorList = []; //存储渐变完成后的颜色
      this.colors.colors.forEach(item => {
        colorList.push(
          new echarts.graphic.LinearGradient(0, 0, 1, 0, [
            { offset: 0, color: item.color1 },
            { offset: 1, color: item.color2 }
          ])
        );
      });

      const option = {
        // 颜色
        color: colorList, //存储颜色
        //图表选择栏
        legend: {
          top: "5%",
          left: this.obj.legendDate,
          orient: "horizontal", //图例方向【horizontal/vertical】
          itemHeight: 12, //修改icon图形大小
          itemWidth: 12, //修改icon图形大小
          selectedMode: false, //不允许点击图例
          itemGap: 30,
          textStyle: {
            fontSize: 14,
            color: "#fff"
          },
          data: this.obj.legend,
          tooltip: {
            show: false
          }
        },
        //图标离容器的距离
        grid: {
          left: "5%",
          right: "3%",
          bottom: "10%",
          top: "20%",
          //是否包含坐标轴
          containLabel: true
        },
        //x坐标轴
        xAxis: [
          {
            type: "value",
            axisTick: {
              show: false
            },
            splitLine: {
              show: true,
              lineStyle: {
                color: "rgba(255,255,255,.3"
              }
            },
            boundaryGap: true,
            axisLine: {
              show: true,
              lineStyle: {
                // 属性lineStyle控制线条样式
                color: "#476579c1",
                width: 1,
                type: "solid"
              }
            },
            axisLabel: {
              color: "#fff",
              fontSize: 14
            }
          }
        ],
        //y坐标轴
        yAxis: [
          {
            type: "category",
            name: "",
            data: this.obj.ydata,
            splitLine: {
              // show: false
            },
            inverse: true,
            axisTick: {
              show: false
            },
            axisLine: {
              // show: true,
              lineStyle: {
                // 属性lineStyle控制线条样式
                color: "#476579c1",
                width: 1,
                type: "solid"
              }
            },
            axisLabel: {
              textStyle: {
                color: "#fff",
                fontSize: 14
              }
            }
          }
        ],
        // 数据展示区域
        series: this.serData
      };
      // console.log(option);
      this.myChart1.setOption(option);
    },
    // 数组求和
    sum(arr) {
      return eval(arr.join("+"));
    }
  }
};
</script>

<style lang="less" scoped>
.index {
  width: 467px;
  height: 300px;
  // background-color: #13447900;
}
</style>

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1623967.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

数据结构四:线性表之带头结点的单向循环循环链表的设计

前面两篇介绍了线性表的顺序和链式存储结构&#xff0c;其中链式存储结构为单向链表&#xff08;即一个方向的有限长度、不循环的链表&#xff09;&#xff0c;对于单链表&#xff0c;由于每个节点只存储了向后的结点的地址&#xff0c;到了尾巴结点就停止了向后链的操作。也就…

2023平航杯——手机取证复现

手机最近连接的wifi"只有红茶可以吗"的密码是&#xff1f;【标准格式&#xff1a;ABCabc123!#】 手机上安装了某个运动软件&#xff0c;它的包名是&#xff1f;【标准格式&#xff1a;com.baidu.gpt】 com.dizhisoft.changdongli 该运动软件中最近一次运动记录的起点…

【产品经理修炼之道】- 如何从0到1搭建B端产品

随着数字化转型的不断深化,B端产品也面临着升级。本文总结分析了如何从0到1搭建B端产品,希望对你有所帮助。 背景 随着公司数字化转型的不断的推进和实施,数字化转型成功越来越明显的体现在财务报上,这也增强了管理层对数字转型的信心,在推进中我们也发现几年建设的系统的…

【继承和多态】

提示&#xff1a;文章写完后&#xff0c;目录可以自动生成&#xff0c;如何生成可参考右边的帮助文档 文章目录 前言一、pandas是什么&#xff1f;二、使用步骤 1.引入库2.读入数据总结 前言 提示&#xff1a;这里可以添加本文要记录的大概内容&#xff1a; 例如&#xff1a;…

ios微信小程序禁用下拉上拉

第一步&#xff1a; page.json配置页面的"navigationStyle":"custom"属性&#xff0c;禁止页面滑动 "navigationStyle":"custom" 第二步&#xff1a; 页面里面使用scroll-view包裹内容&#xff0c;内容可以内部滑动 <view class&…

Java中的 JDK环境变量配置详解

JDK安装后&#xff0c;接下我们来学习一个补充知识&#xff0c;叫做Path环境变量 什么是Path环境变量&#xff1f; Path环境变量是让系统程序的路径&#xff0c;方便程序员在命令行窗口的任意目录下启动程序&#xff1b; 如何配置环境变量呢&#xff1f; 比如把QQ的启动程序&a…

面试二十二、跳表SkipLists

跳表全称为跳跃列表&#xff0c;它允许快速查询&#xff0c;插入和删除一个有序连续元素的数据链表。跳跃列表的平均查找和插入时间复杂度都是O(logn)。快速查询是通过维护一个多层次的链表&#xff0c;且每一层链表中的元素是前一层链表元素的子集&#xff08;见右边的示意图&…

竞赛报名赛事管理系统技术分析

竞赛报名赛事管理系统是一个复杂的应用&#xff0c;涉及到用户管理、赛事信息管理、报名管理、成绩管理等多个方面。使用PHP框架来开发这样的系统&#xff0c;可以大大提高开发效率&#xff0c;保证代码的可维护性和可扩展性。以下是对基于PHP框架的竞赛报名赛事管理系统进行功…

【C++航海王:追寻罗杰的编程之路】C++11(二)

目录 C11(上) 1 -> STL中的一些变化 2 -> 右值引用和移动语义 2.1 -> 左值引用和右值引用 2.2 -> 左值引用与右值引用比较 2.3 -> 右值引用使用场景与意义 2.4 -> 右值引用引用左值及其更深入的使用场景分析 2.5 -> 完美转发 C11(上) 1 -> STL…

百面算法工程师 | 卷积基础知识——Convolution

目录 8.1 图像卷积过程 8.2 卷积层基本参数 8.3 卷积后图像的长和宽大小的计算方式 8.4 卷积神经网络中的权重共享 8.5 上采样中的反卷积 8.6 空洞卷积 8.7 深度可分离卷积 8.8 为什么可分离卷积中Depthwise卷积后还要进行pointwise卷积 8.9 分组卷积 Group Conv 8.1…

【A-024】基于SSH的房屋租赁管理系统(含论文)

【A-024】基于SSH的房屋租赁管理系统&#xff08;含论文&#xff09; 开发环境&#xff1a; Jdk7(8)Tomcat7(8)MySQLIntelliJ IDEA(Eclipse) 数据库&#xff1a; MySQL 技术&#xff1a; SpringStruts2HiberanteBootstrapJquery 适用于&#xff1a; 课程设计&#xff0c;毕…

账号安全及应用

一、账号安全控制 1.1系统账号清理 将用户设置为无法登陆 锁定账户 删除账户 设定账户密码&#xff0c;本质锁定 锁定配置文件-chattr&#xff1a; -a 让文件或目录仅供附加用途。只能追加 -i 不得任意更动文件或目录。 1.2密码安全控制 chage 1.3历史命令 history&am…

SSL证书安装失败怎么办?

在互联网时代&#xff0c;SSL&#xff08;Secure Sockets Layer&#xff09;证书已成为保障网站数据传输安全、提升用户信任度的重要工具。然而&#xff0c;在实际操作过程中&#xff0c;SSL证书的安装并非总能一帆风顺&#xff0c;有时会遇到各种导致安装失败的问题。本文将详…

轻松上手Python Schedule模块,实现高效定时任务

&#x1f340; 前言 博客地址&#xff1a; CSDN&#xff1a;https://blog.csdn.net/powerbiubiu &#x1f44b; 简介 Schedule是Python中的一个轻量级进程调度程序库&#xff0c;用于安排任务以指定的时间间隔定期运行 &#x1f4d6; 正文 1 Schedule的介绍 1.1 安装 pip…

详解MySQL C API 相关接口(大白话就是:MySQL的c语言怎么写)

文章目录 1、C API 官方文档2、初始化 MYSQL3、连接 MySQL设置连接字符集&#xff08;使得客户端编码方式匹配&#xff09; 4、下发 mysql 指令5、获取 mysql 查询结果(保存起来)获取行与列遍历存储结果 6、释放 MYSQL\_RES 对象7、关闭 MySQL 连接8、总结 1、C API 官方文档 …

CSS中的 5 类常见伪元素详解!

你好&#xff0c;我是云桃桃。 一个希望帮助更多朋友快速入门 WEB 前端的程序媛。 云桃桃-大专生&#xff0c;一枚程序媛&#xff0c;感谢关注。回复 “前端基础题”&#xff0c;可免费获得前端基础 100 题汇总&#xff0c;回复 “前端工具”&#xff0c;可获取 Web 开发工具合…

【运维自动化-配置平台】如何通过模板创建集群和模块

通过【每天掌握一个功能点】配置平台如何创建业务机拓扑&#xff08;集群-模块&#xff09;我们知道了直接创建集群和模块的操作方法&#xff0c;直接创建的方式适合各集群模块都相对独立的场景&#xff0c;那大量的、标准规范的集群模块如何快速创建呢&#xff0c;这里就引入了…

企业实施定制鞋厂ERP软件需要注意哪些问题?

企业实施定制鞋厂ERP软件是个复杂的管理系统工程&#xff0c;为了成功地为企业定制实施ERP软件&#xff0c;需要注意和解决几个关键的问题&#xff1a; . 确立ERP系统实施和定制的决策者&#xff1b;. 做好前期咨询与调研工作&#xff1b;. 做好系统产品或项目迭代规划&#x…

Linux安装Docker的多版本PHP和多版本MySQL共存

1: 先安装docker 安装完后执行,权限设置 sudo usermod -aG docker $USER或者sudo usermod -aG docker kentrl#添加当前用户到Docker用户组中 sudo newgrp docker#更新用户组数据,必须执行否则无效 sudo systemctl restart docker 先看目录结构: 2:按照目录结构挂载磁盘,…

ZDOCK linux 下载(无需安装)、配置、使用

ZDOCK 下载 使用 1. 下载1&#xff09;教育邮箱提交申请&#xff0c;会收到下载密码2&#xff09;选择相应的版本3&#xff09;解压 2. 使用方法Step 1&#xff1a;将pdb文件处理为ZDOCK可接受格式Step 2&#xff1a;DockingStep 3&#xff1a;创建所有预测结构 1. 下载 1&…