THREE.JS 使用CSS2DRenderer/CSS3DRenderer 给模型增加标签

在Three.js中,可以使用CSS2DRendererCSS3DRenderer来将2D或3D内容与3D场景中的模型相关联。以下是一个简单的例子,展示如何将标签与3D模型结合使用:




import * as THREE from 'three';
import { CSS2DRenderer, CSS3DRenderer } from 'three/examples/jsm/renderers/CSS2DRenderer.js';
 
// 设置场景、摄像机和渲染器
const scene = new THREE.Scene();
const camera = new THREE.PerspectiveCamera(75, window.innerWidth / window.innerHeight, 0.1, 1000);
const renderer = new THREE.WebGLRenderer();
renderer.setSize(window.innerWidth, window.innerHeight);
document.body.appendChild(renderer.domElement);
 
// 加载3D模型(以GLTF为例)
const loader = new THREE.GLTFLoader();
loader.load('path/to/model.gltf', (gltf) => {
    scene.add(gltf.scene);
    // 假设我们使用的是第一个模型
    const model = gltf.scene.children[0];
 
    // 创建标签元素
    const label = document.createElement('div');
    label.style.color = 'white';
    label.style.padding = '4px';
    label.style.background = 'black';
    label.textContent = '这是一个标签';
    document.body.appendChild(label);
 
    // 将标签与模型相关联
    new CSS2DRenderer().setSize(window.innerWidth, window.innerHeight);
    // 如果使用CSS3DRenderer,需要将标签作为3D元素处理
    // new CSS3DRenderer().setSize(window.innerWidth, window.innerHeight);
    const labelObject = new THREE.CSS2DObject(label);
    // 如果使用CSS3DRenderer,需要将labelObject添加到scene中
    // scene.add(labelObject);
 
    // 将标签的位置与模型的位置对齐
    labelObject.position.copy(model.position);
    scene.add(labelObject);
});
 
camera.position.z = 5;
 
function animate() {
    requestAnimationFrame(animate);
    renderer.render(scene, camera);
    // 如果使用CSS3DRenderer,调用render方法
    // cssRenderer.render(scene, camera);
}
 
animate();

在这个例子中,我们首先设置了Three.js的场景、摄像机和渲染器。然后,我们加载了一个3D模型,并在模型加载完成后创建了一个HTML标签。接着,我们创建了一个CSS2DRenderer实例,并将这个标签作为2D对象添加到了场景中。最后,我们调整了标签的位置,使其与3D模型的位置对齐,并启动了动画循环。

注意:在实际应用中,你需要根据模型的实际情况调整标签的对齐方式,以确保标签始终面向摄像机,并且不会随着模型的旋转而旋转。

评论已关闭

推荐阅读

DDPG 模型解析,附Pytorch完整代码
2024年11月24日
DQN 模型解析,附Pytorch完整代码
2024年11月24日
AIGC实战——Transformer模型
2024年12月01日
Socket TCP 和 UDP 编程基础(Python)
2024年11月30日
python , tcp , udp
如何使用 ChatGPT 进行学术润色?你需要这些指令
2024年12月01日
AI
最新 Python 调用 OpenAi 详细教程实现问答、图像合成、图像理解、语音合成、语音识别(详细教程)
2024年11月24日
ChatGPT 和 DALL·E 2 配合生成故事绘本
2024年12月01日
omegaconf,一个超强的 Python 库!
2024年11月24日
【视觉AIGC识别】误差特征、人脸伪造检测、其他类型假图检测
2024年12月01日
[超级详细]如何在深度学习训练模型过程中使用 GPU 加速
2024年11月29日
Python 物理引擎pymunk最完整教程
2024年11月27日
MediaPipe 人体姿态与手指关键点检测教程
2024年11月27日
深入了解 Taipy:Python 打造 Web 应用的全面教程
2024年11月26日
基于Transformer的时间序列预测模型
2024年11月25日
Python在金融大数据分析中的AI应用(股价分析、量化交易)实战
2024年11月25日
AIGC Gradio系列学习教程之Components
2024年12月01日
Python3 `asyncio` — 异步 I/O,事件循环和并发工具
2024年11月30日
llama-factory SFT系列教程:大模型在自定义数据集 LoRA 训练与部署
2024年12月01日
Python 多线程和多进程用法
2024年11月24日
Python socket详解,全网最全教程
2024年11月27日