vue3+three.js给glb模型设置视频贴图

1.在网上下载一个显示屏或者自己画一个,在blender中设置好显示屏的Mesh,UV设置好,这样方便代码中添加纹理贴图。可以让美术在建模软件中,先随机设置一张图片作为纹理,验证UV是否设置好

关于如何 在blender中给模型设置UV贴图百度很多的

typescript 复制代码
// 视频
import * as THREE from "three"
// 加载建筑模型
import {
  GLTFLoader
} from 'three/examples/jsm/loaders/GLTFLoader.js'
import {
  DRACOLoader
} from 'three/examples/jsm/loaders/DRACOLoader'
export function getVideo(th) {
  console.log('th', th) // this
  var that = th
  const loader = new GLTFLoader().setPath('/models/')
  const dracoLoader = new DRACOLoader()
  dracoLoader.setDecoderPath('/draco/')
  loader.setDRACOLoader(dracoLoader)
  loader.load("SP.glb", function (gltf) {
    gltf.scene.position.set(-50, 0, 90); // 模型位置
    gltf.scene.rotation.y = Math.PI; // 180度等于PI弧度
    gltf.scene.traverse(function (child) {
      console.log('child', child)
      child.castShadow = true;
      child.receiveShadow = true;
      // 下面的这几个判断,就是用来给模型添加视频的
      if (child.name === '显示屏') {
        let video = document.createElement('video');
        video.src = "/public/data/123.mp4";
        video.muted = true;
        video.autoplay = "autoplay";
        video.loop = true;
        video.play();
        const videoTexture = new THREE.VideoTexture(video);
        const videoMaterial = new THREE.MeshBasicMaterial({
          map: videoTexture
        });
        console.log('videoMaterial', videoMaterial)
        child.material = videoMaterial; 
      }
    });
    // 设置模型的大小
    const modelScale = 2.5; // 定义模型的缩放比例
    gltf.scene.scale.set(modelScale, modelScale, modelScale);
    that.scene.add(gltf.scene);
  });
}

结果

相关推荐
程序员小寒2 分钟前
Vue.js 为什么要推出 Vapor Mode?
前端·javascript·vue.js
白菜__9 分钟前
去哪儿小程序逆向分析(酒店)
前端·javascript·爬虫·网络协议·小程序·node.js
困惑阿三32 分钟前
深入理解 JavaScript 中的(Promise.race)
开发语言·前端·javascript·ecmascript·reactjs
我命由我1234534 分钟前
微信小程序 bind:tap 与 bindtap 的区别
开发语言·前端·javascript·微信小程序·小程序·前端框架·js
音视频牛哥39 分钟前
从低延迟到高可用:RTMP与 HTTP/HTTPS-FLV在App播放体系中的角色重构
人工智能·音视频·音视频开发·http-flv播放器·https-flv播放器·ws-flv播放器·wss-flv播放器
克喵的水银蛇39 分钟前
Flutter 布局实战:掌握 Row/Column/Flex 弹性布局
前端·javascript·flutter
Hommy8842 分钟前
如何利用剪映小助手实现视频批量剪辑?
aigc·音视频·批量剪辑·剪映
哆啦A梦15881 小时前
60 订单页选择收货地址
前端·javascript·vue.js·node.js
馬致远1 小时前
案例1- 跳动的心
javascript·css·css3
Hilaku1 小时前
利用 link rel="prefetch":如何让用户的页面秒开?
前端·javascript·性能优化