three.js 加载透明贴图模型不正常显示的问题,渲染透明贴图gltf模型

本文介绍了如何处理从3dmax导出的gltf模型在gltfViewer中无法正确显示透明贴图的状况。通过下载并修改three-gltf-viewer的源码,设置material.alphaTest和material.depthWrite属性,成功让模型达到预期的透明效果。参考了相关博客文章,提供了问题的解决方案。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

概述:

现在有一个从3dmax导出的gltf模型,贴图方式是透明贴图,想要用three.js加载显示出来,但是在gltf Viewer中预览时是不支持透明贴图的,不知道是不是模型的问题,从网上查了很多文章,最后才试出来解决办法。

一、模型

首先看一下在https://gltf-viewer.donmccurdy.com/上预览的效果,直接上图:

二、下载源码,本地运行

下载它的源码,https://github.com/donmccurdy/three-gltf-viewer,在本地运行起来,vscode打开,改一下src目录下的viewer.js文件中的代码,在traverseMaterials函数中增加下面两句:

material.alphaTest = 0.1;
material.depthWrite = false;

三、效果对比 

然后重新预览该gltf模型,效果如下图,算是勉强达到了想要的效果。

找到该解决办法的过程中参考了文章:

https://blog.l0v0.com/posts/50589.html

https://www.manongdao.com/article-1036373.html

评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值