babylonjs

📁 curiosity-ai-bv/babylonjs-skill 📅 3 days ago
4
总安装量
4
周安装量
#54310
全站排名
安装命令
npx skills add https://github.com/curiosity-ai-bv/babylonjs-skill --skill babylonjs

Agent 安装分布

opencode 4
gemini-cli 4
github-copilot 4
codex 4
kimi-cli 4
amp 4

Skill 文档

Babylon.js 8

Quick Reference

Babylon.js is a powerful open-source 3D engine for the web. Version 8 supports WebGL2 and WebGPU.

Coordinate system: Left-handed (X=right, Y=up, Z=forward). Rotations in radians.

NPM packages:

  • @babylonjs/core – Engine, scene, meshes, materials, cameras, lights
  • @babylonjs/gui – 2D/3D GUI controls
  • @babylonjs/loaders – glTF, OBJ, STL loaders
  • @babylonjs/materials – Extra material types
  • @babylonjs/inspector – Debug inspector

Tree-shaking: Import from deep paths for minimal bundles:

import { Scene } from "@babylonjs/core/scene";
import { Vector3 } from "@babylonjs/core/Maths/math.vector";
import { Color3, Color4 } from "@babylonjs/core/Maths/math.color";
import { Mesh } from "@babylonjs/core/Meshes/mesh";
import { PBRMaterial } from "@babylonjs/core/Materials/PBR/pbrMaterial";
import { ArcRotateCamera } from "@babylonjs/core/Cameras/arcRotateCamera";

Side-effect imports (enable features without referencing exports):

import "@babylonjs/core/Meshes/thinInstanceMesh";
import "@babylonjs/core/Rendering/edgesRenderer";
import "@babylonjs/core/Collisions/collisionCoordinator";
import "@babylonjs/loaders/glTF/2.0/glTFLoader";

Minimal Scene Setup

import { Engine } from "@babylonjs/core/Engines/engine";
import { Scene } from "@babylonjs/core/scene";
import { ArcRotateCamera } from "@babylonjs/core/Cameras/arcRotateCamera";
import { HemisphericLight } from "@babylonjs/core/Lights/hemisphericLight";
import { Vector3 } from "@babylonjs/core/Maths/math.vector";
import { CreateSphere } from "@babylonjs/core/Meshes/Builders/sphereBuilder";
import { CreateGround } from "@babylonjs/core/Meshes/Builders/groundBuilder";

const engine = new Engine(canvas, true);
const scene = new Scene(engine);
const camera = new ArcRotateCamera("cam", 0, Math.PI/4, 10, Vector3.Zero(), scene);
camera.attachControl(canvas, true);
const light = new HemisphericLight("light", new Vector3(0, 1, 0), scene);
const sphere = CreateSphere("sphere", { diameter: 2 }, scene);
const ground = CreateGround("ground", { width: 6, height: 6 }, scene);
sphere.position.y = 1;

engine.runRenderLoop(() => scene.render());
window.addEventListener("resize", () => engine.resize());

Key Patterns

PBR Material (most common for realistic rendering)

const pbr = new PBRMaterial("pbr", scene);
pbr.albedoColor = new Color3(1.0, 0.766, 0.336);
pbr.metallic = 0.3;
pbr.roughness = 0.7;
// Optional: connect to environment for reflections
pbr.reflectionTexture = scene.environmentTexture;
mesh.material = pbr;

Thin Instances (high-performance batching)

import "@babylonjs/core/Meshes/thinInstanceMesh";
const buffer = new Float32Array(16 * count);
for (let i = 0; i < count; i++) {
  Matrix.Translation(x, y, z).copyToArray(buffer, i * 16);
}
mesh.thinInstanceSetBuffer("matrix", buffer, 16, false);
mesh.thinInstanceBufferUpdated("matrix");

Asset Loading (glTF)

import "@babylonjs/loaders/glTF/2.0/glTFLoader";
const container = await BABYLON.LoadAssetContainerAsync("model.glb", scene);
container.addAllToScene();

Observable Pattern (Babylon’s event system)

scene.onBeforeRenderObservable.add(() => { /* per frame */ });
const observer = scene.onPointerObservable.add((info) => { /* pointer events */ });
scene.onPointerObservable.remove(observer); // unsubscribe

Reference Files

Read these files for detailed API patterns on specific topics:

  • core-concepts.md – Engine/Scene setup, cameras, lights, shadows, observables, coordinate system
  • meshes.md – Mesh builders, transforms, TransformNode, instances, thin instances, clones, merging, picking
  • materials.md – PBR, Standard, textures, environment/HDR, Node Material, Shader Material
  • gui.md – AdvancedDynamicTexture, all control types, containers, layout, events
  • animation-loading.md – Animation API, groups, easing, skeletal animation, asset loading, AssetContainer
  • performance.md – Scene/mesh/material optimization, instancing strategy comparison, monitoring, memory management

On-Demand Documentation

For topics not covered in the reference files, fetch from the live docs:

  • Doc site: https://doc.babylonjs.com
  • GitHub raw markdown: https://raw.githubusercontent.com/BabylonJS/Documentation/master/content/{path}.md
  • doc-urls.md – Complete URL map for all doc sections

To fetch a specific topic, read the URL map to find the path, then use WebFetch on the doc site URL or fetch raw markdown from GitHub.

Topics covered only in live docs (not in reference files)

  • Physics V2 (Havok): /features/featuresDeepDive/physics
  • WebXR/VR/AR: /features/featuresDeepDive/webXR
  • Post-processing pipelines: /features/featuresDeepDive/postProcesses
  • Solid Particle System: /features/featuresDeepDive/particles/solid_particle_system
  • Crowd navigation: /features/featuresDeepDive/crowdNavigation
  • Node Geometry (procedural): /features/featuresDeepDive/mesh/nodeGeometry
  • Frame Graph: /features/featuresDeepDive/frameGraph
  • Flow Graph: /features/featuresDeepDive/flowGraph
  • Smart Filters: /features/featuresDeepDive/smartFilters
  • Gaussian Splatting: /features/featuresDeepDive/importers (splat/ply formats)

Common Gotchas

  1. Quaternion vs Euler: Setting mesh.rotationQuaternion disables mesh.rotation. To switch back: mesh.rotationQuaternion = null.
  2. Side-effect imports: Features like thin instances, edge rendering, loaders, and collisions require importing their module even if you don’t use the export directly.
  3. Dispose everything: Babylon.js doesn’t garbage-collect GPU resources. Always call .dispose() on meshes, materials, textures when done.
  4. Material sharing: Modifying a shared material affects all meshes using it. Clone or create new materials for independent changes.
  5. TransformNode vs Mesh: Use TransformNode for grouping/hierarchy. Empty Mesh objects waste CPU on frustum evaluation.
  6. Left-handed coordinates: glTF is right-handed; Babylon auto-converts on import. Manual coordinate math may need adjustment.
  7. Alpha sorting: Transparent meshes require proper render ordering. Use mesh.alphaIndex or rendering groups.
  8. Thin instance limitations: All-or-nothing visibility, single bounding box, no per-instance material. Use regular instances when individual control is needed.