位置: IT常识 - 正文

Three.js教程:材质效果(three.js 入门)

编辑:rootadmin
Three.js教程:材质效果

推荐整理分享Three.js教程:材质效果(three.js 入门),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:three.js菜鸟教程,three. js,three. js,three.js glb,three.js 教程,three.js中文教程,three. js,three.js入门指南,内容如对您有帮助,希望把文章链接给更多的朋友!

推荐:将NSDT场景编辑器加入你3D工具链

其他工具系列:NSDT简石数字孪生

材质效果

前面案例中几何体对应网格模型材质只是设置了一个颜色,实际渲染的时候往往会设置其他的参数,比如实现玻璃效果要设置材质透明度,一些光亮的表面要添加高光效果。

半透明效果Three.js教程:材质效果(three.js 入门)

更改场景中的球体材质对象构造函数THREE.MeshLambertMaterial()的参数,添加opacity和transparent属性,opacity的值是0~1之间,transparent表示是否开启透明度效果, 默认是false表示透明度设置不起作用,值设置为true,网格模型就会呈现透明的效果,使用下面的代码替换原来的球体网格模型的材质, 刷新浏览器,通过鼠标旋转操作场景,可以看到半透明的球体和立方体颜色叠加融合的效果。

var sphereMaterial=new THREE.MeshLambertMaterial({ color:0xff0000, opacity:0.7, transparent:true});//材质对象

材质对象的一些属性可以在构造函数参数中设置,也可以访问材质对象的属性设置。

material.opacity = 0.5 ;material.transparent = true ;材质常见属性材质属性简介color材质颜色,比如蓝色0x0000ffwireframe将几何图形渲染为线框。 默认值为falseopacity透明度设置,0表示完全透明,1表示完全不透明transparent是否开启透明,默认false添加高光效果

直接使用下面的代码替换上面的透明度材质即可,刷新浏览器可以看到球体表面的高光效果。

var sphereMaterial=new THREE.MeshPhongMaterial({ color:0x0000ff, specular:0x4488ee, shininess:12});//材质对象

处在光照条件下的物体表面会发生光的反射现象,不同的表面粗糙度不同,宏观上来看对光的综合反射效果,可以使用两个反射模型来概括,一个是漫反射,一个是镜面反射, 使用渲染软件或绘画的时候都会提到一个高光的概念,其实说的就是物理光学中镜面反射产生的局部高亮效果。实际生活中的物体都是镜面反射和漫反射同时存在,只是哪个占得比例大而已, 比如树皮的表面更多以漫反射为主基本没有体现出镜面反射,比如一辆轿车的外表面在阳光下你会看到局部高亮的效果,这很简单汽车表面经过抛光等表面处理粗糙度非常低, 镜面反射效果明显,对于three.js而言漫反射、镜面反射分别对应两个构造函数MeshLambertMaterial()、MeshPhongMaterial(),通过three.js引擎你可以很容易实现这些光照模型,不需要自己再使用原生WebGL实现,更多关于光照模型的知识可以参考文章《WebGL_course光照渲染立方体》或计算机图形学的相关书籍。

前面案例都是通过构造函数MeshLambertMaterial()实现漫反射进行渲染,高光效果要通过构造函数MeshPhongMaterial()模拟镜面反射实现,属性specular表示球体网格模型的高光颜色,改颜色的RGB值会与光照颜色的RGB分量相乘, shininess属性可以理解为光照强度的系数,初学的的时候这些细节如果不清楚,不用深究,每个人的基础不同,理解问题的深度和角度不同,比如高光,学习过计算机图形学的会联想到镜面反射模型和物理光学, 从事过与美术相关工作,都知道需要的时候会给一个物体添加高光,视觉效果更加高亮,因此对于构造函数MeshPhongMaterial()的参数设置不太清除也没关系,对于零基础的读者本节课的要求就是有个简单印象就可以, 站在黑箱外面理解黑箱;对于有WebGL基础的,可以思考three.js引擎构造函数实际封装了哪些WebGL API和图形学算法,站在黑箱里面理解黑箱,如果是你你会怎么封装开发一个三维引擎,这样你可以从底层理解上层的问题, 保证学习的连贯性;如果你使用过其它的三维建模渲染软件,那就使用three.js这个黑箱类比一个你熟悉的黑箱,通过类比降低学习难度,比如你可以打开3dmax软件设置一个材质的高光,体验下视觉效果。

材质类型

threejs提供了很多常用的材质效果,这些效果本质上都是对WebGL着色器的封装,对于开发者来说直接使用就可以,这里不再做过多介绍,大家现有一个印象即可。

材质类型功能MeshBasicMaterial基础网格材质,不受光照影响的材质MeshLambertMaterialLambert网格材质,与光照有反应,漫反射MeshPhongMaterial高光Phong材质,与光照有反应MeshStandardMaterialPBR物理材质,相比较高光Phong材质可以更好的模拟金属、玻璃等效果

3D建模学习工作室

本文链接地址:https://www.jiuchutong.com/zhishi/300832.html 转载请保留说明!

上一篇:React脚手架工具创建项目的详细介绍(react脚手架搭建项目)

下一篇:vue实现动态路由添加(简单无废话版本)(vue动态路由是什么)

  • 出口货物退(免)税管理办法
  • 递延所得税负债大白话解释
  • 关税完税价格是到岸价吗
  • 发票货物名称前带星号规定
  • 政府补助是属于什么财务活动
  • 民办学校房屋要求
  • 结转成本时是否含税
  • 没有认证怎么办
  • 分公司的税收机关在总公司还是分公司
  • 在建工程是资产
  • 国债利息收入免征增值税
  • 当月发票不够用领用了下个月,下个月还能再领吗
  • 施工企业必须要注册造价工程师吗
  • 货物发出未开票不确认收入
  • 应收票据的会计分录例题
  • 软件开发过程的一般步骤
  • 购进的固定资产多少金额可以直接进去费用
  • 现房销售需要哪些手续
  • 股票期权个人所得税税率表
  • 开票金额与实际金额差5元
  • 应收账款确认无法收回
  • 增值税的计征方法有哪些
  • 增值税逾期申报流程
  • 销售商品发生的业务招待费计入什么科目
  • 存货跌价准备计提原则
  • 广告补贴申请报告
  • Windows11更新后无法联网
  • php获取长度
  • 直接人工分配按计时工资怎么分
  • w10引导修复工具
  • win10点搜索
  • conda不是内部或外部命令
  • PHP:imagesetinterpolation()的用法_GD库图像处理函数
  • 直接转销法账务处理
  • 取得政府补助后怎么处理
  • 如何通过无线路由器连接打印机
  • vue中使用数组
  • 弥补以前年度亏损后缴纳所得税
  • 公司向股东借款多久必须归还
  • 作为大学生你能为国家安全贡献哪些力量论文
  • 最新人工智能软件chingt
  • 企业利息支出怎么算
  • 营业外支出是什么会计要素
  • 施工企业内部常设置?主要出实验报告
  • 公司财务变更需要变更哪些内容
  • 个人终止投资经营的情形
  • 持有至到期投资属于流动资产吗
  • sqlserver2008还原数据库 错误3624
  • 销售费用工资是什么科目
  • 实收资本可以去银行查吗
  • 公转私户违法吗
  • 调研费用包括哪些项目
  • 项目人员租房费用怎么算
  • 扣缴个人所得税报告表
  • 17增值税发票怎么抵扣
  • 房地产企业内部控制的现状
  • 在产品占用资金属于资产还是负债
  • 工会活动支出如何记账
  • 资产处置费用是资产类科目吗
  • 如何合理的运用网络
  • 个税租房抵扣细则
  • mysql的操作方法
  • sqlserver数据库恢复
  • ubuntu编辑器在哪
  • OS X 10.12.6 beta 1如何更新 OS X 10.12.6 beta 1如何升级
  • 安装程序不运行怎么回事
  • win10mobile现在能干吗
  • 人走鸟不惊,出自于谁的诗句?
  • 视觉观点
  • android 动效
  • jQuery实现checkbox列表的全选、反选功能
  • axios使用jsonp
  • js右键菜单
  • linux python gui
  • js 分页插件
  • android navigation bar
  • 代码实现死锁
  • 浙江国地税申报网
  • 西安二手房几年可以过户
  • 考公务员考国税局有什么要求吗
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设