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

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

相关推荐
莫的感情13 分钟前
下载按钮点击一次却下载两个文件问题
前端
一个很帅的帅哥17 分钟前
JavaScript事件循环
开发语言·前端·javascript
小宁爱Python22 分钟前
Django Web 开发系列(二):视图进阶、快捷函数与请求响应处理
前端·django·sqlite
fox_22 分钟前
深入理解React中的不可变性:原理、价值与实践
前端·react.js
Github项目推荐24 分钟前
你的错误处理一团糟-是时候修复它了-🛠️
前端·后端
Code小翊29 分钟前
C语言bsearch的使用
java·c语言·前端
云枫晖30 分钟前
Webapck系列-初识Webpack
前端·javascript
慧一居士33 分钟前
HTML5 功能介绍,使用场景,对应功能点完整使用示例
前端
海在掘金6112741 分钟前
告别“undefined is not a function”:TS如何让你的函数调用更安心
前端
云中雾丽44 分钟前
Flutter中Stream的各种使用场景和实现方式
前端