首页 > 其他分享 >在react中用three.js 渲染模型 在上面创建标签

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

时间:2024-09-09 13:53:06浏览次数:11  
标签:style const 标签 three js react new div THREE


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

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

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

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

标签:style,const,标签,three,js,react,new,div,THREE
From: https://blog.51cto.com/u_15482477/11960674

相关文章

  • 推荐一个Python流式JSON处理模块:streaming-json-py
    每天,我们的设备、应用程序和服务都在生成大量的数据流,这些数据往往大多是以JSON格式存在的。如何高效地解析和处理这些JSON数据流是一大挑战。今天,我要为大家介绍一个能极大简化这一过程的利器:streaming-json-pystreaming-json-py介绍streaming-json-py是一个专为实时......
  • 在react中要将页面跳转有动画
    //页面切换过渡动画.page{position:absolute;left:15px;right:15px;}//页面切换过渡动画---进入.page-enter{opacity:0;transform:translateY(100%);}//页面切换过渡动画---进入(被激活).page-enter-active{opacity:1;//transform:s......
  • 在react中利用three.js 渲染模型 让鼠标拖拽是模型转动
    import{OrbitControls}from'three/examples/jsm/controls/OrbitControls';useEffect(()=>{//初始化OrbitControlsconstcontrols=newOrbitControls(camera,renderer.domElement);//设置控制参数controls.enableDamping=true;//平滑化运动c......
  • react 中three.js 模型渲染
      npminstallthreeimport*asTHREEfrom"three";import{GLTFLoader}from"three/examples/jsm/loaders/GLTFLoader.js";constmountRef=useRef(null);useEffect(()=>{//创建渲染器constrenderer=newTHREE.WebGLRender......
  • 在react 中还有另外一种three.js 渲染方式
    npminstall@react-three/drei利用标签去渲染模型importReact,{useRef,useEffect,useState}from'react';import{Canvas,useFrame,useThree,useLoader}from'@react-three/fiber';import{GLTFLoader}from'three/examples/jsm/loaders/GLT......
  • json.dumps(data.__dict__) 会把中文字符转义为 Unicode 码点
    在Python中,json.dumps()函数会将Python对象序列化为JSON字符串,并默认使用UTF-8编码来处理非ASCII字符。虽然在Python3中,字符串是默认以Unicode形式存储的,但是当json.dumps()将Python字符串转换为JSON格式时,非ASCII字符会自动被转义为Unicode码点(例如\u......
  • linux手动安装nodejs
    1.下载nodejs的安装文件,要选择编译好的  预构建二进制文件 这样就不用自己再编译安装了 https://nodejs.org/zh-cn/download/prebuilt-binaries2.下载完成后使用如下命令解压缩文件1)使用xz-dnode-v18.20.4-linux-x64.tar.xz 解压缩得到node-v18.20.4-linux......
  • 【JavaScript系列八】—讲述JS学习历程的知识分享!
    前言本篇主要讲述JS中较为重要的一环,函数的用法,深拷贝和浅拷贝的概念和区别,闭包和递归,包括一些案例:例如递归实现斐波那契数列,求阶乘等等一、关于函数定义函数的方式function关键字函数表达式(匿名函数)varfn=function(){}newfunction()函数的调用及其this指向普通函数—......
  • 【JavaScript系列九】—讲述JS学习历程的知识分享!
    前言本篇主要是讲述ES6的新增语法和相关运用一、ES6ES的全称是ECMAScript,它是由ECMA国际标准化组织,制定的一项脚本语言的标准化规范。泛指2015年6月之后发布的版本为什么使用ES6语言更加完善功能更加强大变量提升特性增加了程序运行时的不确定性语法过于......
  • java导入json数据至doris
    表结构字段名称与json key名称一致:packagecom.ruoyi.doris;importcn.hutool.core.io.FileUtil;importcn.hutool.http.HttpRequest;importcn.hutool.http.HttpResponse;importcom.alibaba.fastjson.JSONArray;importcom.alibaba.fastjson.JSONObject;importlomb......