Three.js从小白到实战,学不会的同学有救了!

2023-11-11 03:20

本文主要是介绍Three.js从小白到实战,学不会的同学有救了!,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

一、案例结构

第 1 章,介绍

介绍了在创建新方法时可以使用的基本方法。基于three.js 的应用程序。我们将向您展示如何设置一个基本的 Three.js 骨架使用任何可用的 Three.js 渲染器。我们将进一步向您展示 WebGL 检测、加载资源,设置动画循环,添加拖放支持,并控制键盘的场景。

欢迎加V-X获得源码:liweb2022

WebGL 渲染器入门

开始使用画布渲染器

CSS 3D 渲染器入门

检测 WebGL 支持

设置动画循环

确定场景的帧速率

控制场景中使用的变量

使用 Python 设置本地 Web 服务器

使用 Node.js 设置本地 Web 服务器

使用 Mongoose 设置本地 Web 服务器

解决 Chrome 中的跨域域错误消息

解决 Firefox 中的跨域错误消息

添加键盘控件

异步加载纹理

异步加载模型

与进度异步加载模型

与进度异步加载其他资源

等到资源加载完毕

将文件从桌面拖到场景中

第 2 章几何和网格

向您展示了一些专注于创建的食谱,使用和操作几何图形和网格。我们将详细介绍如何以不同方式旋转网格,使用矩阵变换操作它们,生成以编程方式生成几何图形,并从 Blender 和其他格式加载模型。

围绕自己的轴旋转对象

围绕空间中的一个点旋转对象

通知 Three.js 更新

处理大量对象

从高度图创建几何图形

将一个对象指向另一个对象

以 3D 形式书写文本

将 3D 公式渲染为 3D 几何图形

使用自定义几何对象扩展 Three.js

在两点之间创建样条曲线

从 Blender 创建和导出模型

使用带有多种材质的 OBJMTLLoader

应用矩阵变换

第 3 章,使用 相机

重点 介绍 操作 相机 的 方法 .在 Three.js 中可用。它向您展示了如何使用透视和正交相机。本章还向您展示了解释如何旋转相机、居中相机,并跟随周围的物体。

使相机跟随物体

将相机缩放到对象

使用透视相机

使用正交相机

创建 2D 叠加

围绕场景旋转相机

将渲染视图与调整大小的浏览器匹配

将世界坐标转换为屏幕坐标

选择场景中的对象

第 4 章材料和纹理

包含说明如何获得良好结果的方法使用 Three.js 提供的材料。它有关于透明度、反射、UV贴图、面部材质、凹凸贴图和法线贴图,还解释了各种混合模式工作。

使用凹凸贴图为网格添加深度

使用法线贴图为网格添加深度

使用 HTML 画布作为纹理

使用 HTML 视频作为纹理

创建具有多种材质的网格

对面使用单独的材质

设置重复纹理

使对象的一部分透明

使用立方体贴图创建反射材质

使用动态立方体贴图创建反射材质

使用 Blender 创建自定义 UV 映射

配置混合模式

为固定阴影使用阴影贴图

第 5 章灯光和自定义着色器

提供了处理Three.js 中的不同光源并向您展示如何使用 WebGL 着色器。表明您如何正确设置阴影,创建类似太阳的光源,并进入聚光灯、点光源和定向光源之间的区别。在本章中,我们还将为您提供了一些说明如何创建自定义顶点着色器和自定义片段着色器。

使用 THREE.SpotLight 创建阴影

使用 THREE.DirectionalLight 创建阴影

通过添加环境照明来柔化灯光

使用 THREE.HemisphereLight 进行自然采光

添加移动的全方位灯光

沿路径移动光源

使光源跟随物体

创建自定义顶点着色器

创建自定义片段着色器

第 6 章点云和后处理

为您提供了一些秘诀,向您展示如何设置后处理。通过后处理,您可以通过模糊增强场景,着色或其他类型的效果。本章还包含解释功能的秘诀粒子系统,例如动画和粒子材质。

基于几何创建点云

从头开始创建点云

为点云中的单个点着色

样式化单个点

移动点云的各个点

爆炸点云

设置基本的后处理管道

创建自定义后处理步骤

将 WebGL 输出保存到磁盘

第 7 章,动画 和 物理
 向 你 展示 一些 帮助 你 制作 动画 的 食谱 .场景中的对象并向您展示如何添加物理(例如重力和碰撞)检测)到您的场景。

使用 Tween.js 创建动画

使用变形目标的动画

骨骼动画

使用在 Blender 中创建的变形动画

使用在 Blender 中创建的骨架动画

添加简单的碰撞检测

在 Chrome 中保存动画电影

在场景周围拖放对象

添加物理引擎

二、源码案例截图

电子书+代码

截图:

案例截图

哪些人需要这个案例集:

1、从事Web前端开发想转三维开发的技术同学;

2、想对自己的技术壁垒再提升一个级别的同学;

3、未来想事数字孪生的同学;

4、想对三维技术进行研究不知道从哪里开始的入门。

需要什么条件:

1、前端开发基础熟悉html+css+js,能写基本的网页页面;

2、html+css+js零基础不建议学,如果学的话先学html+css+js。

这篇关于Three.js从小白到实战,学不会的同学有救了!的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/387188

相关文章

网页解析 lxml 库--实战

lxml库使用流程 lxml 是 Python 的第三方解析库,完全使用 Python 语言编写,它对 XPath表达式提供了良好的支 持,因此能够了高效地解析 HTML/XML 文档。本节讲解如何通过 lxml 库解析 HTML 文档。 pip install lxml lxm| 库提供了一个 etree 模块,该模块专门用来解析 HTML/XML 文档,下面来介绍一下 lxml 库

JS常用组件收集

收集了一些平时遇到的前端比较优秀的组件,方便以后开发的时候查找!!! 函数工具: Lodash 页面固定: stickUp、jQuery.Pin 轮播: unslider、swiper 开关: switch 复选框: icheck 气泡: grumble 隐藏元素: Headroom

性能分析之MySQL索引实战案例

文章目录 一、前言二、准备三、MySQL索引优化四、MySQL 索引知识回顾五、总结 一、前言 在上一讲性能工具之 JProfiler 简单登录案例分析实战中已经发现SQL没有建立索引问题,本文将一起从代码层去分析为什么没有建立索引? 开源ERP项目地址:https://gitee.com/jishenghua/JSH_ERP 二、准备 打开IDEA找到登录请求资源路径位置

在JS中的设计模式的单例模式、策略模式、代理模式、原型模式浅讲

1. 单例模式(Singleton Pattern) 确保一个类只有一个实例,并提供一个全局访问点。 示例代码: class Singleton {constructor() {if (Singleton.instance) {return Singleton.instance;}Singleton.instance = this;this.data = [];}addData(value)

C#实战|大乐透选号器[6]:实现实时显示已选择的红蓝球数量

哈喽,你好啊,我是雷工。 关于大乐透选号器在前面已经记录了5篇笔记,这是第6篇; 接下来实现实时显示当前选中红球数量,蓝球数量; 以下为练习笔记。 01 效果演示 当选择和取消选择红球或蓝球时,在对应的位置显示实时已选择的红球、蓝球的数量; 02 标签名称 分别设置Label标签名称为:lblRedCount、lblBlueCount

滚雪球学Java(87):Java事务处理:JDBC的ACID属性与实战技巧!真有两下子!

咦咦咦,各位小可爱,我是你们的好伙伴——bug菌,今天又来给大家普及Java SE啦,别躲起来啊,听我讲干货还不快点赞,赞多了我就有动力讲得更嗨啦!所以呀,养成先点赞后阅读的好习惯,别被干货淹没了哦~ 🏆本文收录于「滚雪球学Java」专栏,专业攻坚指数级提升,助你一臂之力,带你早日登顶🚀,欢迎大家关注&&收藏!持续更新中,up!up!up!! 环境说明:Windows 10

Node.js学习记录(二)

目录 一、express 1、初识express 2、安装express 3、创建并启动web服务器 4、监听 GET&POST 请求、响应内容给客户端 5、获取URL中携带的查询参数 6、获取URL中动态参数 7、静态资源托管 二、工具nodemon 三、express路由 1、express中路由 2、路由的匹配 3、路由模块化 4、路由模块添加前缀 四、中间件

EasyPlayer.js网页H5 Web js播放器能力合集

最近遇到一个需求,要求做一款播放器,发现能力上跟EasyPlayer.js基本一致,满足要求: 需求 功性能 分类 需求描述 功能 预览 分屏模式 单分屏(单屏/全屏) 多分屏(2*2) 多分屏(3*3) 多分屏(4*4) 播放控制 播放(单个或全部) 暂停(暂停时展示最后一帧画面) 停止(单个或全部) 声音控制(开关/音量调节) 主辅码流切换 辅助功能 屏

使用JS/Jquery获得父窗口的几个方法(笔记)

<pre name="code" class="javascript">取父窗口的元素方法:$(selector, window.parent.document);那么你取父窗口的父窗口的元素就可以用:$(selector, window.parent.parent.document);如题: $(selector, window.top.document);//获得顶级窗口里面的元素 $(

js异步提交form表单的解决方案

1.定义异步提交表单的方法 (通用方法) /*** 异步提交form表单* @param options {form:form表单元素,success:执行成功后处理函数}* <span style="color:#ff0000;"><strong>@注意 后台接收参数要解码否则中文会导致乱码 如:URLDecoder.decode(param,"UTF-8")</strong></span>