打开APP
userphoto
未登录

开通VIP,畅享免费电子书等14项超值服

开通VIP
Three.js教程:递归遍历层级模型修改材质
推荐:将NSDT场景编辑器加入你的3D工具链
其他工具集:NSDT简石数字孪生

递归遍历层级模型修改材质

加载一个外部模型,比如gltf模型,如果你想批量修改每个Mesh的材质,一个一个设置比较麻烦,可以通过递归遍历方法.traverse()批量操作更加方便。

递归遍历方法.traverse()

递归遍历gltf所有的模型节点。

// 递归遍历所有模型节点批量修改材质
gltf.scene.traverse(function(obj) {
    if (obj.isMesh) {//判断是否是网格模型
        console.log('模型节点',obj);
        console.log('模型节点名字',obj.name);
    }
});

查看gltf默认的材质

.obj、.gltf、.fbx等不同格式的模型,threejs加载默认的材质可能不同,不过也不用刻意记忆,通过浏览器控制台log打印即可console.log(obj.material)

threejs解析gltf模型默认材质一般是MeshStandardMaterialMeshPhysicalMaterial,相比较其它网格材质,这两个材质属于PBR物理材质,可以提供更加真实的材质效果

// 递归遍历所有模型节点批量修改材质
gltf.scene.traverse(function(obj) {
    if (obj.isMesh) {
        console.log('gltf默认材质',obj.material);
    }
});

批量修改gltf所有Mesh的材质

gltf.scene.traverse(function(obj) {
    if (obj.isMesh) {
        // 重新设置材质
        obj.material = new THREE.MeshLambertMaterial({
            color:0xffffff,
        });
    }
});
本站仅提供存储服务,所有内容均由用户发布,如发现有害或侵权内容,请点击举报
打开APP,阅读全文并永久保存 查看更多类似文章
猜你喜欢
类似文章
二叉树IT面试题汇总
非递归遍历二叉树
递归,回溯,DFS,BFS的理解和模板
拟穿衣中织物模型的建立和碰撞检测的处理
数据结构与算法: 三十张图弄懂「图的两种遍历方式」
oracle connect by用法
更多类似文章 >>
生活服务
热点新闻
分享 收藏 导长图 关注 下载文章
绑定账号成功
后续可登录账号畅享VIP特权!
如果VIP功能使用有故障,
可点击这里联系客服!

联系客服