Three.js PBR材质简介

参考资料:threejs中文网

threejs qq交流群:814702116

Three.js PBR材质简介

本节课没有具体的代码,就是给大家科普一下PBR材质,所谓PBR就是,基于物理的渲染(physically-based rendering)。

Three.js提供了两个PBR材质相关的APIMeshStandardMaterialMeshPhysicalMaterial,MeshPhysicalMaterialMeshStandardMaterial扩展的子类,提供了更多功能属性。

光照模型

如果你有初高中最基本的物理光学知识,应该有折射、镜面反射、漫反射等基本光学概念,对于实际生活中的光学问题,Three.js会提供一些的光照模型来模拟物体表面的光照,光照模型就一种模拟光照的计算方法。MeshPhysicalMaterialMeshLambertMaterial一样都是渲染网格模型的材质,但是他们用的光照模型不同,具体点说就是材质模拟Mesh反射光照的代码算法不同,算法不同,自然模拟光照的真实程度也不同。

如果你想深入研究光照模型,可以学习下原生WebGL或WebGPU,或者看看计算机图形学相关书籍,使用threejs的大部分情况,用不着你自己实现光照模型算法,毕竟threejs通过网格模型材质帮你实现了。

PBR相关理论介绍文章

  • 半小时了解PBR:https://zhuanlan.zhihu.com/p/37639418
  • PBR知识体系整理:https://zhuanlan.zhihu.com/p/100596453
  • PBR核心知识体系总结与概览:https://zhuanlan.zhihu.com/p/53086060

网格模型材质整体回顾

在这里插入图片描述

  • MeshLambertMaterial: Lambert光照模型(漫反射)

  • MeshPhongMaterial:Phong光照模型(漫反射、高光反射)

  • MeshStandardMaterial和MeshPhysicalMaterial:基于物理的光照模型(微平面理论、能量守恒、菲涅尔反射…)

PBR材质相比MeshLambertMaterial和MeshPhongMaterial可以提供更逼真的、更接近生活中的材质效果,当然也会占用更多的电脑硬件资源。

通过MeshPhysicalMaterial文档,提供的资源,可以查看多个PBR材质的案例效果,系统课程中轿车展示案例也会用到PBR材质。

渲染占用资源和表现能力

整体上来看,就是渲染表现能力越强,占用的计算机硬件资源更多。

  • 占用渲染资源
    MeshBasicMaterial < MeshLambertMaterial < MeshPhongMaterial < MeshStandardMaterial < MeshPhysicalMaterial

  • 渲染表现能力
    MeshBasicMaterial < MeshLambertMaterial < MeshPhongMaterial < MeshStandardMaterial < MeshPhysicalMaterial

  • 24
    点赞
  • 19
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
Three.js中,PBR(物理渲染)贴图是一种高级的纹理贴图技术,它可以模拟真实世界中物体的光照和材质反射。PBR贴图通常包括以下几种类型的贴图:漫反射贴图(Albedo),金属度贴图(Metalness),粗糙度贴图(Roughness)和法线贴图(Normal)。 漫反射贴图(Albedo)定义了物体表面的颜色,它描述了物体对不同光照方向的反射率。金属度贴图(Metalness)定义了物体的金属度,值为0表示非金属,值为1表示完全金属。粗糙度贴图(Roughness)定义了物体表面的光滑程度,值为0表示完全光滑,值为1表示完全粗糙。法线贴图(Normal)用于模拟细节和凹凸感,它可以增加物体表面的真实感。 使用PBR贴图可以使Three.js中的3D场景更加真实和逼真。您可以通过在Three.js中加载PBR贴图并应用到相应的材质上,来实现这一效果。您可以在Three.js的官方文档中找到更多关于如何使用PBR贴图的详细信息和示例代码。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* [Three.js实战常用技巧课程](https://download.csdn.net/download/aidedmniy/85060159)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] - *2* *3* [Three.js贴图效果一览](https://blog.csdn.net/weixin_44064440/article/details/126220987)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Threejs可视化

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值