使用Typescript开发Babylon.js的Vue3模板参考

main.js文件

TypeScript 复制代码
// main.ts
import { createApp } from 'vue'
import App from './App.vue'

createApp(App).mount('#app')

App.vue文件

TypeScript 复制代码
<!-- App.vue -->
<template>
  <div class="app-container">
    <BabylonScene />
  </div>
</template>

<script setup lang="ts">
import BabylonScene from './components/BabylonScene.vue'
</script>

<style>
.app-container {
  width: 100vw;
  height: 100vh;
  margin: 0;
  padding: 0;
  overflow: hidden;
}
</style>

BabylonScene.vue文件

TypeScript 复制代码
<!-- components/BabylonScene.vue -->
<template>
  <canvas ref="bjsCanvas" class="babylon-canvas"></canvas>
</template>

<script setup lang="ts">
import { ref, onMounted, onUnmounted } from 'vue'
import { Engine, Scene, ArcRotateCamera, Vector3, HemisphericLight, MeshBuilder } from '@babylonjs/core'

const bjsCanvas = ref<HTMLCanvasElement | null>(null)

// Babylon.js 初始化
let engine: Engine
let scene: Scene

const initBabylon = () => {
  if (!bjsCanvas.value) return

  // 创建引擎和场景
  engine = new Engine(bjsCanvas.value, true)
  scene = new Scene(engine)

  // 创建相机
  const camera = new ArcRotateCamera(
    'camera',
    Math.PI / 2,
    Math.PI / 3,
    8,
    Vector3.Zero(),
    scene
  )
  camera.attachControl(bjsCanvas.value, true)

  // 添加光源
  new HemisphericLight('light', new Vector3(1, 1, 0), scene)

  // 创建基础物体
  const box = MeshBuilder.CreateBox('box', {}, scene)
  const ground = MeshBuilder.CreateGround('ground', { width: 6, height: 6 }, scene)

  // 处理窗口resize
  window.addEventListener('resize', () => engine.resize())

  // 启动渲染循环
  engine.runRenderLoop(() => {
    scene.render()
  })
}

// 生命周期钩子
onMounted(() => {
  initBabylon()
})

onUnmounted(() => {
  // 清理资源
  scene?.dispose()
  engine?.dispose()
  window.removeEventListener('resize', () => engine?.resize())
})
</script>

<style scoped>
.babylon-canvas {
  width: 100%;
  height: 100%;
  touch-action: none;
}
</style>

包含功能介绍:

Vue3组件结构:

  • 使用Composition API和<script setup>语法

  • 响应式canvas引用

  • 生命周期管理(onMounted/onUnmounted)

Babylon.js基础配置:

  • 引擎初始化

  • 场景创建

  • 相机和光源设置

  • 基础几何体创建

  • 窗口resize处理

最佳实践:

  • 类型安全(TypeScript)

  • 资源清理

  • 内存管理

  • 响应式布局

使用步骤:

安装依赖:

TypeScript 复制代码
npm install vue @babylonjs/core core-js

需要配置TypeScript支持(在vite或vue-cli项目中)

可选扩展功能:

  • 添加GUI调试层

  • 加载3D模型

  • 添加物理引擎

  • 实现交互事件

  • 集成状态管理(Pinia)

要添加调试层,可以修改BabylonScene组件:

TypeScript 复制代码
// 在initBabylon中添加:
import '@babylonjs/core/Debug/debugLayer'
import '@babylonjs/inspector'

// 在创建场景后添加:
scene.debugLayer.show({
  embedMode: true
}).catch(() => {})

// 添加键盘事件切换调试器
window.addEventListener('keydown', (ev) => {
  if (ev.key === 'f9') {
    if (scene.debugLayer.isVisible()) {
      scene.debugLayer.hide()
    } else {
      scene.debugLayer.show()
    }
  }
})
相关推荐
长空任鸟飞_阿康17 分钟前
在 Vue 3.5 中优雅地集成 wangEditor,并定制“AI 工具”下拉菜单(总结/润色/翻译)
前端·vue.js·人工智能
liangshanbo121522 分钟前
React + TypeScript 企业级编码规范指南
ubuntu·react.js·typescript
JNU freshman1 小时前
vue 技巧与易错
前端·javascript·vue.js
北冥有鱼1 小时前
Vue3 中子组件修改父组件样式之—— global() 样式穿透使用指南
vue.js
我是日安2 小时前
从零到一打造 Vue3 响应式系统 Day 28 - shallowRef、shallowReactive
前端·javascript·vue.js
墨鸦_Cormorant3 小时前
Vue 概述以及基本使用
前端·javascript·vue.js
鹏多多3 小时前
使用imaskjs实现js表单输入卡号/日期/货币等掩码的教程
前端·javascript·vue.js
正在学习前端的---小方同学6 小时前
vue-easy-tree树状结构
前端·javascript·vue.js
毕业设计制作和分享7 小时前
springboot150基于springboot的贸易行业crm系统
java·vue.js·spring boot·后端·毕业设计·mybatis