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

vue3+three.js加载glb模型

<template><div><!-- 亮度调节滑块 --><div class="controls"><label for="brightness">背景光亮度:</label><inputtype="range"id="brightness"v-model="brightness"min="0"max="2"step="0.1"/><span>{{ brightness }}</span></div><div ref="container" className="three-container"></div></div>
</template><script setup>
import {ref, onMounted, onBeforeUnmount, watch} from 'vue';
import * as THREE from 'three';
import {GLTFLoader} from 'three/examples/jsm/loaders/GLTFLoader.js';
import {OrbitControls} from 'three/examples/jsm/controls/OrbitControls.js';// 定义容器引用
const container = ref(null);// 定义 Three.js 相关变量
let scene, camera, renderer, controls, model;// 定义环境光
let ambientLight;// 定义亮度变量
const brightness = ref(1); // 初始亮度为 1// 初始化 Three.js 场景
const initThree = () => {// 创建场景scene = new THREE.Scene();scene.background = new THREE.Color(0xffc0cb); // 淡粉色// 创建相机camera = new THREE.PerspectiveCamera(75,container.value.clientWidth / container.value.clientHeight,0.1,1000);camera.position.set(5, 5, 5);// 创建渲染器renderer = new THREE.WebGLRenderer({antialias: true});renderer.setSize(container.value.clientWidth, container.value.clientHeight);container.value.appendChild(renderer.domElement);// 添加轨道控制器controls = new OrbitControls(camera, renderer.domElement);controls.enableDamping = true;// 添加环境光const ambientLight = new THREE.AmbientLight(0xffffff, brightness.value);scene.add(ambientLight);renderer.toneMapping = THREE.ACESFilmicToneMapping; // 设置色调映射renderer.toneMappingExposure = 1.5; // 增加曝光值// 添加平行光const directionalLight = new THREE.DirectionalLight(0xffffff, 2);directionalLight.position.set(1, 1, 1).normalize();scene.add(directionalLight);
};// 加载 GLB 模型
const loadModel = () => {const loader = new GLTFLoader();loader.load('/api/demo.glb', // 替换为你的 GLB 文件路径(gltf) => {model = gltf.scene;scene.add(model);},undefined,(error) => {console.error('An error happened while loading the model:', error);});
};// 动画循环
const animate = () => {requestAnimationFrame(animate);controls.update();renderer.render(scene, camera);
};// 监听亮度变化
watch(brightness, (newBrightness) => {if (ambientLight) {ambientLight.intensity = newBrightness;}
});// 组件挂载时初始化
onMounted(() => {initThree();loadModel();animate();
});// 组件卸载时清理资源
onBeforeUnmount(() => {if (renderer) {renderer.dispose();}
});
</script><style scoped>
.three-container {width: 100%;height: 100vh;
}
</style>
http://www.lryc.cn/news/523873.html

相关文章:

  • Golang Gin系列-4:Gin Framework入门教程
  • 25西湖ctf
  • AI Agent:AutoGPT的使用方法
  • 2024年博客之星主题创作|Android 开发:前沿技术、跨领域融合与就业技能展望
  • 蓝桥杯小白备考指南
  • 面向对象的程序设计:以对象的方式进行思考
  • 酵母三杂交实验全解析:从技术到应用【泰克生物】
  • Git 分支合并
  • C# 以管理员方式启动程序全解析
  • CSS:语法、样式表、选择器
  • python轻量级框架-flask
  • SQL和MySQL以及DAX的日期表生成?数字型日期?将生成的日期表插入到临时表或者实体表中
  • 文件下载时利用redis的队列模式顺序下载文件,防止多文件任务下载导致OOM
  • 第13章:Python TDD完善货币加法运算(二)
  • 两份PDF文档,如何比对差异,快速定位不同之处?
  • ESP-Skainet语音唤醒技术,设备高效语音识别方案,个性化交互应用
  • 地图:nuxt3高德地图简单使用 / nuxt2 + amap
  • 走进DevOps:让开发与运维齐头并进
  • 力扣动态规划-5【算法学习day.99】
  • LLM(3) : 浏览器录制16K的音频并上传到后端
  • PyTorch使用教程(13)-一文搞定模型的可视化和训练过程监控
  • 服务器日志自动上传到阿里云OSS备份
  • 树莓派学习
  • NestJS中实现注入多个实现了同一个接口的Service
  • Qt按钮美化教程
  • 基于单片机的多功能蓝牙语音智能台灯(论文+源码)
  • 第15章:Python TDD应对货币类开发变化(二)
  • 算法随笔_13: 有效三角形的个数
  • WSL 2 自动更新 虚拟 IP 到 window hosts
  • 我在广州学Mysql 系列——触发器的使用