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

相关推荐
llrraa20104 分钟前
python whisper生成字幕
开发语言·python·whisper
努力努力再努力wz7 分钟前
【c++进阶系列】:万字详解多态
java·linux·运维·开发语言·c++
秦亿凡11 分钟前
多线程下为什么用ConcurrentHashMap而不是HashMap
java·开发语言
阿波罗尼亚36 分钟前
ExcelUtils实现 设置内容 插入行 复制行列格式
java·开发语言
changuncle44 分钟前
Angular初学者入门第三课——工厂函数(精品)
前端·javascript·angular.js
日月晨曦1 小时前
JavaScript事件循环:一次浏览器线程的"约会"指南
javascript
s3xysteak1 小时前
我要成为vue高手01:上下文
前端·javascript·vue.js
南篱1 小时前
JavaScript原型链没那么难:一文彻底搞懂
javascript·面试
程序员张31 小时前
Vue3+ElementPlus倒计时示例
javascript·vue.js·前端框架
专注VB编程开发20年1 小时前
c# .net支持 NativeAOT 或 Trimming 的库是什么原理
前端·javascript·c#·.net