在react中用three.js 渲染模型 在上面创建标签

javascript 复制代码
import { CSS2DRenderer, CSS2DObject } 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 );
camera.position.z = 5;

const renderer = new THREE.WebGLRenderer();
renderer.setSize( window.innerWidth, window.innerHeight );
document.body.appendChild( renderer.domElement );

// CSS2DRenderer 设置
const labelRenderer = new THREE.CSS2DRenderer();
labelRenderer.setSize( window.innerWidth, window.innerHeight );
labelRenderer.domElement.style.position = 'absolute';
labelRenderer.domElement.style.pointerEvents = 'none';
document.body.appendChild( labelRenderer.domElement );

// 创建3D模型
const geometry = new THREE.BoxGeometry( 1, 1, 1 );
const material = new THREE.MeshBasicMaterial( { color: 0x00ff00 } );
const cube = new THREE.Mesh( geometry, material );
scene.add( cube );

// 创建CSS2DObject
const div = document.createElement('div');
div.className = 'label-container '
div.style.width = '64px';
div.style.height = '32px';
div.style.color = '#fff';
div.style.backgroundColor = '#000';
div.style.fontSize = '16px';
div.style.textAlign = 'center';
div.style.lineHeight = '32px';
div.textContent = 'Label';

const labelObject = new THREE.CSS2DObject(div);
labelObject.position.set(0, 0, 5); // 设置CSS2DObject的位置
scene.add(labelObject);

// 渲染函数
function animate() {
    requestAnimationFrame( animate );

    // 更新3D模型的位置或旋转
    cube.rotation.x += 0.01;
    cube.rotation.y += 0.01;

    // 更新CSS2DObject的位置,使其跟随3D模型
    labelObject.position.copy(cube.position);
    labelObject.updateMatrix();

    renderer.render( scene, camera );
    labelRenderer.render( scene, camera );
}

animate();

可以给标签添加class 然后通过css来设置样式。

这里唯一的不同是我没有做到标签根据模型旋转然后标签跟着转动

在旋转的时候我给标签删除了。在回归到原位的时候才让标签显示出来。

如果要将标签跟随模型角度转动应该要将标签添加到模型上。

相关推荐
爱上妖精的尾巴几秒前
7-11 WPS JS宏 对象的属性值为函数的写法与用法
前端·javascript·wps·js宏·jsa
zuozewei2 分钟前
零基础 | 使用LangChain框架实现ReAct Agent
前端·react.js·langchain
坠入暮云间x2 分钟前
React Native for OpenHarmony开发环境搭建指南(一)
前端·react native·开源
爱上妖精的尾巴5 分钟前
7-12 WPS JS宏 this、return用构造函数自定义类-1:对象内部函数,外部调用的写法
前端·javascript·wps·js宏·jsa
白鳯5 分钟前
分形世界:React实现交互式分形图绘制与导出
react.js·前端框架·cursor·分形·vibe coding·分形绘制·数学之美
har01d10 分钟前
AI生成的 vue3 日历组件,显示农历与节日,日期可选择,年月可切换
前端·vue.js·节日
HIT_Weston14 分钟前
106、【Ubuntu】【Hugo】搭建私人博客:模糊搜索 Fuse.js(二)
linux·javascript·ubuntu
冲刺逆向17 分钟前
【js逆向案例六】创宇盾(加速乐)通杀模版
java·前端·javascript
我穿棉裤了19 分钟前
文字换行自动添加换行符“-”
前端·javascript·vue.js
six+seven23 分钟前
Node.js内置模块fs
前端·node.js