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

使用HTML5 Canvas 实现呼吸粒子球动画效果的原理

在网页开发领域,动画效果能够极大地提升用户体验,让页面变得更加生动有趣。今天,我们深入剖析一个基于 HTML5 Canvas 的 3D 粒子动画 —— 呼吸粒子球。通过详细解读其代码实现,我们将全面了解如何运用 HTML5 的强大功能构建出如此迷人的视觉效果。
效果展示:

用 HTML5 Canvas 和 JavaScript 实现粒子恒星脉动特效

1,整体架构

整个呼吸粒子球效果是 HTML、CSS 和 JavaScript 协同工作的成果。HTML 搭建基础页面结构,CSS 负责样式与背景设置,而 JavaScript 则实现核心动画逻辑。

1.1,HTML结构

<!DOCTYPE html>
<html>
<head><title>呼吸粒子球</title><style>body {margin: 0;overflow: hidden;background: radial-gradient(circle at center, #1a1a2e 0%, #16213e 50%, #0f172a 100%);}canvas {display: block;}</style>
</head>
<body><canvas id="canvas"></canvas><script>// 动画相关的JavaScript代码</script>
</body>
</html>

在 HTML 部分,我们创建了一个canvas元素,它是动画的绘制区域。通过 CSS 设置页面背景为径向渐变,营造深邃空间感,同时将canvas设为块级元素并使其充满整个页面,保证动画能全屏展示。

1.2,JavaScript初始化

const canvas = document.getElementById('canvas');
const ctx = canvas.getContext('2d');// 设置canvas尺寸为全屏
canvas.width = window.innerWidth;
canvas.height = window.innerHeight;

JavaScript 代码首先获取canvas元素,通过getContext(‘2d’)获取 2D 绘图上下文。然后将canvas尺寸设置为当前窗口的宽高,确保动画全屏显示。

2、粒子类的实现

粒子是构成呼吸粒子球的基本元素,通过定义Particle类来管理每个粒子的属性和行为。

2.1,粒子属性初始化

class Particle {constructor() {this.x = 0;this.y = 0;this.z = 0;this.radius = Math.random() * 1.2 + 0.3;this.theta = Math.random() * Math.PI * 2;this.phi = Math.acos((Math.random() * 2) - 1);this.baseR = 200;this.speed = Math.random() * 0.001 + 0.0005;// 根据深度设置颜色this.baseColor = {r: Math.random() * 100 + 155,g: Math.random() * 100 + 155,b: 255};}

在Particle类的构造函数中:

  • x、y、z表示粒子在三维空间中的位置,初始值为 0 ,后续会在动画过程中更新。
  • radius是粒子半径,通过Math.random()函数生成一个随机小数,再乘以 1.2 并加上 0.3,这样粒子半径范围在 0.3 到
    1.5 之间,使得粒子大小呈现多样化。
  • theta和phi是将三维空间点转换为笛卡尔坐标的角度值。theta通过Math.random()生成一个 0(包括)到 2 *
    Math.PI(不包括)之间的随机数,决定粒子在水平方向上的旋转角度;phi通过Math.acos((Math.random() * 2)- 1)生成,Math.random()生成 0(包括)到 1(不包括)之间的随机数,乘以 2 再减 1 得到 - 1(包括)到 1(不包括)之间的值,然后通过Math.acos函数得到 0(包括)到Math.PI(不包括)之间的角度,决定粒子在垂直方向上的角度,确保粒子在球面上均匀分布。
  • baseR是粒子围绕的基准半径,值为 200,用于控制粒子整体分布范围,所有粒子大致围绕这个半径形成一个球体。
  • speed是粒子旋转速度,通过Math.random()生成随机小数,乘以 0.001 再加上 0.0005,速度范围在 0.0005 到
    0.0015 之间,使粒子运动速度有差异。
  • baseColor是粒子基础颜色,红色和绿色分量通过Math.random()生成随机数,范围在 155 到 255 之间,蓝色分量固定为
    255,从而创建出不同蓝色调的粒子。

2.2,粒子位置更新

update(breathe) {this.theta += this.speed;const r = this.baseR * (1 + breathe * 0.2);this.x = r * Math.sin(this.phi) * Math.cos(this.theta);this.y = r * Math.sin(this.phi) * Math.sin(this.theta);this.z = r * Math.cos(this.phi);
}

update方法用于更新粒子位置。breathe参数控制粒子球呼吸效果,它是通过Math.sin函数生成的在 -1 到 1 之间波动的值。随着时间推移,theta不断增加(增加量为this.speed),使粒子围绕球体中心旋转。r的值根据breathe调整,breathe为正时,r增大,粒子向外扩张;breathe为负时,r减小,粒子向内收缩,实现粒子球缩放效果。最后通过三角函数将极坐标转换为笛卡尔坐标,更新粒子的x、y、z位置。

2.3,粒子绘制

draw() {// 增强透视效果const perspective = 800;const scale = perspective / (perspective + this.z);const x2d = canvas.width/2 + this.x * scale;const y2d = canvas.height/2 + this.y * scale;// 根据深度调整颜色和大小const depth = (this.z + this.baseR) / (this.baseR * 2);const alpha = 0.8 + (depth * 0.2);const radiusScale = this.radius * scale * (0.8 + depth * 0.4);// 计算深度相关的颜色const depthFactor = 0.3 + depth * 0.7;const color = {r: this.baseColor.r * depthFactor,g: this.baseColor.g * depthFactor,b: this.baseColor.b * depthFactor};ctx.beginPath();ctx.arc(x2d, y2d, radiusScale, 0, Math.PI * 2);ctx.fillStyle = `rgba(${color.r}, ${color.g}, ${color.b}, ${alpha})`;ctx.fill();// 为前景粒子添加发光效果if (depth > 0.8) {ctx.shadowBlur = 5;ctx.shadowColor = `rgba(${color.r}, ${color.g}, ${color.b}, 0.5)`;} else {ctx.shadowBlur = 0;}
}

draw方法负责将粒子绘制到canvas上。首先,通过透视变换公式计算粒子在 2D 画布上的位置x2d和y2d。这里perspective值设为 800,它模拟人眼到屏幕的距离,scale通过perspective / (perspective + this.z)计算得出,z值越大(粒子越远),scale越小,实现近大远小的透视效果。x2d和y2d通过画布中心坐标加上this.x和this.y乘以scale得到,确定粒子在画布上的实际绘制位置。
然后,根据粒子深度depth调整粒子透明度alpha、半径缩放radiusScale以及颜色。depth通过(this.z + this.baseR) / (this.baseR * 2)计算,范围在 0 到 1 之间,越接近 1 表示粒子越靠近观察者。alpha从 0.8 开始,随着depth增加而增大,使远处粒子更透明;radiusScale不仅考虑了scale,还根据depth进一步缩放,让近处粒子更大;depthFactor用于调整颜色,使近处粒子颜色更鲜艳。
最后,使用ctx.arc方法绘制粒子,并根据depth判断是否为粒子添加发光效果。当depth > 0.8时,为粒子添加模糊半径为 5、颜色为当前粒子颜色半透明的阴影,增强视觉层次感。

3、动画循环与管理

3.1,粒子数组创建与初始化

const particles = [];
const particleCount = 1500;
for(let i = 0; i < particleCount; i++) {particles.push(new Particle());
}

这里创建了一个包含 1500 个粒子的数组particles,通过循环实例化每个粒子并添加到数组中,这些粒子将共同构成呼吸粒子球。

3.2,动画循环函数

let time = 0;
function animate() {// 使用渐变背景增强深度感ctx.fillStyle = 'rgba(0, 0, 0, 0.3)';ctx.fillRect(0, 0, canvas.width, canvas.height);// 按照z轴深度排序粒子particles.sort((a, b) => b.z - a.z);const breathe = Math.sin(time * 0.01);// 更新和绘制所有粒子particles.forEach(particle => {particle.update(breathe);particle.draw();});time++;requestAnimationFrame(animate);
}animate();

animate函数是动画的核心循环。每次循环:

  • 首先使用ctx.fillRect方法填充一个半透明黑色背景(rgba(0, 0, 0,
    0.3)),模拟深度感并清除上一帧绘制内容,为新的一帧绘制做准备。
  • 然后对粒子数组按z轴深度排序,particles.sort((a, b) => b.z -
    a.z)确保距离观察者近的粒子在上面绘制,实现正确遮挡效果,符合现实中物体的遮挡逻辑。
  • 通过Math.sin(time * 0.01)计算breathe的值,time每次循环自增 1,time *0.01作为Math.sin函数的参数,使breathe的值在 -1 到 1 之间周期性变化,控制粒子球呼吸节奏。
  • 遍历粒子数组,依次调用每个粒子的update和draw方法,更新粒子位置并绘制到画布上,让每个粒子都能按照设定的逻辑进行运动和显示。
  • 最后,time自增,并使用requestAnimationFrame方法请求浏览器在下一次重绘前调用animate函数,该方法会根据浏览器的刷新频率来优化动画性能,实现流畅动画效果,通常浏览器刷新频率为60Hz,即每秒 60 帧。

3.3,窗口大小响应

window.addEventListener('resize', () => {canvas.width = window.innerWidth;canvas.height = window.innerHeight;
});

为确保动画在不同窗口大小下正常显示,添加窗口大小变化监听器。当窗口大小改变时,重新设置canvas的宽度和高度为当前窗口的宽高,使动画始终适应屏幕尺寸,保证用户在不同设备和窗口状态下都能获得良好的视觉体验。

4、总结

通过对呼吸粒子球动画效果实现原理的详细分析,我们清晰看到如何利用 HTML5 Canvas 的 2D 绘图功能,结合 JavaScript 的数学计算和动画控制,创建出具有立体感和动态效果的粒子动画。从粒子属性初始化、位置更新、绘制,到动画循环管理以及窗口大小响应,每个环节紧密配合,共同打造出迷人的呼吸粒子球效果。希望本文能助您更好地理解和运用 HTML5 Canvas 进行动画开发,为网页增添更多精彩视觉效果。

完整的源码获取、技术问题讨论,请大家在评论区留言!

相关文章:

使用HTML5 Canvas 实现呼吸粒子球动画效果的原理

在网页开发领域&#xff0c;动画效果能够极大地提升用户体验&#xff0c;让页面变得更加生动有趣。今天&#xff0c;我们深入剖析一个基于 HTML5 Canvas 的 3D 粒子动画 —— 呼吸粒子球。通过详细解读其代码实现&#xff0c;我们将全面了解如何运用 HTML5 的强大功能构建出如此…...

计算机网络 (56)交互式音频/视频

一、定义与特点 定义&#xff1a;交互式音频/视频是指用户使用互联网和其他人进行实时交互式通信的技术&#xff0c;包括语音、视频图像等多媒体实时通信。 特点&#xff1a; 实时性&#xff1a;音频和视频数据是实时传输和播放的&#xff0c;用户之间可以进行即时的交流。交互…...

Androidstudio 中,project下的.gitignore和module下的.gitignore有什么区别,生效优先级是什么

在 Android Studio 项目中&#xff0c;project 根目录下的 .gitignore 文件和 module 目录下的 .gitignore 文件作用和生效优先级是不同的&#xff0c;理解它们之间的区别非常重要&#xff0c;可以避免不必要的提交和冲突。 1. project 根目录下的 .gitignore&#xff1a; 作…...

三篇物联网漏洞挖掘综述

由于物联网设备存在硬件资源受限、硬件复杂异构&#xff0c; 代码、文档未公开的问题&#xff0c; 物联网设备的漏洞挖掘存在较大的挑战&#xff1a; 硬件资源受限性: 通用动态二进分析技术需要在运行程序外围实施监控分析。由于物联网设备存储资源(存储)的受限性&#xff0c;…...

【动态规划】落花人独立,微雨燕双飞 - 8. 01背包问题

本篇博客给大家带来的是01背包问题之动态规划解法技巧. &#x1f40e;文章专栏: 动态规划 &#x1f680;若有问题 评论区见 ❤ 欢迎大家点赞 评论 收藏 分享 如果你不知道分享给谁,那就分享给薯条. 你们的支持是我不断创作的动力 . 王子,公主请阅&#x1f680; 要开心要快乐顺便…...

uniapps使用HTML5的io模块拷贝文件目录

最近在集成sqlite到uniapp的过程中&#xff0c;因为要将sqlite数据库预加载&#xff0c;所以需要使用HTML5的plus.io模块。使用过程中遇到了许多问题&#xff0c;比如文件路径总是解析不到等。尤其是应用私有文档目录’_doc’。 根据官方文档&#xff1a; 为了安全管理应用的…...

Word2Vec如何优化从中间层到输出层的计算?

文章目录 Word2Vec如何优化从中间层到输出层的计算&#xff1f;用负采样优化中间层到输出层的计算负采样方法的关键思想负采样的例子负采样的采样方法 Word2Vec如何优化从中间层到输出层的计算&#xff1f; 重要性&#xff1a;★★ 用负采样优化中间层到输出层的计算 以词汇…...

C#中的语句

C#提供了各式各样的语句&#xff0c;大多数是由C和C发展而来&#xff0c;当然&#xff0c;在C#中做了相应修改。语句和表达式一样&#xff0c;都是C#程序的基本组成部分&#xff0c;在本文我们来一起学习C#语句。 1.语句 语句是构造所有C#程序的过程构造块。在语句中可以声明…...

2.3.1(项目)kv存储——框架梳理(待定)

一、过一遍代码路线&#xff1a; 体会&#xff1a;&#xff08;1&#xff09;接口统一、测试标准统一&#xff0c;软件才会有量产的过程&#xff1b;&#xff08;b&#xff09;多层框架&#xff0c;实现业务部分和网络部分的完全剥离。 实现多层框架&#xff1a; &#xff0…...

【YOLOv10改进[Backbone]】使用ConvNeXtV2替换Backbone

本文将进行在YOLOv10中使用ConvNeXtV2替换Backbone魔改v10的实践,文中含全部代码、详细修改方式。助您轻松理解改进的方法。 目录 一 ConvNeXtV2 二 魔改YOLOv10 1 整体修改 ① 添加python文件 ② 修改ultralytics/nn/tasks.py文件 2 配置文件...

在C#中添加I/O延时和持续时间

在C#中添加I/O延时和持续时间&#xff0c;可以通过以下方法实现。具体来说&#xff0c;延时可以通过Thread.Sleep、Task.Delay等方式来模拟延迟&#xff0c;而持续时间的控制可以通过循环结构来设定持续的时间。在执行I/O操作时&#xff0c;你可以在操作之间添加延时&#xff0…...

VUE之路由Props、replace、编程式路由导航、重定向

目录 1、路由_props的配置 2、路由_replaces属性 3、编程式路由导航 4、路由重定向 1、路由_props的配置 1&#xff09;第一种写法&#xff0c;将路由收到的所有params参数作为props传给路由组件 只能适用于params参数 // 创建一个路由器&#xff0c;并暴露出去// 第一步…...

RabbitMQ的消息可靠性保证

文章目录 1.环境搭建1.common-rabbitmq-starter 配置防止消费者抢消息&#xff08;基础配置&#xff09;2.common-rabbitmq-starter-demo下创建一个生产者一个消费者 2.生产者可靠性1.开启消息超时重试机制2.生产者开启ConfirmCallback消息确认机制1.application.yml2.TestConf…...

MySQL 很重要的库 - 信息字典

在做owasp SQL 注入的时候&#xff0c;有个很重要的库&#xff0c;那就是 信息库: 这个库就是: information_schema; &#xff08;准确的说&#xff0c;数据字典) mysql> show databases; -------------------- | Database | -------------------- | informa…...

使用C#对指定的MYSQL数据库进行备份以及常见问题

最近在开发过程中&#xff0c;需要做个MYSQL数据库的备份&#xff0c;大致总结了一下代码&#xff0c;以及常见的坑 string bakName "database" DateTime.Now.ToString("yyyyMMddHHmmss") ".sql";//备份后的数据库文件名var bakupFilePath &q…...

Appium(四)

一、app页面元素定位 1、通过id定位元素: resrouce-id2、通过ClassName定位&#xff1a;classname3、通过AccessibilityId定位&#xff1a;content-desc4、通过AndroidUiAutomator定位5、通过xpath定位xpath、id、class、accessibility id、android uiautomatorUI AutomatorUI自…...

jvm_threads_live_threads 和 jvm_threads_states_threads 这两个指标之间存在一定的关系,但它们关注的维度不同

jvm_threads_live_threads 和 jvm_threads_states_threads 这两个指标之间存在一定的关系&#xff0c;但它们关注的维度不同。以下是它们的详细关系和区别&#xff1a; 1. jvm_threads_live_threads 含义&#xff1a; 表示当前 JVM 中存活的线程总数&#xff08;即当前活动的线…...

docker 部署.netcore应用优势在什么地方?

目录 1. 环境一致性 2. 简化依赖管理 3. 快速部署与扩展 4. 资源利用率高 5. 版本控制与回滚 6. 安全性 7. 生态系统支持 8. 微服务架构支持 9. 降低成本 10. 开发体验提升 总结 使用 Docker 部署 .NET Core 应用有许多优势&#xff0c;特别是在开发、测试和生产环境…...

SpringBoot开发(一)应用jar包

1. SpringBoot开发 1.1. 目标及简介 1.1.1. 目标 &#xff08;1&#xff09;掌握微服务SpringBoot在实际项目开发中常用的核心技术栈及其在典型业务场景下的应用实战。   &#xff08;2&#xff09;掌握SpringBoot SpringMVC Mybatis在Java Web应用开发过程的技术干货以及…...

【Linux】深刻理解动静态库

1.什么是库 库是写好的现有的&#xff0c;成熟的&#xff0c;可以复⽤的代码。现实中每个程序都要依赖很多基础的底层库&#xff0c;不可能每个⼈的代码都从零开始&#xff0c;因此库的存在意义⾮同寻常。本质上来说库是⼀种可执⾏代码的⼆进制形式&#xff0c;可以被操作系统载…...

【spring 事务】事务的基本使用,事务隔离级别、事务传播机制

在Spring框架中&#xff0c;声明式事务管理是一种通过注解或配置文件自动管理事务的方式&#xff0c;而不需要手动编写事务管理代码。Transactional是Spring提供的一个注解&#xff0c;用于声明式事务管理&#xff0c;它使得事务的管理变得简单而清晰。 主要特性 自动事务管理…...

arkime 和elasticsearch安装方法二

这次试一下新的办法 先下载centOS 7 然后改成阿里云镜像 输入命令备份官方yum源配置文件 cp /etc/yum.repos.d/CentOS-Base.repo /etc/yum.repos.d/CentOS-Base.repo.bak 下载阿里云源配置&#xff0c;覆盖原文件 curl -o /etc/yum.repos.d/CentOS-Base.repo http://mirr…...

GitCode 助力 AutoTable:共创 MyBatis 生态的自动表格管理新篇章

项目仓库https://gitcode.com/dromara/auto-table 解放双手&#xff0c;专注业务&#xff1a;MyBatis 生态的“自动表格”创新 AutoTable 是一款致力于为 MyBatis 生态赋予“自动表格”功能的创新插件。其核心理念是通过 Java 实体类自动生成和维护数据库的表结构&#xff0c…...

日历热力图,月度数据可视化图表(日活跃图、格子图)vue组件

日历热力图&#xff0c;月度数据可视化图表&#xff0c;vue组件 先看效果&#x1f447; 在线体验https://www.guetzjb.cn/calanderViewGraph/ 日历图简单划分为近一年时间&#xff0c;开始时间是 上一年的今天&#xff0c;例如2024/01/01 —— 2025/01/01&#xff0c;跨度刚…...

ue5 制作,播放,停止动画蒙太奇

右键&#xff0c;动画蒙太奇 新建插槽 把默认插槽选择为&#xff0c;自己新建的插槽 然后拖一个动画进去 input换成玩家0 就可以接收键盘事件 pawn 自动控制玩家换成玩家0 找到动画蓝图 把它化成我们那边蒙太奇里面的槽 第三步&#xff1a;第三人称角色蓝图 按下F…...

Genetic Prompt Search via Exploiting Language Model Probabilities

题目 利用语言模型概率的遗传提示搜索 论文地址&#xff1a;https://www.ijcai.org/proceedings/2023/0588.pdf 项目地址&#xff1a;https://github.com/zjjhit/gap3 摘要 针对大规模预训练语言模型(PLMs)的即时调优已经显示出显著的潜力&#xff0c;尤其是在诸如fewshot学习…...

mysql之表的外键约束

MySQL表的外键约束详细介绍及代码示例 外键约束是数据库中用于维护数据完整性和一致性的重要机制。它确保一个表中的数据与另一个表中的数据相关联&#xff0c;防止无效的数据引用。本文将详细介绍了外键约束的各个方面&#xff0c;并通过具体的代码示例进行演示。 1. 外键约束…...

linux环境变量配置文件区别 /etc/profile和~/.bash_profile

在 Linux 系统中&#xff0c;环境变量可以定义用户会话的行为&#xff0c;而这些变量的加载和配置通常涉及多个文件&#xff0c;如 ~/.bash_profile 和 /etc/profile。这些文件的作用和加载时机各有不同。以下是对它们的详细区别和用途的说明&#xff1a; 文章目录 1. 环境变量…...

C++----STL(vector)

vector的介绍 vector的文档介绍&#xff1a;cplusplus.com/reference/vector/vector/ 1.基本概念 简单来说&#xff0c;vector是表示可以改变大小的数组的顺序容器。使用连续的存储位置来存储元素&#xff0c;因此可以通过常规指针的偏移量来高效访问。 2.内部机制 vector…...

springboot项目适配电科金仓数据库

又接到了信创适配任务,话不多说,直接开始干货 首先安装一下电科金仓的数据库,直接官网下,对应的授权也下90天的专业版,客户肯定是整个采购,365天的开发版本连接数有限制 KES相关下载地址:电科金仓-成为世界卓越的数据库产品与服务提供商 安装就不做赘述了 启动数据库…...

C# 动态创建Label和ComboBox控件并修改Text获取Text

背景&#xff1a;在做项目的时候可能需要根据一定数量创建某些控件并修改其属性&#xff0c;本文以控件label、ConboBox控件进行动态创建。 程序运行前后的的Form动态图 代码如下&#xff1a; using System; using System.Collections.Generic; using System.ComponentModel; …...

HP 笔记本重新安装 Windows 11 无法启动

相信你搜到这篇文章的时候&#xff0c; 你已经看过了网上各种关于如何在 HP 笔记本电脑上安装 Windows 11 的文章。你遇到的问题肯定不是网上那些文章讲的那么简单的问题。你遇到的一定不是你不懂如何安装 Windows&#xff0c;不懂如何对硬盘分区等等小白问题。 问题描述 问…...

BUUCTF_Web( XSS COURSE 1)xss

XSS即跨站脚本攻击&#xff08;Cross-Site Scripting&#xff09;&#xff0c;是一种常见的网络安全漏洞. 定义 XSS攻击指攻击者在目标网站中注入恶意脚本&#xff0c;当用户访问该网站时&#xff0c;浏览器会执行这些恶意脚本&#xff0c;从而导致用户信息泄露、被控制等安全问…...

STM32补充——IAP

0 前置知识&#xff1a; FLASH相关内容&#xff1a;前往STM32补充——FLASH STM32三种烧录方式&#xff08;看看就行&#xff09;&#xff1a; 1.ISP&#xff1a;In System Programming&#xff08;在系统编程&#xff09; 执行芯片厂商的 Bootloader 程序进入 ISP 模式&…...

APP加固的那些事

APP加固是保护APP代码逻辑的重要手段&#xff0c;通过隐藏、混淆、加密等操作提高软件的逆向成本&#xff0c;降低被破解的几率&#xff0c;保障开发者和用户利益。本文将介绍APP加固常见失败原因及解决方法&#xff0c;以及处理安装出现问题的情况和资源文件加固策略选择。 引…...

数据分析 基础定义

一、大数据的定义 数据分析是基于商业等目的&#xff0c;有目的的进行收集、整理、加工和分析数据&#xff0c;提炼有价值信息的过程。 大数据分析即针对海量的、多样化的数据集合的分析 大数据分析是一种利用大规模数据集进行分析和挖掘知识的方法。随着互联网、社交媒体、移动…...

PyTorch广告点击率预测(CTR)利用深度学习提升广告效果

目录 广告点击率预测问题数据集结构广告点击率预测模型的构建1. 数据集准备2. 构建数据加载器3. 构建深度学习模型4. 训练与评估 总结 广告点击率预测&#xff08;CTR&#xff0c;Click-Through Rate Prediction&#xff09;是在线广告领域中的重要任务&#xff0c;它帮助广告平…...

嵌入式入门(二)-STM32CubeMX项目开发

使用STM32CubeMX创建项目 本文使用STM32CubeMX模拟器创建一个嵌入式项目的详细流程。 New Project 根据型号搜索 搜索型号&#xff1a; STM32F103C8T6 启动项目 选择STM32F103C8T6后点击 Start Project 配置时钟 切换到 Clock Configuration 修改HCLK -->72MHZ 修改Input fr…...

MATLAB绘图时线段颜色、数据点形状与颜色等设置,介绍

MATLAB在绘图时&#xff0c;设置线段颜色和数据点的形状与颜色是提高图形可读性与美观性的重要手段。本文将详细介绍如何在 MATLAB 中设置这些属性。 文章目录 线段颜色设置单字母颜色表示法RGB 值表示法 数据点的形状与颜色设置设置数据点颜色和形状示例代码 运行结果小结 线段…...

Java菜鸟养成计划(java基础)--java运算符

java中的运算符 1、java中的运算符1.1 、 、-、 * 、/ 、 %1.2 、、-、 *、/、%1.3 、、--【自增\自减运算符】1.4、>、 <、 > 、< 、 、! 、! 1.5、&&、||、|、&1.6、&、|、~、^1.7、>> 、 <<、>>>位运算1.8、?:三目运算符…...

学习笔记——动态规划

递推 1.递推和动态规划有什么关系&#xff1f; 递推问题包括动态规划&#xff0c;动态规划一定是递推&#xff0c;递推不一定是动态规划。 动态规划是一种决策性的问题&#xff0c;是在状态中做最优决策的一种特殊递推算法&#xff0c;通常的问法包括求最大最小值等&#xff…...

蓝桥杯备考:红黑树与map和set

搜索二叉树 我们三种树只了解原理&#xff0c;不写代码&#xff0c;因为我们竞赛不做要求&#xff0c;只是为了使用set和map做铺垫 原理记不住&#xff0c;没关系&#xff0c;我们只要会各种操作的时间复杂度 二叉搜索树的定义 1若左子树非空&#xff0c;左子树所有结点的权…...

第二届生成式人工智能与信息安全国际学术会议(GAIIS 2025)

在线投稿&#xff1a; 学术会议-学术交流征稿-学术会议在线-艾思科蓝 【征文主题】&#xff08;包括但不限于&#xff09; 深度学习 自然语言处理 算法应用 计算机视觉 视觉识别 模式识别 强化学习 生成对抗网络 生成建模技术 语言预训练 视觉预训练 联合预训练…...

后端面试题分享第一弹(状态码、进程线程、TCPUDP)

后端面试题分享第一弹 1. 如何查看状态码&#xff0c;状态码含义 在Web开发和调试过程中&#xff0c;HTTP状态码是了解请求处理情况的重要工具。 查看状态码的步骤 打开开发者工具&#xff1a; 在大多数浏览器中&#xff0c;您可以通过按下 F12 键或右键单击页面并选择“检查…...

Python 常用运维模块之OS模块篇

Python 常用运维模块之OS模块篇 OS 模块获取当前工作目录更改当前工作目录返回当前目录路径返回上一级目录路径递归生成目录路径删除目录创建目录删除目录列出特定目录下文件和子目录删除某个特定文件重命名某个文件获取某个文件/目录的信息输出目录路径分隔符输出文件行终止符…...

前沿技术趋势洞察:2024年技术的崭新篇章与未来走向!

引言 时光飞逝&#xff0c;2024年已经来临&#xff0c;回顾过去一年&#xff0c;科技的迅猛进步简直让人目不暇接。 在人工智能&#xff08;AI&#xff09;越来越强大的今天&#xff0c;我们不再停留在幻想阶段&#xff0c;量子计算的雏形开始展示它的无穷潜力&#xff0c;Web …...

HTML语言的数据结构

HTML语言的数据结构 引言 HTML&#xff08;超文本标记语言&#xff09;是构建网页的标准语言。尽管HTML本身不是一种编程语言&#xff0c;它为我们提供了一种结构化的信息表示方法&#xff0c;使得网页内容能够有序地展现给用户。HTML的核心在于其标记&#xff08;标签&#…...

怎么创建一个能在线测试php的html5网页?

代码示例&#xff1a; 一、搭建服务器环境 首先&#xff0c;你需要在服务器上搭建 PHP 运行环境。如果你使用的是 Linux 服务器&#xff0c;可以使用 Apache 或 Nginx 作为 Web 服务器&#xff0c;并安装 PHP 解释器。对于 Windows 服务器&#xff0c;可以使用 WAMP&#xff08…...

docker安装elk6.7.1-搜集nginx-json日志

docker安装elk6.7.1-搜集nginx-json日志 如果对运维课程感兴趣&#xff0c;可以在b站上、A站或csdn上搜索我的账号&#xff1a; 运维实战课程&#xff0c;可以关注我&#xff0c;学习更多免费的运维实战技术视频 0.规划 192.168.171.130 nginxfilebeat 192.168.171.131 …...

常见的社交媒体平台有哪些?

社交媒体平台有哪些&#xff1f;在跨境电商和全球营销的过程中&#xff0c;海外社交媒体平台是提高品牌曝光率的重要工具。为了有效管理多个平台的账户&#xff0c;并防止账户之间的关联问题&#xff0c;OKBrow指纹指纹浏览器凭借其强大的多账户管理、防关联技术和隐私保护功能…...