threejs教程-基础网络材质

简介

本系列教程需要具备threejs的基础入门知识,了场景、几何体、相机等基础概念。

学习本教程之前,建议学习笔者的【透视相机】的基础知识

根据threejs前置知识,我们可以实现一个如下的3D效果

示例代码中,我们使用MeshBasicMaterial创建了一个基础网络材质。现在,我们介绍一下它的一些基本特性,方便我们更好的学习材质与贴图

基础网络材质的一些特性

API:threejs.org/docs/#api/z...

这种材质是一个以简单着色(平面或线框)方式来绘制几何体的材质。

光照的影响

它不受光照的影响。ambient light表示光照,我们调整光照颜色,它的颜色不会发生变化。

雾的影响

这材质受到雾的颜色影响

共有属性Material

THREE.Material代表所有材质的共有属性,这些属性的具体信息可以在Material材质文档中找到

透明度transparent

depthTest表示是否开启深度检测。如果为否,则表示在渲染过程中,远处的点不会被近处遮挡。

depthWrite表示是否允许向深度缓冲区写入数据。如果为否,该物体的深度信息不会影响其他物体的渲染。
alphaTest是用来控制透明度的。它默认值为0,如果设置不透明度(opacity)低于此值,则不会渲染材质。

显示与隐藏visible

颜色color

线框wireframe

顶点颜色vertexColor

英/ˈvɜːteks/美/ˈvɜːrteks/

用的很少,了解即可

环境贴图envMaps

envMap,全称environment map,字面意思是"环境图"。代表周围环境对物体渲染的影响,可以设置反射和折射。

当物体表面结合反射lvreflectivity和折射率refractionRatio时,环境对物体的影响非常明显

贴图map

可以给物体表面添加一个材质颜色,比如砖块

相关推荐
还有多久拿退休金11 小时前
dnd-kit 碰撞检测算法:你的订单为什么自己"跑"到了 1 号?
前端
qq_3168377511 小时前
npm run tauri build Downloading下载超时
前端·npm·node.js
w_t_y_y11 小时前
VUE3(二)VUE2和VUE3区别
前端·javascript·vue.js
T-shmily11 小时前
使用svg图标
前端·css
阿明在折腾11 小时前
在浏览器里实现 PDF 合并与拆分:pdf-lib 实战指南
前端·javascript
米高梅狮子11 小时前
03.OpenStack使用
linux·前端·云原生·容器·架构·kubernetes·openstack
时光不负努力11 小时前
手写三大核心:Promise、Event Bus、深拷贝
前端
星栈11 小时前
被Leptos弹窗逼疯后,我搞了一套零Props方案
前端·前端框架·全栈
不是山谷.:.11 小时前
Axios的【接口防抖 + 请求失败重试 + 弱网提示】三合一高阶版封装
前端·javascript·vue.js·笔记·elementui·typescript
超绝大帅哥11 小时前
babel降级|>, Object.groupBy
前端·javascript