Three.js new THREE.TextureLoader()纹理贴图使用png图片显示为黑色

问题代码如下:

javascript 复制代码
  const texture = new THREE.TextureLoader().load('./image.png');
  droneGeometry = new THREE.PlaneGeometry(1, 1);
  droneMaterial = new THREE.MeshBasicMaterial({ map: texture});
  droneMesh = new THREE.Mesh(droneGeometry, droneMaterial);
  droneMesh.position.set(0, 1, 0);
  scene.add(droneMesh);
  renderer.render(scene, camera);

问题出在.TextureLoader()是一个异步函数,加载图片未完成便渲染图片了,参考网上解决方案有以下几种

1、使用回调

2、使用require请求图片

javascript 复制代码
  const texture = new THREE.TextureLoader().load(require('./image.png'));

作者使用的是vite + vue3的技术栈,未能通过上述方法解决,如下方法可以成功加载图片

javascript 复制代码
import droneTexture from '../../assets/images/大疆无人机.png';
 
const texture = new THREE.TextureLoader().load(droneTexture);
相关推荐
bysking1 分钟前
【31-Ai-Agent】ai-agent的核心实现细节-bysking
前端
从文处安5 分钟前
「前端何去何从」(React教程)React 状态管理:从局部 State 到可扩展架构
前端·react.js
一拳不是超人9 分钟前
Three.js一起学-如何通过官方例子高效学习 Three.js?手把手带你“抄”出一个3D动画
前端·webgl·three.js
椰子皮啊12 分钟前
400行Node.js搞定mediasoup信令转换:一次跨语言"表白"实录
前端·架构
果然_20 分钟前
告别混淆!Git 多账号按域名/目录自动切换身份的终极指南
前端
Wect25 分钟前
React Scheduler & Lane 详解
前端·react.js·面试
myNameGL25 分钟前
ArkTs核心语法
前端·javascript·vue.js
重庆穿山甲34 分钟前
从零到精通:OpenClaw完整生命周期指南
前端·后端·架构
浏览器API调用工程师_Taylor37 分钟前
web逆向之小红书无水印图片提取工具
前端·javascript·逆向
程序员阿峰37 分钟前
【JavaScript面试题-作用域与闭包】什么是闭包?闭包在实际开发中有什么应用和潜在问题(如内存泄漏)?
前端·面试