threejs学习(一)概况

1.概况

之前粗略入门了一下计算机图形学和webgl,还有很多很多概念都没有涉及到,不过不影响学习新的工具threejs。它是一个帮助你绘制图像的工具库,封装了底层的webgl操作。学习的时候还是要谨记,threejs只是工具,真正的基础还是计算机图形学的东西。

2. 关于这个专栏

由于我之前浅浅得学习了一下 webgl,所以有的概念不会再次解释。这个专栏也就是我个人的学习总结。

3. 初识threejs

构建第一个例子很简单,安装、引入、官网例子。

ts 复制代码
import * as THREE from 'three';

// 创建一个场景
const scene = new THREE.Scene();
// 设置透视摄像机
const camera = new THREE.PerspectiveCamera( 75, 1, 0.1, 1000 );

// 创建渲染器
const renderer = new THREE.WebGLRenderer();
renderer.setSize( 800, 800 );
document.body.appendChild( renderer.domElement );

// 创建一个几何图形
const geometry = new THREE.BoxGeometry( 1, 1, 1 );
const material = new THREE.MeshBasicMaterial( { color: 0x00ff00 } );
const cube = new THREE.Mesh( geometry, material );
scene.add( cube );

camera.position.z = 5;

// 不停渲染这个图像
function animate() {
	requestAnimationFrame( animate );
	renderer.render( scene, camera );
}
animate();

上面的的代码都是复制的官网的,具体什么含义先不用管,执行之后会出现一个绿色额方块。

这个看起来是二维的,实际上它是立体的,只是我们相机的位置不对,正对着这个立方体看起来就像是平面的。

4. 轨道控制器OrbitControls

顾名思义,就像电影拍摄中,将相机放到固定的轨道上就能实现视角的变动。

ts 复制代码
import * as THREE from 'three';
import { OrbitControls } from 'three/examples/jsm/controls/OrbitControls';

const scene = new THREE.Scene();
const camera = new THREE.PerspectiveCamera( 75, window.innerHeight /window.innerHeight, 0.1, 1000 );
// 添加一个坐标轴
const axesHelper = new THREE.AxesHelper( 2 );
scene.add( axesHelper );

const geometry = new THREE.BoxGeometry( 1, 1, 1 );
const material = new THREE.MeshBasicMaterial( { color: 0x881a1a } );
const cube = new THREE.Mesh( geometry, material );
scene.add( cube );

camera.position.z = 5;



const renderer = new THREE.WebGLRenderer();
renderer.setSize( 800, 800 );
document.body.appendChild( renderer.domElement );
// 控制器
const controls = new OrbitControls( camera, renderer.domElement );
function animate() {
  requestAnimationFrame( animate );
  // 如果使用了自动旋转什么的,就需要不停更新控制器状态
  controls.update();
  renderer.render( scene, camera );
}
animate();

这样就可以自由转动视角了

还可以给控制器加上一点阻尼效果

ts 复制代码
controls.enableDamping = true;

5.物体运动

设置物体运动也很简单

ts 复制代码
const geometry = new THREE.BoxGeometry( 1, 1, 1 );
const material = new THREE.MeshBasicMaterial( { color: 0x881a1a } );
const cube = new THREE.Mesh( geometry, material );
scene.add( cube );
// 平移
cube.position.set(2, 0, 0)
// 某一项平移
cube.position.setX(2)
// 直接设置也可以
cube.position.x = 2
// 缩放
cube.scale.set(2, 1, 1)
// 旋转,注意是弧度
cube.rotation.set(Math.PI / 4, 0 ,0)

6. 总结

可以看出,比起自己手动用webgl写代码简单了很多,连着色器都省略了。要我运用之前学的知识实现这个阻尼效果那都要费劲半天。

不过计算机图形的基础仍然是最重要的,对于优化和理解一些效果很有帮助。

相关推荐
答案—answer1 小时前
three.js编辑器2.0版本
javascript·three.js·three.js 编辑器·three.js性能优化·three.js模型编辑·three.js 粒子特效·three.js加载模型
Coffeeee6 小时前
Threejs粒子动效之龙卷风
前端·three.js·动效
Mintopia7 小时前
Three.js 画布纹理:像素世界的魔法编织术
前端·javascript·three.js
答案answer7 小时前
three.js 实现几个炫酷的粒子特效(火焰,烟雾,烟花)
前端·three.js
康康的幸福生活1 天前
webgl2 方法解析: bufferData()
webgl
xhload3d1 天前
智慧航天运载体系全生命周期监测 | 图扑数字孪生
物联网·3d·智慧城市·html5·webgl·数字孪生·可视化·工业互联网·三维建模·工控·航空航天·火箭升空·智慧航空·智慧航天·火箭发射·火箭回收
魂断蓝桥6661 天前
使用three.js,实现微信3D小游戏系列教程,框架篇(一)
webgl·threejs·微信小游戏·3d建筑·three.js路径规划、三维a*算法、javascript三维导航,·three.js小游戏
Mintopia1 天前
Three.js ArrowHelper:三维世界里的 “方向向导”
前端·javascript·three.js
三维搬砖者2 天前
基于 Three.js 开发三维引擎-02动态圆柱墙体实现
three.js
小桥风满袖2 天前
Three.js-硬要自学系列38之专项学习缓冲几何体
前端·css·three.js