PLY三维模型在vue中的展示

ply三维模型的展示,使用gsplat插件,该插件需要在vue3中使用:

引入插件

import * as SPLAT from 'gsplat';

一、创建html

html 复制代码
<div class="container_model">
		<canvas id="canvasId" class="model_box" ref="canvasRef"></canvas>
		<div class="progress_view" v-if="isShowProgress">
			<el-progress
				:percentage="currentPercentage"
				:show-text="false"
				style="width:100%;"
				striped
				striped-flow
				:stroke-width="15"
			/>
		</div>
	</div>

因为我这里的ply模型的size比较大,就添加了一个进度条

二、初始化属性

html 复制代码
const canvasRef = ref();
const animationId = ref();
const isShowProgress = ref(false);
const currentPercentage = ref(0);
let scene: SPLAT.Scene, renderer: SPLAT.WebGLRenderer, camera: SPLAT.Camera, controls: SPLAT.OrbitControls;

三、添加模型初始化方法

html 复制代码
/**
 * 加载ply高斯模型
 * @param url
 */
const initModel = async (url: any) => {
	if (!url) return;
	try {
		isShowProgress.value = true;//展示进度条
		scene = new SPLAT.Scene();
		camera = new SPLAT.Camera();
		renderer = new SPLAT.WebGLRenderer(canvasRef.value);
		controls = new SPLAT.OrbitControls(camera, renderer.canvas);
		const splatModel = await SPLAT.PLYLoader.LoadAsync(url, scene, (progress) => {
			currentPercentage.value = Math.round(progress * 1000) / 10;
			if (currentPercentage.value >= 100) {
				isShowProgress.value = false;
			}
		});
        //这里根据自己的模型进行旋转、缩放、平移,把模型展示在可视范围中
		//旋转
		const euler = new SPLAT.Vector3(Math.PI / 2, -Math.PI / 5, 0);
		const quaternionz = SPLAT.Quaternion.FromEuler(euler);
		splatModel.data.rotate(quaternionz);
		//缩放
		const scale = new SPLAT.Vector3(0.2, 0.2, 0.2);
		splatModel.data.scale(scale);
		//平移
		const translate = new SPLAT.Vector3(0, 0, -3);
		splatModel.data.translate(translate);

		resizeChange();
		window.addEventListener('resize', resizeChange);
		animate();
	} catch (err) {
		isShowProgress.value = false;
		console.log('加载模型报错:' + err);
	}
};

const resizeChange = () => {
	renderer.setSize(canvasRef.value.clientWidth, canvasRef.value.clientHeight);
};
const animate = () => {
	animationId.value = requestAnimationFrame(animate);
	controls.update();
	renderer.render(scene, camera);
};
//页面销毁时,销毁模型
const removeModel = () => {
	if (animationId.value) {
		cancelAnimationFrame(animationId.value);
	}
	controls && controls.dispose();
	renderer && renderer.dispose();
	if (scene) {
		let models = scene.objects || [];
		models.forEach((item: any) => {
			scene.removeObject(item);
		});
	}
	window.removeEventListener('resize', resizeChange);
};
相关推荐
kyriewen115 小时前
Next.js:让你的React应用从“裸奔”到“穿衣服”
开发语言·前端·javascript·react.js·设计模式·ecmascript
MXN_小南学前端5 小时前
基于 Vue3 + ECharts 的数据大屏实例(提供gitHub仓库地址)
前端·javascript·echarts
宁雨桥5 小时前
for of,for in以及传统for循环的区别与不同场景下的使用选择
前端·javascript
椰羊~王小美6 小时前
除了前端 JS 配置的国际化,对于 JS 没覆盖到的文本,怎么实现国际化
前端·javascript·状态模式
AC赳赳老秦6 小时前
DBA 专属方案:用 OpenClaw 实现 SQL 语句优化、慢查询分析、数据库备份巡检全自动化
服务器·前端·数据库·ffmpeg·自动化·deepseek·openclaw
燐妤6 小时前
前端HTML编程1:初识html
前端·html5
xiaoye37086 小时前
java接口文档工具 swagger2和swagger3对比
java·服务器·前端
tongyiixiaohuang6 小时前
基于轻易云的数据集成,实现企业系统间灵活对接
java·前端·数据库
哥本哈士奇6 小时前
Power BI学习笔记第17篇:Power BI Dashboard 常用布局方案推荐
前端·powerbi
军军君017 小时前
数字孪生监控大屏实战模板:固体颗粒物监管平台
前端·javascript·vue.js·typescript·前端框架·echarts·less