当前位置: 首页 > news >正文

Vue + CSS实现渐变栅格进度条

进度条作为可视化大屏系统中展示数据状态的关键元素,其视觉效果直接影响用户的使用体验,而传统的进度条往往呈现出固定的样式,缺乏视觉吸引力。在这种场景下,一种基于Vue和CSS实现渐变栅格进度条的方法应运而生,该方法将进度条划分为多个栅格单元,每个单元格颜色渐变并且连续,可以根据不同的场景配置个性化属性,具有极高的灵活度和交互性,可以调整颜色、栅格数量、间隔、宽度、高度、圆角、数值、标签、刻度等属性,并同时具有平滑的过渡效果,特别适用于可视化大屏系统中。

1 原理

1.1 划分栅格单元

首先定义一个父容器,用于容纳所有栅格,然而栅格的数量不定,所以需要设置弹性布局,使得任意数量的栅格能够自动均匀平铺。样式合适位置预留响应式变量,保证属性的可配置性。

与此同时,给每个栅格加上平滑的过渡动画,确保每次数据发生变化引起图表变化时能够平滑过渡,而并非跳跃式突变,增强了用户的交互体验和视觉感受,同时能够引导用户注意力,突出变化部分的重要内容或功能。如下图。
在这里插入图片描述

1.2 颜色渐变

为了解决渐变栅格百分比条中栅格之间存在空隙而颜色可以连续的问题,需要利用CSS的两个重要属性:background属性和伪元素。

首先,将每个栅格的背景色设置相同。接着,调整background的size为栅格数量倍的宽度,调整position来指定背景的位置,将每个栅格的背景色都在上一个栅格的基础上,偏移一个栅格的距离。为了实现这一效果,还需将栅格设置为溢出隐藏,并确保背景色不重复,如下图。
在这里插入图片描述

由于进度条分为已完成和未完成两部分,而上述过程仅实现了所有栅格的连续渐变,无法突显出进度,所以需要控制渐变色在指定位置结束。然而,目前的方案似乎无法实现渐变色截断的效果,因此我们尝试使用遮罩。具体而言,就是将每个栅格都增加一个伪元素,将其完全覆盖在栅格上,根据计算的比例,已完成部分的伪元素背景色设置为透明,将渐变色显示出来,未完成部分的则设置为默认背景色,将下方的渐变色进行遮罩。

伪元素可以通过CSS自定义属性进行变量的绑定,在字符串前加上两根连接线“–”,可以将该字符串声明为CSS自定义属性,然后通过var()函数读取变量,最后使用Vue的动态style和模板字符串传入,这样,这个动态属性便可以根据数据的变化动态的渲染伪元素了。如下图。
在这里插入图片描述

1.3 标签与刻度

为了最大程度上不影响原有栅格进度条的层级结构,标签与刻度这种附加属性我们选择了绝对定位。新建一个盒子,保持与栅格的父容器宽度相同,添加进度开始值、结束值作为左右刻度,结合当前值可以计算出进度的百分比,同时根据栅格间距和当前值等属性可以计算出标签的位置。如下图。
在这里插入图片描述

2 实现方法

有了前面的思路铺垫,现在来着手实现。

2.1 可配置属性

首先我们需要配置用户可自定义修改的属性,并给予默认值,这些属性通过绑定响应式变量的方式来实现实时刷新。

最小值、最大值即进度条最左侧和最右侧的位置,默认为0和2,当前值即进度所在的位置,默认为1.66。

栅格数量指的是总共划分多少个栅格,数量不同,每个栅格所代表的比例也将发生改变,默认为10。

栅格间距是每个栅格之间空余的距离,单位为百分比,默认为2%。

渐变色是从起始颜色到终止颜色的色彩变化,形成一种流畅的过渡效果,增强视觉吸引力,默认为#6AE5BB到#3C7DDF的过渡。

背景色则可以认为是进度未完成的部分,默认使用颜色#AAAAAA作为区分。

数值的展示方式分为真实值和百分比值两种,切换后标签和刻度随之改变,其字体、字号、颜色、小数点也可自定义。

此外,栅格的圆角、高度、标签的偏移及其显隐等属性也在相应位置插入了变量提供给用户自定义修改。

2.2 数据初始化

在页面加载之前,需要进行数据的初始化,提前计算部分属性。

通过最小值、最大值、当前值计算出当前值所占比例(valuePercent),默认比例为(1.66-0)/(2-0)*100%=83%。

通过栅格的个数计算每个栅格代表的比例(perGridPercent),默认每个栅格代表100%/10=10%。

通过valuePercent和perGridPercent得到完整显示渐变色的栅格个数(completeGridNum)。Math.floor(83%/10%)=8,也就意味着前8个栅格的伪元素遮罩层的背景色,可以直接设置透明。

而余下的一个不足以完整显示渐变色的栅格,我们需要计算渐变色的部分占整个栅格的比例(remainingGridPercent)。用completeGridNum乘以perGridPercent,得到完整显示的比例,再用valuePercent减去完整显示的比例,得到剩余需要覆盖的部分,最后除以perGridPercent,即(83%-8*10%)/10%=30%,也就是说,余下的渐变色只需占据一个栅格的30%。

通过栅格间隔(interval)和栅格数量(number)得到每个栅格的实际宽度(perGridWidth),即用100%减去interval乘以number-1,得到所有栅格的实际宽度,随后除以number,interval默认为2%,(100%-2%*(10-1))/10=8.2%。Vue的计算属性可以根据依赖关系进行计算并缓存,所以我们可以用computed来计算栅格的实际宽度,由于栅格的间隔和数量都是响应式变量,所以宽度也是响应式的。

通过(completeGridNum+ remainingGridPercent)perGridWidth+completeGridNuminterval,不难算出标签绝对定位下距离左端的位置,即(8+30%)8.2%+82%=84.06%。

2.3 开始绘制

通过Vue的v-for指令,得到指定数量的栅格。通过:style=“`–barWidth:${perGridWidth}`”,将实际宽度传入组件内部,然后使用该值给栅格和伪元素遮罩的宽度赋值,具体为"width:var(–barWidth)"。

接下来,利用CSS从左至右的线性渐变色,均匀的平铺到所有的栅格上,即 “background:linear-gradient(to right,${beginColor},${overColor}) ${(i-1)perGridWidth}/${number100}% no-repeat”。这里的beginColor,overColor为渐变起始和终止颜色,i为栅格的序号。每个栅格的背景色都为扩展了number倍的渐变色,不同的则是各自的偏移量,都偏移了(i-1)*perGridWidth。

然后就是添加遮罩层,通过computed计算属性,可以根据i值大小,动态返回背景色的字符串。当小于等于completeGridNum时,返回透明色;当等于completeGridNum+1时,通过线性渐变,按百分比分配透明色和背景色,即`linear-gradient(to right,transparent r e m a i n i n g G r i d P e r c e n t , {remainingGridPercent}, remainingGridPercent,{backColor} ${remainingGridPercent})`,其中backColor为栅格背景色,意味着从左侧开始,直到达到remainingGridPercent指定的位置时,颜色保持透明色。在remainingGridPercent位置之后,颜色保持为背景色;其他情况下返回背景色。

最后,为栅格和其伪元素遮罩添加"transition: all 1s"的过渡动画。

核心代码

<div class="grid-progress-container"><divclass="grid-progress-bar"v-for="i in state.mergedConfig.bar.number":style="`--barRadius:${state.mergedConfig.bar.radius}px;--barHeight:${state.mergedConfig.bar.height}px;--barWidth:${perGridWidth}%;--barBackground:${renderBack(i)};background:linear-gradient(to right,${state.mergedConfig.bar.preColor},${state.mergedConfig.bar.suffixColor}) ${(i - 1) * perGridWidth}% / ${state.mergedConfig.bar.number * 100 + '%'} no-repeat;`"></div>
</div>const initData = () => {// 当前值所占比例(100%)state.valuePercent =((state.mergedConfig.dataset.value - state.mergedConfig.dataset.min) /(state.mergedConfig.dataset.max - state.mergedConfig.dataset.min)) *100// 每一个栅格比例(100%)state.perGridPercent = 100 / state.mergedConfig.bar.number// 完整渲染的栅格个数state.renderGridNum = Math.floor(state.valuePercent / state.perGridPercent)// 不完整渲染的栅格剩余比例(1)state.remainingGridPercent = (state.valuePercent - state.renderGridNum * state.perGridPercent) / state.perGridPercent
}const perGridWidth = computed(() => {return (100 - state.mergedConfig.bar.interval * (state.mergedConfig.bar.number - 1)) / state.mergedConfig.bar.number
})const renderBack = (i: number) => {if (state.remainingGridPercent === 0) {if (i <= state.renderGridNum) return 'transparent'else return `${state.mergedConfig.bar.backColor}`} else {if (i <= state.renderGridNum) {return 'transparent'} else if (i === state.renderGridNum + 1) {return `linear-gradient(to right,transparent ${state.remainingGridPercent * 100}%,${state.mergedConfig.bar.backColor} ${state.remainingGridPercent * 100}%)`} else {return `${state.mergedConfig.bar.backColor}`}}
}
.grid-progress-container {width: 100%;padding: 60px;display: flex;justify-content: space-between;.grid-progress-bar {height: var(--barHeight);width: var(--barWidth);border-radius: var(--barRadius);transition: all 1s;position: relative;&::before {position: absolute;content: '';height: 100%;width: 100%;background: var(--barBackground);border-radius: var(--barRadius);transition: all 1s;}}}

相关文章:

Vue + CSS实现渐变栅格进度条

进度条作为可视化大屏系统中展示数据状态的关键元素&#xff0c;其视觉效果直接影响用户的使用体验&#xff0c;而传统的进度条往往呈现出固定的样式&#xff0c;缺乏视觉吸引力。在这种场景下&#xff0c;一种基于Vue和CSS实现渐变栅格进度条的方法应运而生&#xff0c;该方法…...

算法模型从入门到起飞系列——背包问题(探索最大价值的掘金之旅)

文章目录 前言一、背包问题溯源&#xff08;动态规划&#xff09;1.1 动态规划的概念1.2 动态规划的基本步骤1.3 动态规划的实际应用 二、背包问题2.1 背包问题衍生2.2 0-1背包2.2.1 0-1背包描述2.2.2 0-1背包图解2.2.3 0-1背包代码刨析 2.3 完全背包2.3.1 完全背包描述2.3.2 完…...

蓝桥杯—迷宫(bfs)

一.题目 分析:最短路径问题&#xff0c;给定一个迷宫&#xff0c;从左上角走到右下角&#xff0c;要求路径最短&#xff0c;并且要求字典序最小&#xff0c;也就是按照D&#xff0c;L&#xff0c;R&#xff0c;U&#xff0c;的搜索顺序去搜索&#xff0c;否则路径不是唯一的&am…...

【Android】安卓 Java下载ZIP文件并解压(笔记)

写在前面的话 在这篇文章中&#xff0c;我们将详细讲解如何在 Android 中通过 Java 下载 ZIP 文件并解压&#xff0c;同时处理下载进度、错误处理以及优化方案。 以下正文 1.权限配置 在 AndroidManifest.xml 中&#xff0c;我们需要添加相应的权限来确保应用能够访问网络和设…...

清晰易懂的 PHP 安装与配置教程

初学者也能看懂的 PHP 安装与配置教程 本教程将手把手教你如何在 Windows 系统上安装 PHP&#xff0c;并配置 Composer&#xff08;PHP 的依赖管理工具&#xff09;的缓存位置&#xff0c;即使你是零基础小白&#xff0c;也能轻松完成&#xff01; 一、准备工作 操作系统&…...

Ceph集群2025(Squid版)快速对接K8S cephFS文件存储

ceph的块存储太简单了。所以不做演示 查看集群 创建一个 CephFS 文件系统 # ceph fs volume create cephfs01 需要创建一个子卷# ceph fs subvolume create cephfs01 my-subvol -----------------#以下全部自动创建好 # ceph fs ls name: cephfs01, metadata pool: c…...

Linux进程控制(四)之进程程序替换

文章目录 进程程序替换单进程版程序替换替换原理多进程版程序替换替换函数函数解释小知识 命名理解 进程程序替换 如果要让子进程执行与父进程完全不同的代码&#xff0c;就要进行进程程序替换。 单进程版程序替换 执行一个可执行文件 makefile mycommand:mycommand.cgcc -…...

python-selenium 爬虫 由易到难

本质 python第三方库 selenium 空值 浏览器驱动 浏览器驱动控制浏览器 推荐 edge 浏览器驱动&#xff08;不容易遇到版本或者兼容性的问题&#xff09; 驱动下载网址&#xff1a;链接: link 1、实战1 &#xff08;1&#xff09;安装 selenium 库 pip install selenium&#…...

希尔排序

希尔排序是一种改进的插入排序算法&#xff0c;它通过将原始数据分成多个子序列来改善插入排序的性能&#xff0c;每个子序列的元素间隔为 d&#xff08;增量&#xff09;。随着算法的进行&#xff0c;d 逐渐减小&#xff0c;最终减为 1&#xff0c;此时整个序列就被排序好了。…...

Pydantic Mixin:构建可组合的验证系统体系

title: Pydantic Mixin:构建可组合的验证系统体系 date: 2025/3/22 updated: 2025/3/22 author: cmdragon excerpt: Pydantic的Mixin模式通过继承组合实现校验逻辑复用,遵循以Mixin后缀命名、不定义初始化方法等设计原则。支持基础校验模块化封装与多策略组合,如电话号码…...

策略模式 vs. 工厂模式:对比与分析

相同点 解耦思想 两者都通过接口/抽象类将实现与调用方解耦&#xff0c;降低模块间的直接依赖。 符合开闭原则 新增策略或产品时&#xff0c;只需扩展新类&#xff0c;无需修改已有代码。 封装变化 策略模式封装算法的变化&#xff0c;工厂模式封装对象创建的变化。 不同…...

RK3568 I2C底层驱动详解

前提须知&#xff1a;I2C协议不懂的话就去看之前的内容吧&#xff0c;这个文章需要读者一定的基础。 RK3568 I2C 简介 RK3568 支持 6 个独立 I2C: I2C0、I2C1、I2C2、I2C3、I2C4、I2C5。I2C 控制器支持以下特性: ① 兼容 i2c 总线 ② AMBA APB 从接口 ③ 支持 I2C 总线主模式…...

【大语言模型_8】vllm启动的模型通过fastapi封装增加api-key验证

背景&#xff1a; vllm推理框架启动模型不具备api-key验证。需借助fastapi可以实现该功能 代码实现&#xff1a; rom fastapi import FastAPI, Header, HTTPException, Request,Response import httpx import logging# 创建 FastAPI 应用 app FastAPI() logging.basicConfig(…...

hadoop-HDFS操作

1. 使用的是hadoop的用户登录到系统&#xff0c;那么 cd ~ 是跳转到/home/hadoop下。 2. 在操作hdfs时&#xff0c;需要在hadoop用户下的/usr/local/hadoop&#xff0c;此时是在根目录下。 cd /usr/local/hadoop或者cd / cd usr/local/hadoop 3. 回到Linux的操作目录 我们把…...

Mysql 安装教程和Workbench的安装教程以及workbench的菜单栏汉化

Mysql 安装教程和Workbench的安装教程 详细请参考我的文件 Mysql 安装教程和Workbench的安装教程 或者下载我的资源Mysql 安装教程和Workbench的安装教程 汉化菜单 英文版菜单文件&#xff1a;下载链接 汉化版菜单文件&#xff1a;下载链接 默认情况下&#xff0c;安…...

失物招领|校园失物招领系统|基于Springboot的校园失物招领系统设计与实现(源码+数据库+文档)

校园失物招领系统目录 目录 基于Springboot的校园失物招领系统设计与实现 一、前言 二、系统功能设计 三、系统实现 1、 管理员功能实现 (1) 失物招领管理 (2) 寻物启事管理 (3) 公告管理 (4) 公告类型管理 2、用户功能实现 (1) 失物招领 (2) 寻物启事 (3) 公告 …...

一条不太简单的TEX学习之路

目录 rule raisebox \includegraphics newenviro 、\vspace \stretch \setlength 解释&#xff1a; 总结&#xff1a; 、\linespread newcommand \par 小四 \small simple 、mutiput画网格 解释&#xff1a; 图案解释&#xff1a; xetex pdelatex etc index 报…...

如何为AI开发选择合适的服务器?

选择适合的服务器可以为您的AI项目带来更高的效率&#xff0c;确保最佳性能、可扩展性和可靠性&#xff0c;从而实现无缝的开发与部署。 选择适合的AI开发服务器可能并不容易。您需要一台能够处理大量计算和大型数据集的服务器&#xff0c;同时它还需要符合您的预算并易于管理…...

doris:审计日志

Doris 提供了对于数据库操作的审计能力&#xff0c;可以记录用户对数据库的登陆、查询、修改操作。在 Doris 中&#xff0c;可以直接通过内置系统表查询审计日志&#xff0c;也可以直接查看 Doris 的审计日志文件。 开启审计日志​ 通过全局变量 enable_audit_plugin 可以随时…...

CSS中的transition与渐变

目录 一、CSS transition 1. 核心属性 简写语法 2. 子属性详解 2.1 transition-property 2.2 transition-duration 2.3 transition-timing-function 2.4 transition-delay 3. 使用场景示例 3.1 悬停效果&#xff08;Hover&#xff09; 3.2 展开/收起动画 3.3 动态移…...

AI + 医疗 Qwq大模型离线本地应用

通义千问Qwq-32b-FP16可用于社区医院、乡镇卫生院、诊所等小型医疗机构&#xff0c;替代专业合理用药系统&#xff0c;作为药品知识库&#xff0c;实现以下功能&#xff1a; 药品信息智能查询&#xff1a;检索药品的详细说明书、适应症、禁忌症、不良反应及药物相互作用等关键信…...

大数据环境搭建

目录 一&#xff1a;虚拟机:VirtualBox 二&#xff1a;Shell工具:MobaXterm 三&#xff1a;安装脚本 四&#xff1a;JDK和Hadoop 4.1&#xff1a;安装 4.2&#xff1a;启动 4.3&#xff1a;Hadoop可视化访问 4.4&#xff1a;关机 一&#xff1a;虚拟机:VirtualBox Virt…...

七天免登录 为什么不能用seesion,客户端的http请求自动携带cookei的机制(比较重要)涉及HTTP规范

如果是七天免登录,和session肯定没关系,因为session不能持久化,主要是客户端一旦关闭,seesion就失效了/// 所以必须是能持久化的&#xff0c;这就清晰了&#xff0c;要莫在的服务器保存&#xff0c;要摸在客户端设置 cook机制 1. 使用Cookie实现七天免登录 前端&#xff08;登…...

从PGC到AIGC:海螺AI多模态内容生成系统的技术革命

一、内容生产的范式迁移&#xff1a;从PGC到AIGC的进化之路 在数字内容生产的历史长河中&#xff0c;人类经历了三次重大范式转变&#xff1a;专业生成内容&#xff08;PGC&#xff09;的工业化生产、用户生成内容&#xff08;UGC&#xff09;的全民创作浪潮&#xff0c;以及当…...

常考计算机操作系统面试习题(三上)

目录 1. 为何要引入与设备的无关性&#xff1f;如何实现设备的独立性&#xff1f; 2. 页面置换先进先出算法 3. 页面置换先进先出算法&#xff0c;4个页框 4. 进程优先级调度算法 5. 短作业优先调度策略 6. 平均内存访问时间计算 7. 页式存储和段式存储的物理地址计算 …...

数据结构之双向链表-初始化链表-头插法-遍历链表-获取尾部结点-尾插法-指定位置插入-删除节点-释放链表——完整代码

数据结构之双向链表-初始化链表-头插法-遍历链表-获取尾部结点-尾插法-指定位置插入-删除节点-释放链表——完整代码 #include <stdio.h> #include <stdlib.h>typedef int ElemType;typedef struct node{ElemType data;struct node *next, *prev; }Node;//初化链表…...

一键部署 GPU Kind 集群,体验 vLLM 极速推理

随着 Kubernetes 在大模型训练和推理领域的广泛应用&#xff0c;越来越多的开发者需要在本地环境中搭建支持 GPU 的 Kubernetes 集群&#xff0c;以便进行测试和开发。大家都知道&#xff0c;本地搭建 Kubernetes 集群通常可以使用 Kind&#xff08;Kubernetes IN Docker&#…...

C/C++蓝桥杯算法真题打卡(Day6)

一、P8615 [蓝桥杯 2014 国 C] 拼接平方数 - 洛谷 方法一&#xff1a;算法代码&#xff08;字符串分割法&#xff09; #include<bits/stdc.h> // 包含标准库中的所有头文件&#xff0c;方便编程 using namespace std; // 使用标准命名空间&#xff0c;避免每次调用…...

【C++】入门

1.命名空间 1.1 namespace的价值 在C/C中&#xff0c;变量&#xff0c;函数和后面要学到的类都是大量存在的&#xff0c;这些变量&#xff0c;函数和类的名称将存在于全局作用域中&#xff0c;可能会导致很多冲突。使用命名空间的目的是对标识符的名称进行本地化&#xff0c;…...

CUDA 学习(2)——CUDA 介绍

GeForce 256 是英伟达 1999 年开发的第一个 GPU&#xff0c;最初用作显示器上渲染高端图形&#xff0c;只用于像素计算。 在早期&#xff0c;OpenGL 和 DirectX 等图形 API 是与 GPU 唯一的交互方式。后来&#xff0c;人们意识到 GPU 除了用于渲染图形图像外&#xff0c;还可以…...

构建自定义MCP天气服务器:集成Claude for Desktop与实时天气数据

构建自定义MCP天气服务器:集成Claude for Desktop与实时天气数据 概述 本文将指导开发者构建一个MCP(Model Control Protocol)天气服务器,通过暴露get-alerts和get-forecast工具,为Claude for Desktop等客户端提供实时天气数据支持。该方案解决了传统LLM无法直接获取天气…...

[Lc_2 二叉树dfs] 布尔二叉树的值 | 根节点到叶节点数字之和 | 二叉树剪枝

目录 1.计算布尔二叉树的值 题解 2.求根节点到叶节点数字之和 3. 二叉树剪枝 题解 1.计算布尔二叉树的值 链接&#xff1a;2331. 计算布尔二叉树的值 给你一棵 完整二叉树 的根&#xff0c;这棵树有以下特征&#xff1a; 叶子节点 要么值为 0 要么值为 1 &#xff0c;其…...

搜广推校招面经五十六

字节推荐算法 一、Attention的复杂度是多少&#xff1f; 见【搜广推校招面经三十八】 二、如何对普适性强的物品&#xff08;如新华字典&#xff09;设计指标进行降权 2.1. 问题背景 普适性强的物品&#xff08;如新华字典&#xff09;在推荐系统或搜索排序中可能频繁出现…...

ZYNQ的cache原理与一致性操作

在Xilinx Zynq SoC中&#xff0c;Cache管理是确保处理器与外部设备&#xff08;如FPGA逻辑、DMA控制器&#xff09;之间数据一致性的关键。Zynq的ARM Cortex-A9处理器包含L1 Cache&#xff08;指令/数据&#xff09;和L2 Cache&#xff0c;其刷新&#xff08;Flush/Invalidate&…...

安装React开发者工具

我们在说组件之前&#xff0c;需要先安装一下React官方推出的开发者工具&#xff0c;首先我们分享在线安装方式 首先打开谷歌网上应用商店(针对谷歌浏览器)&#xff0c;在输入框内搜索react&#xff0c;安装如下插件&#xff1a; 注意安装提供方为Facebook的插件&#xff0c;这…...

多层感知机

多层感知机&#xff08;Multilayer Perceptron&#xff0c;简称 MLP&#xff09;是一种基于前馈神经网络&#xff08;Feedforward Neural Network&#xff09;的深度学习模型&#xff0c;由多个神经元层组成&#xff0c;每一层与前一层全连接。它包括至少一个隐藏层&#xff08…...

2025年渗透测试面试题总结- PingCAP安全工程师(题目+回答)

网络安全领域各种资源&#xff0c;学习文档&#xff0c;以及工具分享、前沿信息分享、POC、EXP分享。不定期分享各种好玩的项目及好用的工具&#xff0c;欢迎关注。 目录 PingCAP安全工程师 一、SQL注入判断数据库类型技术分析 1. 常规判断方法 2. 盲注场景下的判断 3. 补…...

CAD模型导入Geant4

CADMesh是一个开源项目&#xff0c;专门用于将STL格式的CAD模型导入Geant4。以下是使用CADMesh操作STL模型的步骤&#xff1a; 准备工作 下载CADMesh开源代码&#xff1a;可以从GitHub或Gitee下载CADMesh的开源代码。 将CAD模型转换为STL格式&#xff1a;在CAD软件中创建几何…...

DeepSORT 目标追踪算法详解

DeepSORT&#xff08;Deep Simple Online and Realtime Tracking&#xff09;是 多目标追踪&#xff08;MOT&#xff09; 领域的经典算法&#xff0c;通过结合目标检测、运动预测和外观特征匹配&#xff0c;实现了高效、稳定的实时追踪。其核心思想是通过 检测驱动追踪&#xf…...

mne溯源后的数据初步处理方法

文章目录 导入库 Yeo2011_7Networks_N1000绘制一些圆球来代表区域大小和强度 单网络绘制和扩展的方式AI补充一下背景知识&#x1f4da; **背景与研究来源**&#x1f9e0; **7 个功能网络的定义**&#x1f4c2; **标签数据获取**&#x1f50d; **标签文件内容解析**&#x1f6e0…...

基于STM32进行FFT滤波并计算插值DA输出

文章目录 一、前言背景二、项目构思1. 确定FFT点数、采样率、采样点数2. 双缓存设计 三、代码实现1. STM32CubeMX配置和HAL库初始化2. 核心代码 四、效果展示和后话五、项目联想与扩展1. 倍频2. 降频3. 插值3.1 线性插值3.2 样条插值 一、前言背景 STM32 对 AD 采样信号进行快…...

【用 Trace读源码】PlanAgent 执行流程

前提条件 在 Trae 中打开 OpenManus 工程&#xff0c;使用 build 模式&#xff0c;模型选择 claude-sonnet-3.7 提示词 分析 agent/planning.py 中 main 方法及相关类的执行流程&#xff0c;以流程图的方式展示PlanningAgent 执行流程图 以下流程图展示了 PlanningAgent 类…...

AI代码编辑器:Cursor和Trae

Cursor 定义&#xff1a;Cursor 是一款基于AI的代码编辑器&#xff0c;它继承了VS Code的核心功能&#xff0c;并在此基础上增加了深度AI支持。它支持代码生成、优化、重构以及调试等功能&#xff0c;提供直观的Diff视图和自动补全功能&#xff0c;是一款功能强大的编程工具。…...

LSM-Tree(Log-Structured Merge-Tree)详解

1. 什么是 LSM-Tree? LSM-Tree(Log-Structured Merge-Tree)是一种 针对写优化的存储结构,广泛用于 NoSQL 数据库(如 LevelDB、RocksDB、HBase、Cassandra)等系统。 它的核心思想是: 写入时只追加写(Append-Only),将数据先写入内存缓冲区(MemTable)。内存数据满后…...

介绍一个测试boostrap表格插件的好网站!

最近在开发一个物业管理系统。用到bootstrap的表格插件bootstrap table&#xff0c;官方地址&#xff1a; https://bootstrap-table.com/ 因为是英文界面&#xff0c;对国人不是很友好。后来发现了IT小书童网站 IT小书童 - 为程序员提供优质教程和文档 网站&#xff1a; IT…...

虚拟路由与单页应用(SPA):详解

在单页应用&#xff08;SPA&#xff0c;Single Page Application&#xff09;中&#xff0c;虚拟路由&#xff08;也称为前端路由&#xff09;是一种关键的技术&#xff0c;用于管理页面导航和状态变化&#xff0c;而无需重新加载整个页面。为了帮助你更好地理解这一概念&#…...

基于树莓派3B+的人脸识别实践:Python与C联合开发

基于树莓派3B的人脸识别实践&#xff1a;Python与C联合开发 引言 树莓派因其小巧的体积和丰富的扩展性&#xff0c;成为嵌入式开发的理想平台。本文将分享如何通过Python与C语言联合开发&#xff0c;在树莓派3B上实现从硬件控制、摄像头拍照到百度API人脸比对的完整流程。项目…...

尝试使用Tauri2+Django+React项目(2)

前言 尝试使用tauri2DjangoReact的项目-CSDN博客https://blog.csdn.net/qq_63401240/article/details/146403103在前面笔者不知道怎么做&#xff0c;搞了半天 笔者看到官网&#xff0c;原来可以使用二进制文件&#xff0c;好好好 嵌入外部二进制文件 | Taurihttps://v2.taur…...

Qt桌面客户端跨平台开发实例

在Windows平台上&#xff0c;桌面客户端软件通常使用C/C语言和Qt跨平台开发框架进行开发。因此&#xff0c;大部分代码可以运行于不同平台环境&#xff0c;但是程序运行依赖的三方库以及代码中一些平台相关的头文件和接口需要进行平台兼容。本文以windows桌面端应用迁移到Linux…...

c++进阶之------红黑树

一、概念 红黑树&#xff08;Red-Black Tree&#xff09;是一种自平衡二叉查找树&#xff0c;它在计算机科学的许多领域中都有广泛应用&#xff0c;比如Java中的TreeMap和C中的set/map等数据结构的底层实现。红黑树通过在每个节点上增加一个颜色属性&#xff08;红色或黑色&am…...