Three.js 图像粒子飞线效果 | 三维可视化 / AI 提示词

Three.js 图像粒子飞线效果 | 三维可视化 / AI 提示词

📋 AI 提示词

prompt 复制代码
创建一个图像粒子飞线效果,将图像转换为粒子系统,粒子沿贝塞尔曲线飞行,创造动态视觉效果。

🖼️ 效果预览

🎮 案例演示

立即体验


效果描述

这是一个将图像转换为粒子系统并沿贝塞尔曲线飞行的效果,通过自定义动画实现粒子的分块飞散,创造出震撼的视觉效果。

效果特性

  • 图像转粒子:将图像分解为粒子系统
  • 贝塞尔曲线动画:粒子沿三次贝塞尔曲线飞行
  • 分块飞散:粒子按三角形面分组飞散
  • 周期性循环:4秒周期自动重置
  • 3D视角控制:OrbitControls支持3D旋转查看

核心参数

参数 说明
宽度 200
高度 100
周期 1500ms
纹理 earth.jpeg

核心代码解析

BufferGeometry配置

javascript 复制代码
let bufferGeometry = new THREE.BufferGeometry();
bufferGeometry.setAttribute("position", new THREE.BufferAttribute(new Float32Array(positionArr), 3));
bufferGeometry.setAttribute("originPosition", new THREE.BufferAttribute(new Float32Array(positionArr), 3));
bufferGeometry.setAttribute("normal", new THREE.BufferAttribute(new Float32Array(normalArr), 3));
bufferGeometry.setAttribute("uv", new THREE.BufferAttribute(new Float32Array(uvArr), 2));
bufferGeometry.faceAnimateArr = [];

贝塞尔曲线计算

javascript 复制代码
function bezier(P0, P1, P2, P3, t) {
    const x = P0.x * (1 - t) * (1 - t) * (1 - t) +
              3 * P1.x * t * (1 - t) * (1 - t) +
              3 * P2.x * t * t * (1 - t) +
              P3.x * t * t * t;
    const y = P0.y * (1 - t) * (1 - t) * (1 - t) +
              3 * P1.y * t * (1 - t) * (1 - t) +
              3 * P2.y * t * t * (1 - t) +
              P3.y * t * t * t;
    const z = P0.z * (1 - t) * (1 - t) * (1 - t) +
              3 * P1.z * t * (1 - t) * (1 - t) +
              3 * P2.z * t * t * (1 - t) +
              P3.z * t * t * t;
    return { x, y, z };
}

粒子飞行动画

javascript 复制代码
bufferGeometry.faceAnimateArr.forEach((face, index) => {
    const tArr = bufferGeometry.attributes.originPosition.array;
    const face_firstVertex = {
        x: tArr[index * 3 * 3],
        y: tArr[index * 3 * 3 + 1],
        z: tArr[index * 3 * 3 + 2]
    };

    if (!face.startTime && face_firstVertex.x < currX) {
        face.startTime = Date.now();
    }

    if (face.startTime && face.progress < 1) {
        face.progress = (Date.now() - face.startTime) / face.circle;
        if (face.progress > 1) face.progress = 1;

        for (let i = 0; i < 3; i++) {
            const currVertexIndex = index * 3 + i;
            const originPos = {
                x: tArr[currVertexIndex * 3],
                y: tArr[currVertexIndex * 3 + 1],
                z: tArr[currVertexIndex * 3 + 2]
            };
            const { start, control1, control2, end } = bufferGeometry.faceAnimateArr[index].bezier;
            const bezierPos = bezier(start, control1, control2, end, face.progress);
            const newPos = {
                x: originPos.x + bezierPos.x,
                y: originPos.y + bezierPos.y,
                z: originPos.z + bezierPos.z
            };
            bufferGeometry.attributes.position.setXYZ(currVertexIndex, newPos.x, newPos.y, newPos.z);
        }
    }
});
plane.geometry.dispose();
plane.geometry = bufferGeometry.clone();

控制点生成

javascript 复制代码
let control1 = {
    x: Math.random() * 50,
    y: y_sign * (Math.random() * 80),
    z: 0
};
let control2 = {
    x: Math.random() * 50,
    y: -y_sign * 20,
    z: 0
};
obj.bezier = { start, control1, control2, end };

技术亮点

  1. 图像粒子化:将图像纹理应用于几何体并分解为粒子
  2. 贝塞尔曲线动画:三次贝塞尔曲线创造平滑的飞行动画
  3. 分组飞散:按三角形面分组,创造整体飞散效果
  4. 实时几何更新:动态更新几何体属性实现动画
  5. 周期性重置:自动循环创造持续视觉效果

调试技巧

  1. 周期调节:修改circle变量调整动画周期
  2. 控制点范围:调整Math.random范围改变飞行轨迹
  3. 纹理替换:更换earth.jpeg可实现不同图像效果
  4. 几何体精度:调整PlaneGeometry分段数改变粒子密度
  5. 飞散方向:调整控制点y值改变飞散方向

扩展方向

  1. 多种纹理:添加多张图像实现切换效果
  2. 交互触发:鼠标点击触发飞散动画
  3. 粒子特效:添加粒子尾迹效果增强视觉
  4. 声音同步:添加音频分析与粒子效果同步
  5. 3D模型:将图像替换为3D模型实现更复杂效果

本文档由 ThreeLab 编辑整理,专注 Three.js 着色器、Web 3D、GIS 可视化技术分享。如需转载,请注明出处。

相关推荐
怀庆同学2 小时前
C语言基础-单链表
c语言·开发语言
niucloud-admin2 小时前
JAVA V6 多商户商城 开发文档——插件安装
java·开发语言
阿里云云原生2 小时前
「郑州市科技系统人工智能素养培训」暨「龙虾引擎——AI 原生应用开发实战营·郑州站」精彩回顾 & PPT 下载
人工智能
百度Geek说2 小时前
2 小时,0 行手写代码,我用 Claude 做了一个生产级 VSCode 插件
人工智能
测试员周周2 小时前
【免费福利】AI测试:测试技能包进阶:造数、压测、视觉回归、CI 全流程串联
开发语言·人工智能·python·功能测试·测试工具·ci/cd·测试用例
生成论实验室2 小时前
《源·觉·知·行·事·物:生成论视域下的统一认知语法》第十七章 科学与人心的重聚
人工智能·算法·架构·知识图谱·创业创新
AGV算法笔记2 小时前
目标检测论文精读:Deformable DETR 为什么被认为是 DETR 真正走向实用的关键一步?
人工智能·深度学习·目标检测·机器学习·计算机视觉·目标跟踪
人工智能AI技术2 小时前
卷积神经网络 CNN 基础:专为图像而生的模型
人工智能
model20052 小时前
yolo26训练自己数据集
人工智能·深度学习