threejs 大场景下,对小模型进行贴图处理

接上篇小模型的删除☞threeJS 大模型中对小模型进行删除-CSDN博客

针对已有模型,根据数据状态进行贴图处理,例如:机房内电脑告警状态、电脑开关机状态下的不同状态贴图等

示例模型还是以丛林小屋为例:针对该模型中的树干进行贴图处理

原图

贴图后,忽略红色丑树干,只是增强演示效果

找模型的小tip

第一步加载完模型后,查看下模型的结构,可以打印下object的子模型

输出结果:

大概知道这个模型由哪些子模型组成,这个模型没有group的概念,只有简单的mesh组成,根据实际的业务需求,模型名称可能有一定的约束规范,例如id之类。

我们以name为'BTree_BrichTree_0'为例,进行大模型中的对其删除操作;具体代码如下

javascript 复制代码
    // 贴图的方法,设置全局变量screenMaterial, 对其材质赋值
    loadTexture() {
      const img = require('@/assets/img/threeImg/pop-item-red.png'); // 贴图路径
      const textureLoader = new THREE.TextureLoader();
      textureLoader.load(img, texture => {
        this.screenMaterial = new THREE.MeshStandardMaterial({ map: texture });
      });
    },

selectedObject.material = this.screenMaterial; // 敲黑板,划重点

单个模型的情况下,直接对其进行 material 进行赋值即可,亲测有效

javascript 复制代码
const name = 'BTree_BrichTree_0';
const selectedObject = object.getObjectByName(name);
selectedObject.material = this.screenMaterial; // 敲黑板,划重点

模型组的场景,对其进行children遍历,进行材质重新赋值

javascript 复制代码
for (let i = selectedObject.children.length - 1; i >= 0; i--) {
  const child = selectedObject.children[i];
     if (child instanceof THREE.Mesh && child.name.indexOf(name) !== -1 && child.material.map) {
        child.material = this.screenMaterial;
     }
}
相关推荐
明月_清风5 分钟前
前端工程化七连问:从紧急修复到版本控制,一文打通工程化任督二脉
前端·前端工程化
用户6757049885029 分钟前
不装插件不写代码!教你一招搞定网页长截图!清晰且高效!
前端·chrome
tjl521314_2113 分钟前
01C++ 分离编译与多文件编程
前端·c++·算法
sayamber16 分钟前
vLLM 容器化部署实战:如何在云服务器上跑起高并发大模型推理服务
前端
LIO16 分钟前
Pinia 极简指南:Vue 3 官方状态管理库
前端·vue.js
燐妤1 小时前
前端HTML编程2:深入学习表单与表格
前端·学习·html5
朝阳391 小时前
react【实战】首页 -- 响应式导航栏(含带联动动画的搜索框)
前端·react.js·前端框架
贾铭1 小时前
如何实现一个网页版的剪映(五)如何跳转到视频某一帧
前端·后端
林恒smileZAZ1 小时前
CSS 滚动驱动动画(scroll-timeline):无 JS 实现滚动特效
前端·javascript·css
俺不会敲代码啊啊啊1 小时前
el-table实现行拖拽(包含展开项)
前端·vue.js·typescript