当前位置: 首页 > 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>

相关文章:

vue3+three.js加载glb模型

<template><div><!-- 亮度调节滑块 --><div class"controls"><label for"brightness">背景光亮度&#xff1a;</label><inputtype"range"id"brightness"v-model"brightness"min&quo…...

Golang Gin系列-4:Gin Framework入门教程

在本章中&#xff0c;我们将深入研究Gin&#xff0c;一个强大的Go语言web框架。我们将揭示制作一个简单的Gin应用程序的过程&#xff0c;揭示处理路由和请求的复杂性。此外&#xff0c;我们将探索基本中间件的实现&#xff0c;揭示精确定义路由和路由参数的技术。此外&#xff…...

25西湖ctf

2025西湖冬季 图片不全去我blog找&#x1f447; 25西湖 | DDLS BLOG 文章所有参考将在文末给出 web web1 ssti 太简单的不赘述&#xff0c;知道用就行 {{cycler.__init__.__globals__.__builtins__[__import__](os).popen($(printf "\150\145\141\144\40\57\146\1…...

AI Agent:AutoGPT的使用方法

AutoGPT的使用方法 准备工作: 安装Python:确保你的电脑上安装了Python 3.8或更高版本。获取OpenAI API密钥:访问https://platform.openai.com/account/api-keys获取API密钥,并保存备用。获取Google API及Google Search Engine ID(可选):若要使用谷歌搜索功能,需访问htt…...

2024年博客之星主题创作|Android 开发:前沿技术、跨领域融合与就业技能展望

目录 引言 一、推动 Android 应用创新的核心力量 1.1 人工智能与机器学习的崛起 1.2 增强现实&#xff08;AR&#xff09;与虚拟现实&#xff08;VR&#xff09;的应用扩展 1.3 5G技术的推动 1.4 跨平台开发技术的成熟 1.4.1 React Native 1.4.2 Flutter 1.4.3 Taro …...

蓝桥杯小白备考指南

一、了解蓝桥杯 蓝桥杯大赛是工业和信息化部人才交流中心举办的全国性专业信息技术赛事 &#xff0c;旨在促进软件和信息领域专业技术人才培养&#xff0c;提升高校毕业生的就业竞争力。比赛涵盖多个编程语言组别&#xff0c;如 Java、C/C、Python 等。不同组别和参赛类别&…...

面向对象的程序设计:以对象的方式进行思考

1 理解接口与实现的区别 以上一篇文章的电视机需要插电使用的例子继续来讲解: 对电视而言,插电使用,只需要标准的插座即可,具体的电从哪里来,是火力发电厂,或是太阳能发电,亦或是畜电池逆变供电,电视机是不需要关心的。 发电厂或供电设备属于实现,220V交流电插座属于…...

酵母三杂交实验全解析:从技术到应用【泰克生物】

酵母三杂交实验&#xff08;Yeast Three-Hybrid, Y3H&#xff09;是酵母双杂交&#xff08;Y2H&#xff09;技术的扩展&#xff0c;专门用于研究更复杂的分子相互作用&#xff0c;尤其是小分子与蛋白质间的相互作用。通过引入小分子作为第三方调节因子&#xff0c;酵母三杂交技…...

Git 分支合并

Merge&#xff08;合并&#xff09; Merge 是 Git 中最常用的分支合并方式之一。当你想要将一个分支的更改合并到另一个分支时&#xff0c;你可以使用 Merge 操作。 合并步骤&#xff1a; 通常是从开发分支往主分支上合并代码的时候用 merge 1、git checkout master&#x…...

C# 以管理员方式启动程序全解析

引言 在 Windows 应用程序开发的领域中&#xff0c;C# 语言凭借其强大的功能和广泛的适用性&#xff0c;被众多开发者所青睐。然而&#xff0c;在实际的开发过程里&#xff0c;我们常常会遭遇这样的情况&#xff1a;程序需要访问特定的系统资源&#xff0c;像是系统文件夹、注…...

CSS:语法、样式表、选择器

目录 一、语法 二、创建 外部样式表 内部样式表 内联样式 三、选择器 ID选择器 类选择器 伪类选择器 :hover a:link a:active a:visited 属性选择器 伪元素选择器 ::first-letter ::first-line ::selection ::placeholder ::before 和::after 通配选择器 标…...

python轻量级框架-flask

简述 Flask 是 Python 生态圈中一个基于 Python 的Web 框架。其轻量、模块化和易于扩展的特点导致其被广泛使用&#xff0c;适合快速开发 Web 应用以及构建小型到中型项目。它提供了开发 Web 应用最基础的工具和组件。之所以称为微框架&#xff0c;是因为它与一些大型 Web 框架…...

SQL和MySQL以及DAX的日期表生成?数字型日期?将生成的日期表插入到临时表或者实体表中

几种生成日期表的方法 如何用SQL语句生成日期表呢&#xff1f; 如何用MySQL语句生成日期表呢&#xff1f; 如何用DAX语句生成日期表呢&#xff1f; 1. MySQL生成日期表 1.1 日期格式&#xff1a;yyyy-MM-dd 字符型 2024-01-02 -- 生成日期表 WITH RECURSIVE temp_dateTable …...

文件下载时利用redis的队列模式顺序下载文件,防止多文件任务下载导致OOM

1、controller层控制 Resourceprivate RedissonClient redissonClient;Slf4j Service public class CustomerSettlementExportServiceImpl implements ICustomerSettlementExportService { /*** 文件加入队列顺序导出** param pubFileExportList 参数* return 结果*/public Aja…...

第13章:Python TDD完善货币加法运算(二)

写在前面 这本书是我们老板推荐过的&#xff0c;我在《价值心法》的推荐书单里也看到了它。用了一段时间 Cursor 软件后&#xff0c;我突然思考&#xff0c;对于测试开发工程师来说&#xff0c;什么才更有价值呢&#xff1f;如何让 AI 工具更好地辅助自己写代码&#xff0c;或许…...

两份PDF文档,如何比对差异,快速定位不同之处?

PDF文档比对是通过专门的工具或软件&#xff0c;自动检测两个PDF文件之间的差异&#xff0c;并以可视化的方式展示出来。这些差异可能包括文本内容的修改、图像的变化、表格数据的调整、格式的改变等。比对工具通常会标记出新增、删除或修改的部分&#xff0c;帮助用户快速定位…...

ESP-Skainet语音唤醒技术,设备高效语音识别方案,个性化交互应用

在当今数字化、智能化飞速发展的时代&#xff0c;物联网&#xff08;IoT&#xff09;与人工智能&#xff08;AI&#xff09;的深度融合正在重塑我们的生活和工作方式。 在智能家居的生态系统中&#xff0c;语音唤醒技术不仅能够为用户提供个性化的服务&#xff0c;还能通过定制…...

地图:nuxt3高德地图简单使用 / nuxt2 + amap

一、官方网站 JS API 安全密钥使用-基础-进阶教程-地图 JS API 2.0 | 高德地图API 二、使用 2.1、创建应用 2.2、添加key&#xff0c;得到key值 2.3、nuxt3项目 引入amap 2.4、pages/map.vue <template><div class"container"><div id"map-co…...

走进DevOps:让开发与运维齐头并进

引言&#xff1a;开发与运维的“世纪和解” 还记得那些年&#xff0c;开发人员总是埋头写代码&#xff0c;然后甩手交给运维去部署&#xff0c;仿佛是把热山芋扔给别人。而运维呢&#xff0c;总是默默承受着系统崩溃、服务停机的风险&#xff0c;直到某一天他们终于忍不住咆哮&…...

力扣动态规划-5【算法学习day.99】

前言 ###我做这类文章一个重要的目的还是给正在学习的大家提供方向&#xff08;例如想要掌握基础用法&#xff0c;该刷哪些题&#xff1f;建议灵神的题单和代码随想录&#xff09;和记录自己的学习过程&#xff0c;我的解析也不会做的非常详细&#xff0c;只会提供思路和一些关…...

从“人海战术”到“算法军团”:TVA引发的劳动力革命(4)

——岗位重构&#xff1a;TVA时代&#xff0c;制造业劳动力的岗位迭代与技能升级TVA“算法军团”的普及&#xff0c;不仅替代了传统的体力型、重复型劳动力&#xff0c;更引发了制造业岗位体系的颠覆性重构——大量传统岗位被淘汰&#xff0c;一批全新岗位应运而生&#xff0c;…...

AI写论文哪家强?这4款AI论文生成工具测评结果告诉你答案!

你是否还在为撰写期刊论文、毕业论文或职称论文而感到焦虑呢&#xff1f;在进行人工撰写时&#xff0c;面对海量的文献就像在浩瀚的大海中捞针&#xff0c;而繁琐的格式要求更是让人头疼&#xff0c;反复修改的过程常常让我们的耐心耗尽&#xff0c;低效率的写作成为众多学术研…...

从月损耗20万到年增收300万:零售老板180天蜕变

李老板在二线城市经营着5家社区超市&#xff0c;年营收5000万&#xff0c;利润却越来越薄。一个残酷的数字让他夜不能寐&#xff1a;因线上线下系统割裂、手工操作繁多&#xff0c;每月生鲜损耗和运营错漏造成的损失超过20万元。他意识到&#xff0c;不变革&#xff0c;就是在慢…...

OpenClaw数据整理术:千问3.5-9B自动化清洗Excel数据

OpenClaw数据整理术&#xff1a;千问3.5-9B自动化清洗Excel数据 1. 为什么需要AI驱动的数据清洗 每次面对杂乱无章的Excel表格时&#xff0c;我都忍不住想起上个月那个加班的深夜。市场部发来的客户名单里&#xff0c;同一家公司的联系人分散在十几行&#xff0c;电话号码格式…...

mutt-wizard疑难排解终极指南:常见错误与解决方案完全清单

mutt-wizard疑难排解终极指南&#xff1a;常见错误与解决方案完全清单 【免费下载链接】mutt-wizard A system for automatically configuring mutt and isync with a simple interface and safe passwords 项目地址: https://gitcode.com/gh_mirrors/mu/mutt-wizard mu…...

Piggy_Packages V2026.1 帮助文档(七)WRFDA同化试验

数值天气预报的主要误差来源于初始场的误差。资料同化&#xff08;Data Assimilation&#xff09;是一种将观测资料与数值天气预报&#xff08;NWP&#xff09;产品及其各自的误差统计数据相结合的技术&#xff0c;旨在为数值模式提供更加准确的初始场。 在“Piggy_Packages V…...

营销管理5步流程指南

什么是营销管理流程&#xff1f; 营销管理流程是一种规划、组织和控制一个组织的营销活动的方法。营销管理流程是一套系统性的步骤&#xff0c;帮助企业通过满足客户需求来实现其目标。营销管理流程中的每一个步骤都帮助企业实现这些目标。 营销流程始于定义公司的组织目标和目…...

OpenClaw+Qwen2.5-VL-7B:低成本自动化内容生成方案

OpenClawQwen2.5-VL-7B&#xff1a;低成本自动化内容生成方案 1. 为什么选择这个组合 去年我开始尝试用AI辅助内容创作时&#xff0c;遇到了两个核心痛点&#xff1a;一是商业API调用成本太高&#xff0c;二是现有工具无法实现端到端的自动化。经过多次尝试&#xff0c;最终找…...

基于File-Based App开发MVP项目鸥

Issue 概述 先来看看提交这个 Issue 的作者是为什么想到这个点子的&#xff0c;以及他初步的核心设计概念。?? 本 PR 实现了 Apache Gravitino 与 SeaTunnel 的集成&#xff0c;将其作为非关系型连接器的外部元数据服务。通过 Gravitino 的 REST API 自动获取表结构和元数据&…...

Infoseek舆情系统决策树:在回应、沉默与引导间寻找最优解

对于许多品牌公关从业者而言&#xff0c;最难熬的时刻并非负面舆情爆发时的焦头烂额&#xff0c;而是事件初露端倪时的犹豫不决。手里攥着Infoseek舆情系统推送的早期预警&#xff0c;看着那条曲线正在缓慢抬头&#xff0c;一个终极难题摆在面前&#xff1a;是立刻回应以求先发…...