vue3之echarts3D圆柱
vue3之echarts3D圆柱
效果:

版本
"echarts": "^5.1.2"
核心代码:
<template><div ref="charts" class="charts"></div><svg><linearGradient id="labColor" x1="0" y1="0" x2="0" y2="1"><stop offset="21%" stop-color="#ffffff"></stop><stop offset="100%" stop-color="#7FFFFF"></stop></linearGradient></svg>
</template><script lang="ts" setup>
import { reactive, onMounted, ref, onBeforeUnmount } from 'vue';
import * as echarts from "echarts";const data: any = reactive({"list": [104,86,210,135,72,180,180],"xAxis": ["星期一","星期二","星期三","星期四","星期五","星期六","星期日"]
});
const charts = ref(null);
let myechart: any = null;
let timer: any = null;// 圆柱宽度
const barWidth = 40;const initChart = () => {if (charts.value && !myechart) {myechart = echarts.init(charts.value, '', { renderer: 'svg' });}const option = {tooltip: {show: false},xAxis: [{data: data.xAxis,axisTick: {show: false,},axisLine: {show: false,},axisLabel: {interval: 0,textStyle: {fontSize: 20,color: "#ffffff",fontFamily: "OPPOSans-R",},margin: 38, //刻度标签与轴线之间的距离。},}, {type: "category",axisLine: {show: false,},axisTick: {show: false,},axisLabel: {show: false,},splitArea: {show: false,},splitLine: {show: false,},data: data.xAxis,}],yAxis: {splitLine: {show: false,},axisTick: {show: false,},axisLine: {show: false,},axisLabel: {show: false,},},grid: {left: "5%",right: "5%",bottom: "0%",top: '10%',containLabel: true,},series: [{name: '顶部渐变文字',type: 'pictorialBar',symbol: 'rect',symbolRepeat: false,symbolSize: [0, 0],symbolOffset: [0, -10],z: 200,symbolPosition: 'end',data: data.list.map((item: any) => {return {value: item,label: {show: true,position: 'top',formatter: (item: any) => {return `${item.value}次`;},fontSize: 24,fontFamily: 'OPPOSans',// 使用svg渐变颜色color: 'url(#labColor)',},};}),},{name: "顶部圆形",type: "pictorialBar",symbolSize: [barWidth, 15],symbolOffset: [0, -5],symbolPosition: 'end',z: 12,itemStyle: {normal: {color: new echarts.graphic.LinearGradient(0, 0, 0, 1, [{offset: 0,color: "rgba(28, 135, 175, 0)",},{offset: 1,color: "rgba(28, 135, 175, 1)",},])}},data: data.list,},{name: "顶部圆环",type: "pictorialBar",symbolSize: [barWidth, 15],symbolOffset: [0, -5],symbolPosition: 'end',z: 100,itemStyle: {normal: {color: "transparent",borderColor: new echarts.graphic.LinearGradient(0, 0, 0, 1, [{offset: 0,color: "rgba(100, 207, 246, 0)",},{offset: 1,color: "rgba(100, 207, 246, 1)",},]),borderWidth: 1,},},data: data.list,},{name: "底部最小圆形",type: "pictorialBar",symbolSize: [barWidth, 15],symbolOffset: [0, 5],z: 12,itemStyle: {normal: {color: 'rgba(56, 132, 160, 1)',},},data: data.list,},{name: "底部最小圆环",type: "pictorialBar",symbolSize: [barWidth, 15],symbolOffset: [0, 5],z: 13,itemStyle: {normal: {color: "transparent",borderColor: new echarts.graphic.LinearGradient(0, 0, 0, 1, [{offset: 0,color: "rgba(15, 97, 127, 0)",},{offset: 1,color: "rgba(56, 132, 160, 1)",},]),borderWidth: 1,},},data: data.list,},{name: "底部第二层圆形",type: "pictorialBar",symbolSize: [barWidth + (barWidth / 2), 20],symbolOffset: [0, 12],z: 1,itemStyle: {normal: {color: "#3884A0",opacity: 0.45},},data: data.list,},{name: "底部最外层圆形",type: "pictorialBar",symbolSize: [barWidth * 2, 30],symbolOffset: [0, 20],z: 0,itemStyle: {normal: {color: "#3884A0",opacity: 0.2},},data: data.list,},{type: "bar",name: "最外层柱状渐变",itemStyle: {color: "transparent",borderWidth: 1,borderColor: new echarts.graphic.LinearGradient(0, 0, 0, 1, [{offset: 0,color: "rgba(96, 199, 237, 0)",},{offset: 1,color: "#3884A0",},]),},silent: true,barWidth,barGap: "-100%",data: data.list,},{type: "bar",name: "大的柱状图",z: 0,itemStyle: {normal: {color: new echarts.graphic.LinearGradient(0, 0, 0, 1, [{offset: 0,color: "rgba(15, 97, 127, 0)",},{offset: 1,color: "rgba(15, 97, 127, 1)",},]),},},silent: true,barWidth,barGap: "-100%",data: data.list,},{type: "bar",z: 100,name: "小的柱状图",xAxisIndex: 1,itemStyle: {normal: {color: new echarts.graphic.LinearGradient(0, 0, 0, 1, [{offset: 0,color: "rgba(15, 97, 127, 0)",},{offset: 0.85,color: "rgba(15, 97, 127, 1)",},{offset: 1,color: 'rgba(56, 132, 160, 1)'}]),opacity: 0.5,},},silent: true,barWidth: 10,barGap: "-100%",data: data.list.map((item: any) => item - item * 0.1),},],};myechart.setOption(option);
};onMounted(() => {initChart();
});onBeforeUnmount(() => {if (timer) {clearInterval(timer);timer = null;}if (myechart) {myechart.clear();myechart.dispose();myechart = null;}
});
</script>
<style scoped lang="scss">
.charts {width: 777px;height: 478px;background: url(@/assets/img/overview/coal-bg.png) no-repeat center bottom;
}
</style>相关文章:
vue3之echarts3D圆柱
vue3之echarts3D圆柱 效果: 版本 "echarts": "^5.1.2" 核心代码: <template><div ref"charts" class"charts"></div><svg><linearGradient id"labColor" x1"0&q…...
Redux中间件redux-thunk和redux-saga的具体区别是什么?
Redux 中间件是增强 Redux 功能的重要工具,redux-thunk 和 redux-saga 是两个常用的中间件,它们在处理异步操作和副作用时提供了不同的方式和理念。以下是两者的具体区别: 1. 概念与设计理念 redux-thunk 简洁:redux-thunk 是一…...
代码随想录算法训练营第四十三天| 动态规划06
322. 零钱兑换 如果求组合数就是外层for循环遍历物品,内层for遍历背包。 如果求排列数就是外层for遍历背包,内层for循环遍历物品。 这句话结合本题 大家要好好理解。 视频讲解:动态规划之完全背包,装满背包最少的物品件数是多少&…...
UI自动化教程 —— 元素定位技巧:精确找到你需要的页面元素
引言 在UI自动化测试中,准确地定位页面元素是至关重要的。无论是点击按钮、填写表单还是验证页面内容,都需要首先找到相应的页面元素。Playwright 提供了多种方法来实现这一点,包括使用CSS选择器和XPath进行元素定位,以及利用文本…...
MySQL六大日志的功能介绍。
前言 首先,MySQL的日志应该包括二进制日志(Binary Log)、错误日志(Error Log)、查询日志(General Query Log)、慢查询日志(Slow Query Log)、重做日志(Redo …...
二级指针略解【C语言】
以int** a为例 1.二级指针的声明 a 是一个指向 int*(指向整型的指针)的指针,即二级指针。 通俗的讲,a是一个指向指针的指针,对a解引用会是一个指针。 它可以用于操作动态分配的二维数组、指针数组或需要间接修改指针…...
鸿蒙状态管理概述
状态管理 状态管理之v1LocalStorageLocalStorageLink的框架行为LocalStorageProp的框架行为LocalStorage使用场景 AppStorageStorageLink的框架行为StorageProp的框架行为AppStorage的使用场景 PersistentStorageEnvironmentEnvironment内置参数 WatchWatch的使用场景 $$语法$$…...
【核心算法篇十三】《DeepSeek自监督学习:图像补全预训练方案》
引言:为什么自监督学习成为AI新宠? 在传统监督学习需要海量标注数据的困境下,自监督学习(Self-Supervised Learning)凭借无需人工标注的特性异军突起。想象一下,如果AI能像人类一样通过观察世界自我学习——这正是DeepSeek图像补全方案的技术哲学。根据,自监督学习通过…...
由浅入深学习大语言模型RLHF(PPO强化学习- v1浅浅的)
最近,随着DeepSeek的爆火,GRPO也走进了视野中。为了更好的学习GRPO,需要对PPO的强化学习有一个深入的理解,那么写一篇文章加深理解吧。纵观网上的文章,要么说PPO原理,各种复杂的公式看了就晕,要…...
网络安全三件套
一、在线安全的四个误解 Internet实际上是个有来有往的世界,你可以很轻松地连接到你喜爱的站点,而其他人,例如黑客也很方便地连接到你的机器。实际上,很多机器都因为自己很糟糕的在线安全设置无意间在机器和系统中留下了“…...
瑞芯微RV1126部署YOLOv8全流程:环境搭建、pt-onnx-rknn模型转换、C++推理代码、错误解决、优化、交叉编译第三方库
目录 1 环境搭建 2 交叉编译opencv 3 模型训练 4 模型转换 4.1 pt模型转onnx模型 4.2 onnx模型转rknn模型 4.2.1 安装rknn-toolkit 4.2.2 onn转成rknn模型 5 升级npu驱动 6 C++推理源码demo 6.1 原版demo 6.2 增加opencv读取图片的代码 7 交叉编译x264 ffmepg和op…...
【ISO 14229-1:2023 UDS诊断(会话控制0x10服务)测试用例CAPL代码全解析⑤】
ISO 14229-1:2023 UDS诊断【会话控制0x10服务】_TestCase05 作者:车端域控测试工程师 更新日期:2025年02月15日 关键词:UDS诊断、0x10服务、诊断会话控制、ECU测试、ISO 14229-1:2023 TC10-005测试用例 用例ID测试场景验证要点参考条款预期…...
python-leetcode 35.二叉树的中序遍历
给定一个二叉树的根节点root,返回它的中序遍历。 方法一:递归 二叉树的中序遍历:按照访问左子树——根节点——右子树的方式遍历这棵树,而在访问左子树或者右子树的时候我们按照同样的方式遍历,直到遍历完整棵树。因此整个遍历过…...
glob 用法技巧
目录 处理大量文件节省内存 匹配多个文件扩展名 遍历多种格式文件 遍历某一个文件: 查找当前目录和子目录 6. 排除特定文件 7. 大小写不敏感匹配 8. 获取绝对路径 9. 处理特殊字符 处理大量文件节省内存 技巧:用 iglob 替代 glob,逐…...
CodeGPT 使用教程(适用于 VSCode)
CodeGPT 使用教程(适用于 VSCode) CodeGPT 是一个 VSCode 插件,可以让你在代码编辑器中直接调用 GPT 进行代码补全、优化、调试等操作。以下是详细的安装和使用步骤: 1. 安装 CodeGPT 方式 1:从 VSCode 插件市场安装…...
以下是MySQL中常见的增删改查语句
以下是MySQL中常见的增删改查语句: 增加数据(INSERT) 基本语法: INSERT INTO table_name (column1, column2,...) VALUES (value1, value2,...); 示例:向名为 students 的表中插入一条学生记录, id 为1&am…...
Vue3 与 TypeScript 实战:核心细节与最佳实践
引言 Vue3 的 Composition API 与 TypeScript 的强类型支持完美契合,极大提升了代码的可维护性和开发体验。本文将深入探讨 Vue3 TypeScript 的关键细节,并通过实际代码示例展示如何高效结合二者。 一、组合式 API 与类型推导 Vue3 的 setup 函数与 T…...
23种设计模式 - 解释器模式
模式定义 解释器模式(Interpreter Pattern)是一种行为型设计模式,用于为特定语言(如数控系统的G代码)定义文法规则,并构建解释器来解析和执行该语言的语句。它通过将语法规则分解为多个类,实现…...
常用的 React Hooks 的介绍和示例
目录 1. useState2. useEffect3. useContext4. useReducer5. useCallback6. useMemo7. useRef8. useImperativeHandle9. useLayoutEffect10. useDebugValue 常用的 React Hooks 的介绍和示例: 1. useState useState 是一个用于在函数组件中添加状态的 Hook。 impo…...
ChatGLM-6B模型
ChatGLM-6B 是由 清华大学人工智能研究院(THU AI) 和 智源研究院(BAAI) 开发的一款中文对话生成大语言模型。它是ChatGLM系列的一个版本,其核心特点是基于GLM(General Language Model)架构&…...
Windows 10系统优化配置指南:开源工具的技术实现与应用
Windows 10系统优化配置指南:开源工具的技术实现与应用 【免费下载链接】Win10BloatRemover Configurable CLI tool to easily and aggressively debloat and tweak Windows 10 by removing preinstalled UWP apps, services and more. Originally based on the W10…...
别再死记硬背4R理论了!用小米、Target和电商的真实案例,手把手教你落地客户关系管理
4R理论实战手册:用小米、Target和电商案例解锁客户关系管理 记得去年双十一,一位做电商的朋友向我抱怨:"学了那么多营销理论,一到实战就抓瞎。"这让我想起第一次接触4R理论时的困惑——那些抽象的概念就像隔着一层毛玻璃…...
复分析入门避坑指南:Stein教材第一章的5个常见误解与正确理解姿势
复分析入门避坑指南:Stein教材第一章的5个常见误解与正确理解姿势 复分析作为数学领域的一颗明珠,其精妙的理论体系常常让初学者既兴奋又困惑。E.M. Stein与R. Shakarchi合著的《复分析》无疑是这一领域的经典教材,但第一章的基础概念往往成…...
从TAGE到TAGE-SC-L:一篇看懂现代CPU分支预测器的演进史
从TAGE到TAGE-SC-L:现代CPU分支预测器的技术进化论 在处理器设计的微观世界里,分支预测器如同一位隐形的指挥家,它的每一次判断都直接影响着指令流水线的演奏效率。当现代CPU的主频提升遭遇物理极限,架构师们将目光转向了如何让每…...
三步解锁百度文库:127行代码让你免费保存任何文档的终极指南
三步解锁百度文库:127行代码让你免费保存任何文档的终极指南 【免费下载链接】baidu-wenku fetch the document for free 项目地址: https://gitcode.com/gh_mirrors/ba/baidu-wenku 还在为百度文库的付费文档而烦恼吗?每次找到心仪的资料&#x…...
3大核心功能+5步实战:DLSS Swapper终极性能优化指南
3大核心功能5步实战:DLSS Swapper终极性能优化指南 【免费下载链接】dlss-swapper 项目地址: https://gitcode.com/GitHub_Trending/dl/dlss-swapper DLSS Swapper是一款革命性的游戏性能优化工具,它让普通玩家也能像专业调优师一样,…...
告别手动部署!用Docker Compose一键搞定若依Vue全家桶(Java/MySQL/Redis/Nginx)
容器化部署若依Vue全家桶:Docker Compose实战指南 在传统服务器部署中,开发者往往需要花费大量时间在环境配置、依赖安装和服务调优上。每次部署新环境,都要重复执行相同的步骤:安装JDK、配置MySQL、编译Redis、调整Nginx参数...这…...
别再死记硬背了!用Python+OpenCV手把手带你玩转YUV与RGB互转(附代码避坑)
PythonOpenCV实战:YUV与RGB互转全解析与避坑指南 在视频处理、计算机视觉和嵌入式开发中,YUV与RGB的格式转换是每个开发者迟早要面对的挑战。想象一下这样的场景:你从Android Camera2 API获取到NV21格式的YUV数据,需要在Python中转…...
Unity游戏去马赛克终极指南:5分钟掌握UniversalUnityDemosaics完整方案
Unity游戏去马赛克终极指南:5分钟掌握UniversalUnityDemosaics完整方案 【免费下载链接】UniversalUnityDemosaics A collection of universal demosaic BepInEx plugins for games made in Unity3D engine 项目地址: https://gitcode.com/gh_mirrors/un/Universa…...
XXMI启动器终极指南:如何一站式管理所有热门二次元游戏模组
XXMI启动器终极指南:如何一站式管理所有热门二次元游戏模组 【免费下载链接】XXMI-Launcher Modding platform for GI, HSR, WW and ZZZ 项目地址: https://gitcode.com/gh_mirrors/xx/XXMI-Launcher 还在为管理《原神》、《崩坏:星穹铁道》、《鸣…...
