基于three.js的室内全景3D展馆案例分享

  • 先看效果图
    • 实现了第一人称行走,WASD
    • 点击目标画册进行预览查看
    • 位置音乐播放环绕
    • 地面镜面反光
    • 碰撞检测等等.

地址在gitee上gallery: 数字展馆概念的demo项目,本项目中使用的技术栈为three.js

有兴趣的伙伴可以去下载看看,有这方面的项目应该能受很大启发。

import Core from "../core";

import Environment from "../environment";

import Character from "../character";

import Css3DRenderer from "../css3DRenderer";

import Audio from "../audio";

import RayCasterControls from "../rayCasterControls";

import {ON_CLICK_RAY_CAST, ON_HIDE_TOOLTIP, ON_LOAD_MODEL_FINISH, ON_LOAD_PROGRESS, ON_ENTER_APP, ON_SHOW_TOOLTIP} from "../Constants";

import {Object3D} from "three";

export default class World {

private core: Core;

private environment: Environment;

private character: Character;

private css_3d_renderer: Css3DRenderer;

private audio: Audio;

private ray_caster_controls: RayCasterControls;

constructor() {

this.core = new Core();

this.core.$on(ON_LOAD_PROGRESS, this._handleLoadProgress.bind(this));

this.core.$on(ON_LOAD_MODEL_FINISH, this._onLoadModelFinish.bind(this));

this.core.$on(ON_CLICK_RAY_CAST, this._onClickRayCast.bind(this));

this.core.$on(ON_SHOW_TOOLTIP, this._onShowTooltip.bind(this));

this.core.$on(ON_HIDE_TOOLTIP, this._onHideTooltip.bind(this));

this.core.$on(ON_ENTER_APP, this._onEnterApp.bind(this));

this.environment = new Environment();

this.character = new Character({speed: 12});

this.css_3d_renderer = new Css3DRenderer();

this.audio = new Audio();

this.ray_caster_controls = new RayCasterControls();

}

update(delta: number) {

if (this.environment.collider && this.environment.is_load_finished) {

this.css_3d_renderer.update();

this.character.update(delta, this.environment.collider);

this.ray_caster_controls.updateTooltipRayCast(this.environment.raycast_objects);

}

}

/*

* 点击进入展馆后的回调

* */

private _onEnterApp() {

this.audio.playAudio();

// 进入后才允许控制键盘

this.core.control_manage.enabled();

}

private async _onLoadModelFinish() {

// 场景模型加载完毕后开始加载音频

await this.audio.createAudio();

// 音频加载完毕后移除加载进度UI,显示进入确认UI

this.core.ui.removeLoading();

this.core.ui.showLoadingConfirm();

// 场景模型加载完毕后将场景中需要光线投射检测的物体传入给rayCasterControls

this.ray_caster_controls.bindClickRayCastObj(this.environment.raycast_objects);

}

private _handleLoadProgress([{url, loaded, total}]: [{url: string, loaded: number, total: number}]) {

const percentage = ((loaded / total) * 100).toFixed(2);

if (/.*\.(blob|glb)$/i.test(url)) {

this.core.ui.updateLoadingProgress(`{url.includes("collision") ? "加载碰撞场景模型" : "加载其他场景模型"}:{percentage}%`);

}

if (/.*\.(jpg|png|jpeg)$/i.test(url)) {

this.core.ui.updateLoadingProgress("加载图片素材中...");

}

if (/.*\.(m4a|mp3)$/i.test(url)) {

this.core.ui.updateLoadingProgress("加载声音资源中...");

}

}

private _onClickRayCast([object]: [object: Object3D]) {

this.core.ui.showBoardsBox(

object.userData.title,

object.userData.author,

object.userData.describe,

object.userData.src,

);

}

private _onShowTooltip([{msg, show_preview_tips}]: [{ msg: string, show_preview_tips: boolean }]) {

this.core.ui.showPreviewTooltip(msg, show_preview_tips);

}

private _onHideTooltip() {

this.core.ui.hidePreviewTooltip();

}

}

相关推荐
微风中的麦穗9 分钟前
【MATLAB】MATLAB R2025a 详细下载安装图文指南:下一代科学计算与工程仿真平台
开发语言·matlab·开发工具·工程仿真·matlab r2025a·matlab r2025·科学计算与工程仿真
2601_9491465317 分钟前
C语言语音通知API示例代码:基于标准C的语音接口开发与底层调用实践
c语言·开发语言
开源技术28 分钟前
Python Pillow 优化,打开和保存速度最快提高14倍
开发语言·python·pillow
学嵌入式的小杨同学34 分钟前
从零打造 Linux 终端 MP3 播放器!用 C 语言实现音乐自由
linux·c语言·开发语言·前端·vscode·ci/cd·vim
mftang2 小时前
Python 字符串拼接成字节详解
开发语言·python
jasligea2 小时前
构建个人智能助手
开发语言·python·自然语言处理
yuezhilangniao2 小时前
AI智能体全栈开发工程化规范 备忘 ~ fastAPI+Next.js
javascript·人工智能·fastapi
kokunka2 小时前
【源码+注释】纯C++小游戏开发之射击小球游戏
开发语言·c++·游戏
云栖梦泽3 小时前
易语言开发从入门到精通:补充篇·网络编程进阶+实用爬虫开发·API集成·代理IP配置·异步请求·防封禁优化
开发语言
java1234_小锋4 小时前
Java高频面试题:SpringBoot为什么要禁止循环依赖?
java·开发语言·面试