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

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

相关推荐
用户5757303346248 分钟前
从 LocalStorage 待办清单到 CSS 核心机制:一次搞懂数据持久化、继承与盒模型陷阱
前端
codingWhat14 分钟前
前端组件库开发实践:从零到发布
前端·npm·vite
cxxcode19 分钟前
浏览器模块加载与 Webpack 打包原理
前端
兆子龙20 分钟前
React Compiler 来了:少写 useMemo,照样稳
前端·架构
用户54330814419421 分钟前
Manifest V3 实战:从补天网站逆向到 Chrome 扩展开发全记录
前端·后端
zhqiok24 分钟前
React中类似于Vue中Pinia的轻量级状态管理神器——Zustand
前端
Mintopia27 分钟前
促成高端技术方案形成的关键要素与实践路径
前端
摸鱼的春哥2 小时前
春哥的Agent通关秘籍13:实现RAG查询
前端·javascript·后端
明月_清风2 小时前
滚动锁定:用户向上翻看历史时,如何阻止 AI 新消息把它“顶”下去?
前端·javascript
明月_清风2 小时前
当高阶函数遇到 AI:如何自动化生成业务层面的逻辑拦截器
前端·javascript·函数式编程