当前位置: 首页 > article >正文

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

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来设置样式。

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

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

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


http://www.kler.cn/news/290407.html

相关文章:

  • 传统CV算法——基于opencv的答题卡识别判卷系统
  • 【大数据】Java与Python的无缝对接:探讨Java调用Python的方法与原理
  • <数据集>车辆识别数据集<目标检测>
  • 你必须知道的C语言问题(8)
  • Go 中间件学习
  • 【CanMV K230】边缘检测
  • 羊大师:白露养生经,羊奶不可少
  • docker实战基础一 (Docker基础命令)
  • 【云原生】Helm来管理Kubernetes集群的详细使用方法与综合应用实战
  • C++实现简易俄罗斯方块小游戏
  • Apache SeaTunnel Zeta 引擎源码解析(一)Server端的初始化
  • 心觉:如何填平想象和愿望之间的鸿沟?
  • Docker设置socks5代理
  • 大模型超详细解读汇总
  • 一个“改造”的工厂背后:中国电商的AI重构
  • 赛码网牛客在acm模式下利用node.js处理多行输入方法
  • 视频结构化从入门到精通——图像算法类型介绍
  • LuaJit分析(三)luajit字节码文件格式
  • 【C++】string的模拟实现
  • 1119 Pre- and Post-order Traversals
  • Django学习(二)
  • 基因对应身体的需求 平衡饮食的重要性 第四篇
  • 8个优质视频素材库,商用无忧
  • AT+MQTT指令连接华为云实现数据上传
  • 使用linux命令导出mysql数据为CSV文件
  • 【开源风云】从若依系列脚手架汲取编程之道(三)
  • 低代码表单 FormCreate 中组件的生成规则详解
  • 机器学习和深度学习中常见损失函数,包括损失函数的数学公式、推导及其在不同场景中的应用
  • 从python应用app向微软Microsoft Teams Channel发送消息message
  • Kafka3.x 使用 KRaft 模式部署 不依赖 ZooKeeper