three.js环境及使用教程

开发环境

bash 复制代码
npm i three@0.156.1
npm i @types/three@0.156.0

入门代码

index.html

xml 复制代码
<!DOCTYPE html>
<html lang="en">
	<head>
		<meta charset="UTF-8" />
		<meta http-equiv="X-UA-Compatible" content="IE=edge" />
		<meta name="viewport" content="width=device-width, initial-scale=1.0" />
		<title>Document</title>
		<!-- <link rel="stylesheet" href="demo.css" /> -->
		<style>
			body {
				margin: 0;
			}
		</style>
		<!-- 核心依赖 -->
		<script
			async
			src="https://unpkg.com/es-module-shims@1.8.3/dist/es-module-shims.js"
		></script>
		<script type="importmap">
			{
				"imports": {
					"three": "../../node_modules/three/build/three.module.js"
				}
			}
		</script>
	</head>
	<body>
		<script type="module" src="demo.js"></script>
	</body>
</html>

demo.js

js 复制代码
import * as THREE from "three";

//! 场景
const scene = new THREE.Scene();

//! 透视相机(垂直视野角度,长宽比,近端面,远端面)
const camera = new THREE.PerspectiveCamera(
	75,
	window.innerWidth / window.innerHeight,
	0.1,
	1000
);
camera.position.z = 5;

//! 渲染器
const renderer = new THREE.WebGLRenderer();
renderer.setSize(window.innerWidth, window.innerHeight);
document.body.appendChild(renderer.domElement);
window.onresize = function () {
	renderer.setSize(window.innerWidth, window.innerHeight);
	//
	camera.setViewOffset(
		window.innerWidth,
		window.innerHeight,
		0,
		0,
		window.innerWidth,
		window.innerHeight
	);
};

//! 线
{
	// 定义材质
	const material = new THREE.LineBasicMaterial({ color: 0x00ff00 });
	// 创建几何体
	const points = [];
	points.push(new THREE.Vector3(-3, 0, 0));
	points.push(new THREE.Vector3(0, 3, 0));
	points.push(new THREE.Vector3(3, 0, 0));
	points.push(new THREE.Vector3(0, -3, 0));
	points.push(new THREE.Vector3(-3, 0, 0));
	const geometry = new THREE.BufferGeometry().setFromPoints(points);
	// 创建 Line
	const line = new THREE.Line(geometry, material);
	// 添加到场景
	scene.add(line);
}

//! 立方体
{
	// 定义材质
	const material = new THREE.MeshBasicMaterial({ color: 0x0ffff0 });
	// 几何对象
	const geometry = new THREE.BoxGeometry(1, 1, 1);
	// 创建 Cube
	const cube = new THREE.Mesh(geometry, material);
	// 添加到场景
	scene.add(cube);
	// 动画效果
	function animate() {
		// 向浏览器发起一个执行某函数的请求(一般默认保持60FPS的频率)
		requestAnimationFrame(animate);
		// 旋转 Cube
		cube.rotation.x += 0.01;
		cube.rotation.y += 0.01;
		// 旋转 Camera
		camera.rotation.z += 0.01;
		// 刷新相机
		renderer.render(scene, camera);
	}
	animate();
}

摄像机(Camer)

TODO

材质(Mesh)

TODO

图层(Layers)

TODO

基本几何图形

TODO

加载3D模型

TODO

相关推荐
烬羽38 分钟前
后端返回的 JSON 字符串,浏览器怎么"看懂"的?——Ajax 全链路拆解
javascript
赴生-1 小时前
C++进阶 异常
开发语言·c++
黄毛火烧雪下1 小时前
Java 核心知识点总结(一)
java·开发语言
半个落月1 小时前
一个新手用 Bun + Axios 调通 DeepSeek API 的实践记录
javascript
其实防守也摸鱼1 小时前
软件安全与漏洞--软件安全编码与防御技术理论题库
开发语言·网络·安全·网络安全·软件安全·软件安全与漏洞
不好听6131 小时前
深入理解链表:线性数据结构的另一面
javascript·数据结构
x138702859571 小时前
c语言中srtlen(指针使用计算字符长度)、传值和传址调用
c语言·开发语言·算法·visual studio
林希_Rachel_傻希希2 小时前
学React治好了我的焦虑症,1小时速通React 前20分钟。
前端·javascript·面试
小林ixn2 小时前
从 Ajax 到异步编程:JSON 序列化、Event Loop 与 XHR 请求完全解析
javascript
iCxhust2 小时前
C#进程管理程序
开发语言·汇编·stm32·单片机·c#·微机原理