Three.js 基础概念:构建3D世界的核心要素

文章目录

    • 前言
    • 一、场景(Scene)
    • 二、相机(Camera)
    • 三、渲染器(Renderer)
    • 四、物体(Object)
    • 五、材质(Material)
    • 六、几何体(Geometry)
    • 七、光源(Light)
    • 结语


前言

在数字化时代的浪潮中,Three.js 作为一款强大的 JavaScript 库,使得开发者能够轻松地将逼真的三维图形带入网页。对于初学者来说,理解 Three.js 的核心概念是掌握这个库的关键第一步。本文将深入探讨这些基础概念,帮助你为创建自己的3D项目打下坚实的基础。


一、场景(Scene)

场景就像是一个舞台,所有3D元素都在这里共存。它是容纳几何体、光源、相机等所有对象的容器。在 Three.js 中,场景通过 THREE.Scene() 构造函数创建:

const scene = new THREE.Scene();

一旦有了场景,我们就可以开始向其中添加各种元素,从而构建出想要展示的世界。

二、相机(Camera)

为了看到场景中的内容,我们需要一个“眼睛”,这就是相机的作用。Three.js 提供了两种主要类型的相机:透视相机 (THREE.PerspectiveCamera) 和正交相机 (THREE.OrthographicCamera)。透视相机模仿了人眼观察世界的自然方式,而正交相机则提供了平行投影,常用于 CAD 软件和某些类型的游戏。

创建一个透视相机时,你需要指定视场角(FOV)、宽高比(aspect ratio)、近裁剪面(near clipping plane)和远裁剪面(far clipping plane)。这些参数决定了相机如何捕捉场景以及哪些部分会被渲染到屏幕上。

const camera = new THREE.PerspectiveCamera(75, window.innerWidth / window.innerHeight, 0.1, 1000);
camera.position.set(0, 0, 5); // 设置相机位置

三、渲染器(Renderer)

渲染器的任务是把场景和相机的信息转化为可以显示在屏幕上的图像。Three.js 支持多种渲染技术,但最常用的是 WebGL 渲染器 (THREE.WebGLRenderer),因为它利用了现代 GPU 的强大性能,可以高效地处理复杂的图形。

要使用 WebGL 渲染器,首先要创建一个实例,并设置其尺寸以匹配浏览器窗口大小。然后,需要将渲染器的 DOM 元素添加到页面上,以便它能够正确显示输出。

const renderer = new THREE.WebGLRenderer({ antialias: true });
renderer.setSize(window.innerWidth, window.innerHeight);
document.body.appendChild(renderer.domElement);

四、物体(Object)

物体是 Three.js 场景中最基本的组成部分之一。它们可以是几何形状、光源、甚至是其他更复杂的实体。每个物体都继承自 THREE.Object3D 类,这意味着它们共享相同的基本属性和方法,如位置、旋转和缩放。

要创建一个物体,通常需要先定义它的几何形状和材质,然后通过 THREE.Mesh 将两者组合起来形成一个网格。最后,将网格添加到场景中即可。

const geometry = new THREE.BoxGeometry(); // 创建几何体
const material = new THREE.MeshBasicMaterial({ color: 0x00ff00 }); // 创建材质
const cube = new THREE.Mesh(geometry, material); // 创建网格
scene.add(cube); // 添加到场景

五、材质(Material)

材质定义了物体表面的外观,包括颜色、纹理、反射特性等。Three.js 提供了多种预定义的材质类型,每种都有不同的视觉效果。例如,MeshBasicMaterial 不考虑光照条件,总是以指定的颜色显示;而 MeshStandardMaterial 则能与光源互动,产生更加真实的阴影和高光效果。

// 使用 MeshStandardMaterial 可以实现更真实的光照效果
const material = new THREE.MeshStandardMaterial({ color: 0x00ff00 });

六、几何体(Geometry)

几何体决定了物体的形状。Three.js 内置了许多常用的几何体构造函数,如球体、平面、立方体等,同时也支持自定义几何体的创建。几何体可以通过顶点和面来描述,这使得开发者可以根据需求灵活地设计物体形态。

const geometry = new THREE.SphereGeometry(1, 32, 32); // 创建球体几何体

七、光源(Light)

没有光源,即使是使用了光照敏感型材质的物体也无法被照亮。Three.js 提供了不同类型的光源来模拟现实世界的光照环境。方向光(THREE.DirectionalLight)、点光源(THREE.PointLight)、聚光灯(THREE.SpotLight)等都能用来营造丰富的光影效果。

const light = new THREE.DirectionalLight(0xffffff, 1); // 创建方向光
light.position.set(5, 5, 5).normalize(); // 设置光源位置
scene.add(light); // 添加到场景

结语

上述六大基础概念——场景、相机、渲染器、物体、材质和光源,构成了 Three.js 的核心框架。了解并熟练运用这些概念,不仅能帮助你快速入门 Three.js,还能为未来探索更高级的主题铺平道路。无论是制作交互式网站还是开发复杂的游戏,掌握好这些基础知识都是至关重要的。希望这篇文章能够成为你学习 Three.js 的良好起点,激发你对3D编程的热情和创造力。

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

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【开源免费】基于Vue和SpringBoot的贸易行业crm系统(附论文)

本文项目编号 T 153 ,文末自助获取源码 \color{red}{T153,文末自助获取源码} T153,文末自助获取源码 目录 一、系统介绍二、数据库设计三、配套教程3.1 启动教程3.2 讲解视频3.3 二次开发教程 四、功能截图五、文案资料5.1 选题背景5.2 国内…

仓库叉车高科技安全辅助设备——AI防碰撞系统N2024G-2

在当今这个高效运作、安全第一的物流时代,仓库作为供应链的中心地带,其安全与效率直接关系到企业的命脉。 随着科技的飞速发展,传统叉车作业模式正逐步向智能化、安全化转型,而在这场技术革新中,AI防碰撞系统N2024G-2…

如何打开/处理大型dat文件?二进制格式.dat文件如何打开?Python读取.dat文件

背景&#xff1a; 希望查看C语言输出的二进制DAT文件&#xff0c;写入方式如下&#xff08;如果是视频或游戏&#xff0c;未必能使用这种方式打开&#xff0c;关键是需要知道数据的格式&#xff09; # 写入二进制的C语言fp fopen(str, "wb");for (int i 0; i < …

面向对象分析与设计Python版 活动图与类图

文章目录 一、活动图二、类图 一、活动图 活动图 活动图用于描述业务流程、工作流程或算法中的控制流。活动图强调的是流程中的各个步骤的先后顺序&#xff0c;它可以帮助系统分析师、设计师和程序员更好地理解系统的动态行为。 活动图与用例模型互为补充&#xff0c;主要用于…

51单片机——步进电机模块

直流电机没有正负之分&#xff0c;在两端加上直流电就能工作 P1.0-P1.3都可以控制电机&#xff0c;例如&#xff1a;使用P1.0&#xff0c;则需要把线接在J47的1&#xff08;VCC&#xff09;和2&#xff08;OUT1&#xff09;上 1、直流电机实验 要实现的功能是&#xff1a;直…

2024AAAI SCTNet论文阅读笔记

文章目录 SCTNet: Single-Branch CNN with Transformer Semantic Information for Real-Time Segmentation摘要背景创新点方法Conv-Former Block卷积注意力机制前馈网络FFN 语义信息对齐模块主干特征对齐共享解码头对齐 总体架构backbone解码器头 对齐损失 实验SOTA效果对比Cit…

数字IC设计高频面试题

在数字IC设计领域&#xff0c;面试是评估候选人技术能力和问题解决能力的重要环节。数字IC设计的复杂性和要求在不断提高。面试官通常会提出一系列面试题&#xff0c;以考察应聘者在数字设计、验证、时钟管理、功耗优化等方面的专业知识和实践经验。 这些题目不仅涉及理论知识…

Functions

1.trigonometric function 定义和图像 反三角函数是三角函数的反函数 versin(verse -sin)&#xff1a;1/sinx 性质 三角函数的公式 三角恒等式 周期性公式&#xff1a;直接画图记 公式记忆&#xff1a;先想象一个在第一象限的锐角 1&#xff1a;在坐标轴中旋转360 2.sin&am…

1/7 C++

练习&#xff1a;要求在堆区连续申请5个int的大小空间用于存储5名学生的成绩&#xff0c;分别完成空间的申请、成绩的录入、升序排序、成绩输出函数&#xff0c;并在主程序中完成测试 要求使用new #include <iostream>using namespace std; double *addr_new() {double …

[文献精汇]使用PyCaret预测 Apple 股价

介绍 开发一个机器学习模型来尝试通过线性回归分析来预测 Apple 股票的价格会很有趣。PyCaret 的库&#xff0c;这是一个开源的 Python 低代码机器学习库&#xff0c;可以自动化机器学习工作流程&#xff0c;非常适合像我这样的机器学习初学者。 线性回归分析 线性回归分析用…

【51单片机】02LED流水灯实验

点亮你的LED 一、点亮第一个LED1.GPIO介绍2.P1、P2、P3端口 二、LED实验2.尝试点亮LED3.LED流水灯 一、点亮第一个LED 1.GPIO介绍 这块内容这里可以做简单的了解&#xff0c;与数电知识强相关。后续可以再回过头来学习 GPIO (general purpose input output) 通用输入输出端口…

「Mac畅玩鸿蒙与硬件53」UI互动应用篇30 - 打卡提醒小应用

本篇教程将实现一个打卡提醒小应用&#xff0c;通过用户输入时间进行提醒设置&#xff0c;并展示实时提醒状态&#xff0c;实现提醒设置和取消等功能。 关键词 打卡提醒状态管理定时任务输入校验UI交互 一、功能说明 打卡提醒小应用包含以下功能&#xff1a; 提醒时间输入与…

Python递归(汉诺塔问题)

递归分析 递归&#xff1a;通过自我调用来解决问题的函数 递归通常把一个大型复杂的问题层层转化为一个与原问题相似的规模较小的问题来求解。 递归要注意&#xff1a; 1.递归出口 2.当前问题如何变成子问题 利用递归写一个阶乘函数&#xff0c;F(n)&#xff0c;求n的阶乘…

VS2022 C#创建Com组件和调用

生成一个类库项目 这里创建了一个.net 4.8的项目&#xff0c;添加了一个ComAIFaceTest类 如下图&#xff1a; ComAIFaceTest代码如下&#xff1a; [ComVisible(true)][Guid("12345678-ABCD-1234-EF00-0123456789AB")][ClassInterface(ClassInterfaceType.AutoDual)…

【GOOD】A Survey of Deep Graph Learning under Distribution Shifts

深度图学习在分布偏移下的综述&#xff1a;从图的分布外泛化到自适应 Northwestern University, USA Repository Abstract 图上的分布变化——训练和使用图机器学习模型之间的数据分布差异——在现实世界中普遍存在&#xff0c;并且通常不可避免。这些变化可能会严重恶化模…

ARM发布Armv9.5架构:迈向更强性能与灵活性的新时代

2024年11月30日&#xff0c;ARM正式发布了其最新的Armv9.5架构&#xff0c;这是Arm技术发展的又一重要里程碑。从表中信息来看&#xff0c;Armv9.5架构的发布标志着该公司的架构系列在性能、灵活性和可扩展性方面取得了进一步突破。本次发布不仅是技术上的提升&#xff0c;更是…

RAFT:随机退火森林

RAFT:随机退火森林 RAFT(Randomized Annealed Forests)是一种机器学习算法,主要用于分类和回归任务。以下是对它的介绍及原理举例说明: 一、RAFT简介 RAFT是一种基于随机森林的集成学习方法,它结合了随机森林的优点和退火算法的思想。随机森林通过构建多个决策树并综…

“AI智慧语言训练系统:让语言学习变得更简单有趣

大家好&#xff0c;我是你们的老朋友&#xff0c;一个热衷于探讨科技与教育结合的产品经理。今天&#xff0c;我想和大家聊聊一个让语言学习变得不再头疼的话题——AI智慧语言训练系统。这个系统可是我们语言学习者的福音&#xff0c;让我们一起来揭开它的神秘面纱吧&#xff0…

自动驾驶相关知识学习笔记

一、概要 因为想知道SIL、HIL是什么仿真工具&#xff0c;故而浏览了自动驾驶相关的知识。 资料来源《自动驾驶——人工智能理论与实践》胡波 林青 陈强 著&#xff1b;出版时间&#xff1a;2023年3月 二、图像的分类、分割与检测任务区别 如图所示&#xff0c;这些更高阶的…