【Three.js】初识 Three.js

Threejs介绍

我们开发 webgl 主要是使用 threejs 这个库,因为 webGL太难用,太复杂!但是现代浏览器都支持WebGL,这样我们就不必使用Flash、Java等插件就能在浏览器中创建三维图形。

threejs 它提供-一个很简单的关于WebGL特性的JavaScript API, 使得用户不需要详细地学习webgl ,就能轻松创作出好看的三维图形样例。

webgl 原生的 api 是一种非常低级的接口,而且还需要一些数学和图形学的相关技术。对于没有相关基础的人来说,入门真的很难,Three.js将入门的门槛降低了整整的一大截,对WebGL进行封装,简化我们创建三维

动画场景的过程。

微信小游戏跳一跳也是在Three,js的基础上开发出来的。

Threejs该项目的目的是使用默认的 webgl 渲染器创建一个易于使用,轻量级的3D库。该库还在示例中提供了 Canvas2D,SVG和CSS3D渲染器。

https://github.com/mrdoob/three.js

特点

优势
  1. Three.js掩盖了3D渲染的细节:Three.js将WebGL原生API的细节抽象化,将3D场景拆解为网格、材质和光源,即它内置了图形编程常用的一些对象种类。
  2. 面向对象:开发者可以使用上层的 JavaScript对象,而不是仅仅调用JavaScript函数。
  3. 功能非常丰富:Three.js除了封装了WebGL原始API之外,Three,js还包含了许多实用的内置对象,可以方便地应用于游戏开发、动画制作、幻灯片制作、高分辨率模型和一些特殊的视觉效果制作。
  4. 速度很快:Three.is采用了3D图形最佳实践,来保证在不失可用性的前提下,保持极高的性能。支持交互:webgl 本身并不提供拾取(picking)功能(即是否知道鼠标正处于某个物体上)。而Three.js则固化了拾取支持,这就使得你可以轻松为你的应用添加交互功能。
  5. 包含数学库:Three.is拥有一个强大易用的数学库,你可以在其中进行矩阵、投影和矢量运算。
  6. 内置文件格式支持:你可以使用流行的3D建模软件导出文本格式的文件,然后使用Three.isjs 加载,也可以使用Three.js自己的 json 格式或二进制格式。
  7. 扩展性很强:为Three.js添加新的特性或进行自定义优化是很容易的事情。如果你需要某个特殊的数据结构,那么只需要封装到Three,js即可。
痛点
  1. 官方问的粗糙,对新手不友好
  2. 国内资源匮乏
  3. 如果想要开发游戏,threejs 不是游戏引擎,需要二次开发

与Babylon.js对比:

Babylon.JS是最好的 JavaScript.3D游戏引擎,它能创建专业级三维游戏。主要以游戏开发和易用性为主。与Three,js之间的对比:

  1. Three,js比较全面,而Babylon.js专注于游戏方面。
  2. Babylon.js提供了对碰撞检测、场景重力、面向游戏的照相机Three.js 本身不自带,需要依靠引入插件实现。
  3. 对于WebGL的封装,双方做的各有千秋,Three,js浅一些,好处是易于扩展,易于向更底层学习;Babylon.js深一些,好处是易用扩展难度大一些。
  4. Three.js的发展是依靠社区推动,出来的比较早,发展比较成熟,Babylon.js是由微软公司在2013推出,文档和社区都比较健全,国内还不怎么火。

threejs 在线编辑器:https://threejs.org/editor/

相关推荐
老毛肚1 小时前
jeecg-boot-base-core 02 day
javascript·python
yaoxin5211231 小时前
434. Java 日期时间 API - Period 基于日期的时间段
java·开发语言·python
凡人叶枫2 小时前
Effective C++ 条款30:透彻了解 inlining 的里里外外
linux·开发语言·c++·嵌入式开发·effective c++
学逆向的2 小时前
C++纯虚函数
开发语言·c++·网络安全
程序员二叉3 小时前
【JUC】ThreadLocal底层原理|内存泄漏|弱引用|跨线程传递方案
java·开发语言·面试·职场和发展·juc
程序员二叉3 小时前
【JUC】线程池全套深度详解|参数|流程|拒绝策略|调优|异常处理
java·开发语言·jvm·算法·面试·juc
凡人叶枫3 小时前
Effective C++ 条款22:将成员变量声明为 private
linux·开发语言·c++
Qt程序员3 小时前
掌握 Linux 内核调度:从原理到实现(进程篇)
java·开发语言
code bean3 小时前
【LangChain】检索器完全指南:从向量检索到生产级 RAG 架构
java·开发语言·微服务
LabVIEW开发4 小时前
LabVIEW + MATLAB 混合编程:爆炸场测试数据精准采集方案
开发语言·matlab·labview