Three.js知识框架

news2025/5/15 8:09:40

一、Three.js 基础概念

1. Three.js 简介

  • 是什么?

    • 基于 WebGL 的 3D JavaScript 库,用于在浏览器中渲染 3D 场景。

  • 核心优势

    • 简化 WebGL 的复杂 API,提供高层封装。

    • 跨平台(支持桌面和移动端)。

  • 适用场景

    • 3D 可视化、游戏开发、VR/AR、产品展示等。

2. 核心三要素

  • 场景(Scene)

    • 3D 世界的容器,包含所有对象(模型、光源、相机等)。

  • 相机(Camera)

    • 定义视图的观察角度(透视相机 PerspectiveCamera / 正交相机 OrthographicCamera)。

  • 渲染器(Renderer)

    • 将场景和相机结合,输出到 HTML 画布(WebGLRenderer)。

3. 开发环境搭建

  • CDN 引入

    <script src="https://cdn.jsdelivr.net/npm/three@0.132.2/build/three.min.js"></script>

  • npm 安装

    npm install three

  • 基础代码结构

    // 1. 创建场景、相机、渲染器
    const scene = new THREE.Scene();
    const camera = new THREE.PerspectiveCamera(75, window.innerWidth / window.innerHeight, 0.1, 1000);
    const renderer = new THREE.WebGLRenderer();
    renderer.setSize(window.innerWidth, window.innerHeight);
    document.body.appendChild(renderer.domElement);
    
    // 2. 添加物体(立方体)
    const geometry = new THREE.BoxGeometry();
    const material = new THREE.MeshBasicMaterial({ color: 0x00ff00 });
    const cube = new THREE.Mesh(geometry, material);
    scene.add(cube);
    
    // 3. 渲染循环
    function animate() {
      requestAnimationFrame(animate);
      cube.rotation.x += 0.01;
      cube.rotation.y += 0.01;
      renderer.render(scene, camera);
    }
    animate();


二、Three.js 核心模块

4. 几何体(Geometry)

  • 内置几何体

    • BoxGeometry(立方体)、SphereGeometry(球体)、CylinderGeometry(圆柱体)。

  • 自定义几何体

    • 使用 BufferGeometry 和顶点数据手动创建。

5. 材质(Material)

  • 常用材质

    • MeshBasicMaterial(基础材质,不受光照影响)。

    • MeshPhongMaterial(高光材质,受光照影响)。

    • MeshStandardMaterial(PBR 材质,支持金属度和粗糙度)。

  • 纹理贴图

    • TextureLoader 加载图片作为材质贴图:

      const texture = new THREE.TextureLoader().load('texture.jpg');
      const material = new THREE.MeshBasicMaterial({ map: texture });

6. 光源(Light)

  • 光源类型

    • AmbientLight(环境光,均匀照亮所有物体)。

    • DirectionalLight(平行光,模拟太阳光)。

    • PointLight(点光源,模拟灯泡)。

    • SpotLight(聚光灯,带锥形照射范围)。

7. 动画与交互

  • 动画循环

    • 使用 requestAnimationFrame 实现平滑动画。

  • 用户交互

    • 通过 Raycaster 实现物体点击检测:

      const raycaster = new THREE.Raycaster();
      const mouse = new THREE.Vector2();
      window.addEventListener('click', (event) => {
        mouse.x = (event.clientX / window.innerWidth) * 2 - 1;
        mouse.y = -(event.clientY / window.innerHeight) * 2 + 1;
        raycaster.setFromCamera(mouse, camera);
        const intersects = raycaster.intersectObjects(scene.children);
        if (intersects.length > 0) console.log('点击了物体!');
      });


三、Three.js 进阶技术

8. 模型加载

  • 加载外部模型

    • 使用 GLTFLoader 加载 GLTF 格式(推荐):

      import { GLTFLoader } from 'three/examples/jsm/loaders/GLTFLoader';
      const loader = new GLTFLoader();
      loader.load('model.gltf', (gltf) => scene.add(gltf.scene));
    • 支持格式:GLTF、OBJ、FBX、STL 等。

9. 着色器(Shaders)

  • 自定义着色器

    • 通过 ShaderMaterial 编写 GLSL 代码:

      const material = new THREE.ShaderMaterial({
        vertexShader: `void main() { gl_Position = projectionMatrix * modelViewMatrix * vec4(position, 1.0); }`,
        fragmentShader: `void main() { gl_FragColor = vec4(1.0, 0.0, 0.0, 1.0); }`
      });

10. 后期处理(Post-Processing)

  • 特效添加

    • 使用 EffectComposer 实现模糊、辉光等效果:

      import { EffectComposer, RenderPass, BloomEffect } from 'postprocessing';
      const composer = new EffectComposer(renderer);
      composer.addPass(new RenderPass(scene, camera));
      composer.addPass(new BloomEffect());

11. 性能优化

  • 减少绘制调用

    • 合并几何体(BufferGeometryUtils.mergeBufferGeometries)。

  • 使用 InstancedMesh

    • 批量渲染相同几何体(适合大量重复物体)。

  • LOD(Level of Detail)

    • 根据距离切换不同精度的模型。


四、Three.js 高级应用

12. VR/AR 支持

  • WebXR

    • 通过 WebXRManager 实现 VR 渲染:

      import { VRButton } from 'three/examples/jsm/webxr/VRButton';
      renderer.xr.enabled = true;
      document.body.appendChild(VRButton.createButton(renderer));

13. 物理引擎集成

  • Cannon.js / Ammo.js

    • 添加重力、碰撞检测:

      import * as CANNON from 'cannon-es';
      const world = new CANNON.World({ gravity: new CANNON.Vec3(0, -9.82, 0) });

14. 与其他库结合

  • dat.GUI

    • 快速创建调试控制面板:

      import * as dat from 'dat.gui';
      const gui = new dat.GUI();
      gui.add(cube.position, 'x', -5, 5).name('X 轴位置');


五、学习路线建议

1. 初级阶段(1-2 周)

  • 掌握 Three.js 核心三要素(Scene、Camera、Renderer)。

  • 熟悉基础几何体和材质。

  • 实现简单动画(旋转、平移)。

2. 中级阶段(1-2 个月)

  • 加载外部 3D 模型(GLTF)。

  • 添加交互(点击、拖拽)。

  • 学习光照和阴影。

3. 高级阶段(2-3 个月)

  • 编写自定义着色器(GLSL)。

  • 集成物理引擎(Cannon.js)。

  • 优化性能(InstancedMesh、LOD)。

4. 实战项目

  • 初级:3D 旋转立方体 + 交互。

  • 中级:3D 产品展示页(模型加载 + 光照)。

  • 高级:第一人称视角游戏(物理碰撞 + 动画)。


六、资源推荐

  • 官方文档

    • Three.js Docs

  • 学习平台

    • Three.js Journey(付费系统课程)

    • YouTube 免费教程(Bruno Simon、SimonDev)。

  • 模型资源

    • Sketchfab、TurboSquid。

通过这个知识框架,你可以逐步掌握 Three.js 的核心技术,并进阶到复杂 3D 应用的开发!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2375932.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

HTML、CSS 和 JavaScript 基础知识点

HTML、CSS 和 JavaScript 基础知识点 一、HTML 基础 1. HTML 文档结构 <!DOCTYPE html> <html lang"zh-CN"> <head><meta charset"UTF-8"><meta name"viewport" content"widthdevice-width, initial-scale1.…

数据结构与算法分析实验12 实现二叉查找树

实现二叉查找树 1、二叉查找树介绍2.上机要求3.上机环境4.程序清单(写明运行结果及结果分析)4.1 程序清单4.1.1 头文件 TreeMap.h 内容如下&#xff1a;4.1.2 实现文件 TreeMap.cpp 文件内容如下&#xff1a;4.1.3 源文件 main.cpp 文件内容如下&#xff1a; 4.2 实现展效果示5…

使用 Semantic Kernel 调用 Qwen-VL 多模态模型

使用 Semantic Kernel 调用 Qwen-VL 多模态模型 一、引言 随着人工智能技术的不断发展&#xff0c;多模态模型逐渐成为研究的热点。Qwen-VL 是阿里云推出的大规模视觉语言模型&#xff0c;支持图像、文本等多种输入形式&#xff0c;并能够进行图像描述、视觉问答等多种任务。…

(4)python开发经验

文章目录 1 使用ctypes库调用2 使用pybind11 更多精彩内容&#x1f449;内容导航 &#x1f448;&#x1f449;Qt开发 &#x1f448;&#x1f449;python开发 &#x1f448; 1 使用ctypes库调用 说明&#xff1a;ctypes是一个Python内置的库&#xff0c;可以提供C兼容的数据类型…

深度剖析 GpuGeek 实例:GpuGeek/Qwen3-32B 模型 API 调用实践与性能测试洞察

深度剖析 GpuGeek 实例&#xff1a;GpuGeek/Qwen3-32B 模型 API 调用实践与性能测试洞察 前言 GpuGeek专注于人工智能与高性能计算领域的云计算平台&#xff0c;致力于为开发者、科研机构及企业提供灵活、高效、低成本的GPU算力资源。平台通过整合全球分布式数据中心资源&#…

MindSpore框架学习项目-ResNet药物分类-数据增强

目录 1.数据增强 1.1设置运行环境 1.1.1数据预处理 数据预处理代码解析 1.1.2数据集划分 数据集划分代码说明 1.2数据增强 1.2.1创建带标签的可迭代对象 1.2.2数据预处理与格式化&#xff08;ms的data格式&#xff09; 从原始图像数据到 MindSpore 可训练 / 评估的数…

【MySQL】别名设置与使用

个人主页&#xff1a;Guiat 归属专栏&#xff1a;MySQL 文章目录 1. 别名基础概念2. 列别名设置2.1 基础语法2.2 特殊字符处理2.3 计算字段示例 3. 表别名应用3.1 基础表别名3.2 自连接场景 4. 高级别名技术4.1 子查询别名4.2 CTE别名 5. 别名执行规则5.1 作用域限制5.2 错误用…

【内网渗透】——S4u2扩展协议提权以及KDC欺骗提权

【内网渗透】——S4u2扩展协议提权以及KDC欺骗提权 文章目录 【内网渗透】——S4u2扩展协议提权以及KDC欺骗提权[toc]一&#xff1a;Kerberos 委派攻击原理之 S4U2利用1.1原理1.2两种扩展协议**S4U2Self (Service for User to Self)****S4U2Proxy (Service for User to Proxy)*…

Linux——CMake的快速入门上手和保姆级使用介绍、一键执行shell脚本

目录 一、前言 二、CMake简介 三、CMake与其他常见的构建、编译工具的联系 四、CMake入门 1、CMake的使用注意事项 2、基本的概念和术语 3、CMake常用的预定义变量 4、CMakeLists.txt文件的基本结构 五、上手实操 1、示例 ​编辑 2、一个正式的工程构建 2.1基本构…

如何高效集成MySQL数据到金蝶云星空

MySQL数据集成到金蝶云星空&#xff1a;SC采购入库-深圳天一-OK案例分享 在企业信息化建设中&#xff0c;数据的高效流转和准确对接是实现业务流程自动化的关键。本文将聚焦于一个具体的系统对接集成案例——“SC采购入库-深圳天一-OK”&#xff0c;详细探讨如何通过轻易云数据…

通过POI实现对word基于书签的内容替换、删除、插入

一、基本概念 POI&#xff1a;即Apache POI&#xff0c; 它是一个开源的 Java 库&#xff0c;主要用于读取 Microsoft Office 文档&#xff08;Word、Excel、PowerPoint 等&#xff09;&#xff0c;修改 或 生成 Office 文档内容&#xff0c;保存 为对应的二进制或 XML 格式&a…

FlashInfer - 测试的GPU H100 SXM、A100 PCIe、RTX 6000 Ada、RTX 4090

FlashInfer - 测试的GPU H100 SXM、A100 PCIe、RTX 6000 Ada、RTX 4090 flyfish GPU 技术参数术语 1. Memory bandwidth (GB/s) 中文&#xff1a;显存带宽&#xff08;单位&#xff1a;GB/秒&#xff09; 定义&#xff1a;显存&#xff08;GPU 内存&#xff09;与 GPU 核心…

MongoDB从入门到实战之Windows快速安装MongoDB

前言 本章节的主要内容是在 Windows 系统下快速安装 MongoDB 并使用 Navicat 工具快速连接。 MongoDB从入门到实战之MongoDB简介 MongoDB从入门到实战之MongoDB快速入门 MongoDB从入门到实战之Docker快速安装MongoDB 下载 MongoDB 安装包 打开 MongoDB 官网下载页面&…

Excelize 开源基础库发布 2.9.1 版本更新

Excelize 是 Go 语言编写的用于操作 Office Excel 文档基础库&#xff0c;基于 ECMA-376&#xff0c;ISO/IEC 29500 国际标准。可以使用它来读取、写入由 Excel、WPS、OpenOffice 等办公软件创建的电子表格文档。支持 XLAM / XLSM / XLSX / XLTM / XLTX 等多种文档格式&#xf…

Profibus DP主站转Modbus RTU/TCP网关接艾默生流量计与上位机通讯

Profibus DP主站转Modbus RTU/TCP网关接艾默生流量计与上位机通讯 艾默生流量计与Profibus DP主站转Modbus RTU/TCP网关的通讯&#xff0c;是现代工业自动化中的一个关键环节。为了实现这一过程&#xff0c;我们需要了解一些基础概念和具体操作方法。 在工业自动化系统中&…

Linux proc文件系统 内存影射

文章目录 常见的内存分配函数/proc/pid/ 目录解析 用户进程的内存空间分配算法mmap 分配大内存可能不在堆中换为 malloc 现象相同 常见的内存分配函数 malloc / calloc / realloc&#xff08;来自 C 标准库&#xff09; void *malloc(size_t size)&#xff1a;分配 size 字节…

五、Hadoop集群部署:从零搭建三节点Hadoop环境(保姆级教程)

作者&#xff1a;IvanCodes 日期&#xff1a;2025年5月7日 专栏&#xff1a;Hadoop教程 前言&#xff1a; 想玩转大数据&#xff0c;Hadoop集群是绕不开的一道坎。很多小伙伴一看到集群部署就头大&#xff0c;各种配置、各种坑。别慌&#xff01;这篇教程就是你的“救生圈”。 …

电流检测放大器的优质选择XBLW-INA180/INA181

前言&#xff1a; 在当前复杂的国际贸易环境下&#xff0c;关税的增加使得电子元器件的采购成本不断攀升&#xff0c;电子制造企业面临着巨大的成本压力。为了有效应对这一挑战&#xff0c;实现国产化替代已成为众多企业降低生产成本、保障供应链稳定的关键战略。对此芯伯乐推出…

# 深度剖析LLM的“大脑”:单层Transformer的思考模式探索

简单说一下哈 —— 咱们打算训练一个单层 Transformer 加上稀疏自编码器的小型百万参数大型语言模型&#xff08;LLM&#xff09;&#xff0c;然后去调试它的思考过程&#xff0c;看看这个 LLM 的思考和人类思考到底有多像。 LLMs 是怎么思考的呢&#xff1f; 开源 LLM 出现之后…

【C++】类与对象【下】

文章目录 再谈构造函数构造函数的赋值构造函数体赋值&#xff1a;初始化列表explicit关键字 static成员概念特性 C11中成员初始化的新玩法友元友元类 内部类概念 再谈构造函数 构造函数的赋值 构造函数体赋值&#xff1a; 在创建对象时&#xff0c;编译器会通过调用构造函数…