Three.js实现3D动态心形与粒子背景的数学与代码映射解析
一、效果概述
本文通过Three.js构建了一个具有科技感的3D场景,主要包含两大视觉元素:
- 动态心形模型:采用数学函数生成基础形状,通过顶点操作实现表面弧度。
- 星空粒子背景:随机分布的粒子群组形成空间层次感。
- 复合动画系统:包含心跳脉冲、轴向旋转、粒子场运动等动画效果。
视觉效果:
超酷3D心形粒子特效,浪漫满分!
二、核心技术实现原理
2.1,心形建模算法
心形建模算法利用了经典的心形参数方程,通过数学公式生成心形路径。该方程定义了心形在二维平面上的轮廓,其中 (x(t) = 16\sin^3 t) 和 (y(t) = 13\cos t - 5\cos 2t - 3\cos 3t - \cos 4t)。这些公式通过参数 (t) 描述了心形的曲线形状,随着 (t) 从0到 (2\pi) 的变化,生成一个完整的心形轮廓。这个路径随后被用于创建三维几何体,通过Three.js的ExtrudeGeometry进行挤出,形成一个具有深度和曲面弧度的3D心形模型。
2.1.1,心形参数方程
代码中采用经典心形线参数方程,其数学表达式为:

其中 t∈[0,2π]t∈[0,2π],步长0.01决定曲线精度。该方程相比标准心形方程 r=a(1−sinθ)r=a(1−sinθ) 能生成更圆润的边界曲线。
2.1.2,代码实现
function createHeartShape() {const shape = new THREE.Shape();for (let t = 0; t <= Math.PI*2; t += 0.01) {const x = 16 * Math.pow(Math.sin(t), 3);const y = 13*Math.cos(t) - 5*Math.cos(2*t) - 3*Math.cos(3*t) - Math.cos(4*t);// 路径绘制...}return shape;
}
2.1.3,原理说明
该方程通过多项式组合控制曲线形态,相比标准心形方程:
- 5cos2t 项控制心形凹陷深度
- 3cos3t 调整顶部曲率
- cos4t 消除底部尖角
代码中t += 0.01的步长值决定了曲线精度(约628个顶点)
2.2,三维挤出变换
2.2.1,变换矩阵
通过ExtrudeGeometry实现2D到3D转换时,运用了仿射变换矩阵:

2.2.2,代码实现
const extrudeSettings = {depth: 8, // 挤出深度bevelEnabled: true, // 启用倒角bevelSegments: 12 // 倒角细分
};
geometry.scale(0.5, 0.5, 0.5);
2.2.3,原理说明
- depth:8 沿Z轴挤出8个单位
- bevelSegments:12 使用12段圆弧平滑边缘
- 缩放矩阵将模型整体缩小50%,避免场景过载
2.3. 表面弧度算法
2.3.1,曲面变形公式:

2.3.2,代码实现
function addSurfaceCurvature(geometry) {const position = geometry.attributes.position;for (let i = 0; i < position.count; i++) {const x = position.getX(i);const y = position.getY(i);const z = position.getZ(i) + 0.01 * Math.sqrt(x*x + y*y);position.setXYZ(i, x, y, z);}geometry.computeVertexNormals();
}
2.3.3,原理说明
- 0.01为曲率系数,值越大曲面越凸
- 法线重计算确保光照反射正确,算法复杂度为O(n)
- 该变形等效于将平面映射到旋转抛物面:

其中 p=25 控制抛物面开口大小。
2.4,动画系统
2.4.1,心跳脉冲函数数学公式:

2.4.2,代码实现
// 在animate()函数中
const pulse = Math.sin(time * 3) * 0.2 + 1;
heart.scale.set(pulse, pulse, pulse);
2.4.3,原理说明
- 频率参数3:每秒完成3/(2π)≈0.477次心跳
- 振幅0.2:尺寸在0.8~1.2倍之间波动
- 基准值1:确保缩放不出现负值
2.5,粒子系统
粒子系统的实现通过使用Three.js的BufferGeometry来优化性能和内存使用。我们生成了1500个粒子,每个粒子的坐标在 [−50,50的范围内均匀分布,这意味着每个坐标轴上的位置是随机的。这样,粒子的平均密度为 0.015 粒子/单位立方体。BufferGeometry的使用相比于传统的Geometry减少了约70%的内存占用,因为它允许直接在GPU上存储和操作顶点数据,从而提高了渲染效率和性能。这种方法特别适合于需要处理大量粒子的场景,如模拟星空或烟雾效果。
2.5.1,位置随机分布函数

2.5.2,代码实现
for (let i = 0; i < 1500; i++) {positions.push((Math.random() - 0.5) * 100, // x(Math.random() - 0.5) * 100, // y (Math.random() - 0.5) * 100 // z);
}
2.5.3,原理说明,
- U(-50,50)表示均匀分布
- 粒子数1500时,平均密度为:

- 使用BufferGeometry减少内存占用约70%(相比普通Geometry)
三、光照模型实现
在光照模型中,点光源的衰减通过物理模型来实现,使得光源的强度随着距离的增加而减弱。在Three.js中,可以通过配置点光源的初始强度和衰减半径来实现这一效果。在代码中,new THREE.PointLight(0xff77aa, 1, 50) 设置了光源的初始强度为1,衰减半径为50。这意味着当距离达到50时,光照强度会减弱到一半。这种衰减模型使得光源在场景中更具真实感,模拟了现实中光线随着距离减弱的效果。,
3.1,点光源衰减物理公式:

3.2,代码实现
new THREE.PointLight(0xff77aa, 1, 50) // distance=50
四、性能优化
4.1,矩阵更新优化渲染循环:
function animate() {requestAnimationFrame(animate);// 仅更新变换矩阵renderer.render(scene, camera);
}
4.2,原理说明
- Three.js采用矩阵惰性更新机制
- 当修改object.position等属性时,仅标记需要更新矩阵
- 在渲染前统一计算世界矩阵,复杂度从O(n²)降至O(n)
五、扩展应用示例
5.1,数学原理
实时修改曲率系数k时,顶点位置更新公式:

5.2,代码实现
// 添加GUI控件
const gui = new dat.GUI();
gui.add(curveParams, 'factor', 0, 0.05).onChange(v => {heart.traverse(child => {if (child.isMesh) {addSurfaceCurvature(child.geometry, v);}});
});
六,总结
本文利用Three.js实现了一个3D曲面爱心动画,包含场景初始化、光源配置、心形模型创建、粒子背景生成和动画效果。通过数学公式生成心形路径,并使用ExtrudeGeometry进行三维挤出,形成具有曲面弧度的心形模型。添加环境光和双色点光源提供立体照明,利用BufferGeometry和PointsMaterial创建动态粒子背景,模拟星空效果。动画部分实现了心形的脉动和旋转,以及粒子背景的缓慢运动,并通过监听窗口大小变化实现响应式设计,确保在不同设备上正常显示。
任何问题,源码获取请私信留言。
相关文章:
Three.js实现3D动态心形与粒子背景的数学与代码映射解析
一、效果概述 本文通过Three.js构建了一个具有科技感的3D场景,主要包含两大视觉元素: 动态心形模型:采用数学函数生成基础形状,通过顶点操作实现表面弧度。星空粒子背景:随机分布的粒子群组形成空间层次感。复合动画…...
linux asio网络编程理论及实现
最近在B站看了恋恋风辰大佬的asio网络编程,质量非常高。在本章中将对ASIO异步网络编程的整体及一些实现细节进行完整的梳理,用于复习与分享。大佬的博客:恋恋风辰官方博客 Preactor/Reactor模式 在网络编程中,通常根据事件处理的触…...
多目标优化策略之一:非支配排序
多目标优化策略中的非支配排序是一种关键的技术,它主要用于解决多目标优化问题中解的选择和排序问题,确定解集中的非支配解(也称为Pareto解)。 关于什么是多目标优化问题,可以查看我的文章:改进候鸟优化算法之五:基于多目标优化的候鸟优化算法(MBO-MO)-CSDN博客 多目…...
电子电气架构 --- 在智能座舱基础上定义人机交互
我是穿拖鞋的汉子,魔都中坚持长期主义的汽车电子工程师。 老规矩,分享一段喜欢的文字,避免自己成为高知识低文化的工程师: 简单,单纯,喜欢独处,独来独往,不易合同频过着接地气的生活…...
Autosar-Os是怎么运行的?(时间保护)
写在前面: 入行一段时间了,基于个人理解整理一些东西,如有错误,欢迎各位大佬评论区指正!!! 1.功能概述 AUTOSAR OS 的四大可定制类型凸显了时间保护(Timing Protection)…...
一种用于低成本水质监测的软传感器开源方法:以硝酸盐(NO3⁻)浓度为例
论文标题 A Soft Sensor Open-Source Methodology for Inexpensive Monitoring of Water Quality: A Case Study of NO3− Concentrations 作者信息 Antonio Jess Chaves, ITIS Software, University of Mlaga, 29071 Mlaga, Spain Cristian Martn, ITIS Software, Universi…...
5分钟带你获取deepseek api并搭建简易问答应用
目录 1、获取api 2、获取base_url和chat_model 3、配置模型参数 方法一:终端中临时将加入 方法二:创建.env文件 4、 配置client 5、利用deepseek大模型实现简易问答 deepseek-v3是截止博文撰写之日,无论是国内还是国际上发布的大模型中…...
算法基础学习——二分查找(附带Java模板)
有单调性的数列一定可以使用二分,没有单调性的题目也可能可以使用二分; (一)整数二分 二分的本质: 在某个整数区间内,存在某种性质使得区间内左半边的数都不满足该性质;而右半边的数都满足该性…...
如何使用formlinker,重构微软表单创建的数字生产力法则?
仅需三步:上传文件-下载文件-导入文件到微软表单 凌晨两点的格式炼狱:被浪费的300万小时人类创造力 剑桥大学的实验室曾捕捉到一组震撼数据:全球教育工作者每年花在调整试题格式上的时间,足够建造3座迪拜哈利法塔。当北京某高校的…...
python-leetcode-路径总和
112. 路径总和 - 力扣(LeetCode) # Definition for a binary tree node. # class TreeNode: # def __init__(self, val0, leftNone, rightNone): # self.val val # self.left left # self.right right class Solution:de…...
乐理笔记——DAY01
三分钟音乐社视频地址: 【四川音乐学院作曲硕士】零基础自学音乐学乐理合集-第二季(最终版)/已完结https://www.bilibili.com/video/BV14p4y1e7TV?spm_id_from333.788.videopod.episodes&vd_source0a2d366696f87e241adc64419bf12cab&am…...
使用DeepSeek技巧:提升内容创作效率与质量
一、引言 在当今快节奏的数字时代,内容创作的需求不断增加,无论是企业营销、个人博客还是学术研究,高效且高质量的内容生成变得至关重要。DeepSeek作为一款先进的人工智能写作助手,凭借其强大的语言生成能力,为创作者…...
视频编辑系列——Shotcut如何裁切视频黑边并放大画面导出
会议录屏经常出现不满屏的现象(图1),通过本方法可以调整为图2。 图1 图2 打开shotcut,将待裁剪视频导入,将视频拖到时间线。顶部菜单栏点击“滤镜”,新建一个“尺寸、位置与旋转”的滤镜,然后…...
vim操作简要记录
操作容易忘记,记录一下基本使用的 :wq保存退出 :w :q :q! :wq! i I a A 方向键 h左 j下 k上 l右 dd删除方行(这其实是剪切行操作,不过一般用作删除,长按可删除,不过按.执行上一次操作删除更快) .执行上…...
小南每日 AI 资讯 | AI模型扩展的快速增长时代正在放缓 | 25/01/30
AI模型扩展的挑战:随着研究人员发现单纯通过增加规模和计算能力难以获得更大回报,AI模型扩展的快速增长时代正在放缓。 GPT-5开发延迟:OpenAI雄心勃勃的GPT-5项目(代号:Orion)面临着显著的障碍,…...
《DeepSeek 对话实录》
《DeepSeek 对话实录》 你是DeepSeek哪个版本?一、DeepSeek key如何申请1. 访问DeepSeek官网:2. 注册或登录:3. **进入API管理页面**:4. 申请API密钥:5. 提交申请:6. 等待审核:7. 使用API密钥&a…...
FastAPI + GraphQL + SQLAlchemy 实现博客系统
本文将详细介绍如何使用 FastAPI、GraphQL(Strawberry)和 SQLAlchemy 实现一个带有认证功能的博客系统。 技术栈 FastAPI:高性能的 Python Web 框架Strawberry:Python GraphQL 库SQLAlchemy:Python ORM 框架JWT&…...
React第二十八章(css modules)
css modules 什么是 css modules 因为 React 没有Vue的Scoped,但是React又是SPA(单页面应用),所以需要一种方式来解决css的样式冲突问题,也就是把每个组件的样式做成单独的作用域,实现样式隔离,而css modules就是一种…...
昆仑万维Java开发面试题及参考答案
进程和线程的区别是什么? 进程和线程都是操作系统中非常重要的概念,它们在多个方面存在显著的区别。 从定义上看,进程是操作系统进行资源分配和调度的基本单位。每个进程都有自己独立的内存空间,包括代码段、数据段、堆栈段等。例如,当你在电脑上同时打开浏览器和音乐播放…...
DeepSeek R1-Zero vs. R1:强化学习推理的技术突破与应用前景
📌 引言:AI 推理的新时代 近年来,大语言模型(LLM) 的规模化扩展成为 AI 研究的主流方向。然而,LLM 的扩展是否真的能推动 通用人工智能(AGI) 的实现?DeepSeek 推出的 R1…...
Linux《基础指令》
在之前的Linux《Linux简介与环境的搭建》当中我们已经初步了解了Linux的由来和如何搭建Linux环境,那么接下来在本篇当中我们就要来学习Linux的基础指令。在此我们的学习是包括两个部分,即指令和关于Linux的基础知识;因此本篇指令和基础知识的…...
2024.12.28测试 总结
还是超级无敌寀啊~ 目录 T1 赠送笔记本T2 中位数T3 好子集T4 异或总结 T1 赠送笔记本 link 题意 有 n n n 个宿舍,每个宿舍 4 4 4 头奶牛,第 i i i 个宿舍有 a i a_i ai 头牛有笔记本(每头牛的笔记本都不同)。现在所有奶…...
工业相机开发操作流程
建议按照如下的流程操作相机(其中有一些步骤是可选的,已经标明): 一、载入SDK的动态链接库档MVCAMSDK.DLL。可以使用动态或者静 态加载两种方式。 如果使用C/C进行开发,在工程引用 CameraApi.h头文件(位于安装目录的SDK/DEMO/VC/include中)和…...
DeepSeek-R1 模型及GRPO算法学习
总结DeepSeek-R1 模型算法,并对其中的GRPO算法做一些学习补充。 DeepSeek-R1 论文总结 提出了通过强化学习提升大语言模型推理能力的方法,开发出 DeepSeek-R1-Zero 和 DeepSeek-R1 模型,在多个推理任务上表现出色,并开源模型推动…...
Vue 3.0打造响应式用户界面的新方式
1 简介 Vue.js 是一个用于构建用户界面的渐进式框架。Vue 3.0 是其最新版本,引入了许多新特性和改进,使得开发者能够更高效地构建响应式的Web应用程序。本文将带你深入了解如何使用Vue 3.0来打造响应式用户界面,并通过实际案例和代码示例帮助你快速上手。 2 环境搭建 要开…...
爬虫基础(二)Web网页的基本原理
一、网页的组成 网页由三部分构成:HTML、JavaScript、CSS。 (1)HTML HTML 相当于网页的骨架,它通过使用标签来定义网页内容的结构。 举个例子: 它把图片标签为img、把视频标签为video,然后组合到一个界面…...
Kotlin开发(六):Kotlin 数据类,密封类与枚举类
引言 想象一下,你是个 Kotlin 开发者,敲着代码忽然发现业务代码中需要一堆冗长的 POJO 类来传递数据。烦得很?别急,Kotlin 贴心的 数据类 能帮你自动生成 equals、hashCode,直接省时省力!再想想需要多种状…...
我的AI工具箱Tauri+Django内容生产介绍和使用
在现代内容生产环境中,高效、自动化的工具能够显著提升生产力,降低人工成本。Tauri 与 Django 结合打造的工作箱,集成了强大的 音频处理、视频剪辑、内容下载 以及 AI 文章撰写 等模块,帮助用户在多媒体内容生产的各个环节实现高效…...
openssl 生成证书 windows导入证书
初级代码游戏的专栏介绍与文章目录-CSDN博客 我的github:codetoys,所有代码都将会位于ctfc库中。已经放入库中我会指出在库中的位置。 这些代码大部分以Linux为目标但部分代码是纯C的,可以在任何平台上使用。 源码指引:github源…...
AJAX笔记入门篇
黑马程序员视频地址: 黑马程序员前端AJAX入门到实战全套教程https://www.bilibili.com/video/BV1MN411y7pw?vd_source0a2d366696f87e241adc64419bf12cab&spm_id_from333.788.videopod.episodes&p2https://www.bilibili.com/video/BV1MN411y7pw?vd_source…...
