skills/phaser-gamedev/SKILL.md
Phaser 3 2D game dev: scenes, physics, tilemaps, sprites, polish.
npx skillsauth add notque/claude-code-toolkit phaser-gamedevInstall this skill globally with one command. Works with Claude Code, Cursor, and Windsurf.
3 of 9 scanners reported clean
Some scanners were skipped, did not run, or reported a non-clean status. Review each row below.
This skill builds complete Phaser 3 2D games using a Phased Construction pattern: DESIGN (plan game type, physics, scenes) → BUILD (scene lifecycle, sprites, tilemaps) → ANIMATE (physics, animation state machines, input) → POLISH (camera effects, particles, tweens, sound, mobile). Targets Phaser 3.60+ throughout.
Scope: Platformers, arcade shooters, top-down RPGs, puzzle games, and side-scrollers — anything 2D in Phaser 3. Use threejs-builder for 3D games, native mobile games, and non-Phaser canvas work.
| Signal | Load These Files | Why |
|---|---|---|
| references/core-patterns.md | core-patterns.md | Always |
| references/build-scaffolds.md | build-scaffolds.md | Phase 2 BUILD |
| references/animate-scaffolds.md | animate-scaffolds.md | Phase 3 ANIMATE |
| references/polish-scaffolds.md | polish-scaffolds.md | Phase 4 POLISH |
| references/errors.md | errors.md | Error Handling |
| references/arcade-physics.md | arcade-physics.md | Arcade physics |
| references/tilemaps.md | tilemaps.md | Tilemap / Tiled |
| references/spritesheets.md | spritesheets.md | Sprites / animation |
| references/performance.md | performance.md | Performance concern |
| references/game-feel-patterns.md | game-feel-patterns.md | Polish / juice signal |
| references/tilemaps-and-physics.md | tilemaps-and-physics.md | Complex maps / Matter.js |
Goal: Understand what to build, select the physics system, and plan the scene graph before writing any code.
Core constraints:
Step 1: Identify the game type
From the user's request, determine: game genre (platformer, shooter, RPG, puzzle, side-scroller), primary physics need, number of scenes, tilemap or procedural world, spritesheet or texture atlas.
Step 2: Select the physics system
| Physics | Use When | When Not to Use | |---------|----------|------------| | Arcade | Platformers, shooters, simple AABB | Rotating bodies, non-rectangular shapes | | Matter.js | Physics puzzles, destructible terrain | Performance-critical (100+ bodies) | | None | Puzzles, card games, UI-only | Any meaningful collision detection |
Step 3: Document the scene plan and load references
Write a short markdown scene plan covering: Boot, Game, UI, Physics choice, World, Sprites (measured frame dimensions).
Load these references based on the plan:
references/core-patterns.md (scene lifecycle, transitions, input)references/tilemaps.mdreferences/spritesheets.mdreferences/arcade-physics.mdreferences/performance.mdreferences/game-feel-patterns.mdreferences/tilemaps-and-physics.mdGate: Scene plan documented. Physics system selected. References loaded. Proceed only when gate passes.
Goal: Implement the scene lifecycle skeleton, load assets, place sprites, wire up tilemaps.
Core constraints:
frameWidth/frameHeight is the #1 Phaser bug; open the PNG, count pixels per frame before writing this.load.spritesheet()preload() — never load assets in create() or update()Full TypeScript scaffolds (entry point, BootScene with progress bar, GameScene skeleton): references/build-scaffolds.md.
Gate: Boot and Game scenes compile. Assets load without console errors. Scene transitions work. Proceed only when gate passes.
Goal: Add physics-driven movement, animation state machines, and player input.
Core constraints:
update() — no new Phaser.Math.Vector2(), no this.physics.add.sprite(), no array creation per frame; allocate in create(), reuse in update()delta for frame-rate-independent movement — velocity = speed * (delta / 1000) ensures consistent feel at any FPS'idle' | 'walk' | 'jump' | 'attack' | 'dead' prevents impossible states like isJumping && isAttackingAnimation definitions (anims.create), the Player state machine, and input handling scaffolds: references/animate-scaffolds.md. Collision groups, overlap callbacks, and physics tuning: references/arcade-physics.md.
Gate: Player moves. Animations transition correctly. State machine has no impossible state combinations. No per-frame allocations. Proceed only when gate passes.
Goal: Add camera work, particles, tweens, sound, and mobile controls. Verify performance.
Core constraints:
debug: true from physics config before shippingconsole.log calls unless the user explicitly requested loggingFull scaffolds for camera effects, particles (Phaser 3.60+ API), tweens, sound, mobile virtual controls, and final verification steps: references/polish-scaffolds.md.
Gate: Polish checks pass. Performance within budget. Debug config removed. Game is shippable.
Common errors and fixes (spritesheet frame mismatches, undefined body access, tilemap collision no-ops, animation failures, mobile slowdowns): references/errors.md.
| Reference | When to Load | Content |
|-----------|-------------|---------|
| references/core-patterns.md | Always | Scene lifecycle, transitions, input, state machines |
| references/build-scaffolds.md | Phase 2 BUILD | TypeScript entry point, BootScene with progress bar, GameScene skeleton |
| references/animate-scaffolds.md | Phase 3 ANIMATE | Animation definitions, Player state machine, input handling |
| references/polish-scaffolds.md | Phase 4 POLISH | Camera, particles, tweens, sound, mobile controls, verification |
| references/errors.md | Error Handling | Common Phaser error scenarios and fixes |
| references/arcade-physics.md | Arcade physics | Groups, colliders, velocity, physics tuning, pitfalls |
| references/tilemaps.md | Tilemap / Tiled | Layer system, collision, animated tiles, object layers |
| references/spritesheets.md | Sprites / animation | Frame measurement, loading, atlases, nine-slice |
| references/performance.md | Performance concern | Object pooling, GC avoidance, texture atlases, mobile |
| references/game-feel-patterns.md | Polish / juice signal | Screen shake, particle bursts, hit-stop, scale punch, tween chains, sound timing |
| references/tilemaps-and-physics.md | Complex maps / Matter.js | Tiled integration pipeline, Matter.js vs Arcade decision table, collision categories, slopes, object layer spawning |
documentation
Document translation: quick/normal/refined modes with chunked parallel subagents and glossary support.
development
AI image generation: Gemini and Nano Banana backends; single/series/batch workflows with prompt-to-disk.
testing
Unified voice content generation pipeline with mandatory validation and joy-check. 13-phase pipeline: LOAD, GROUND, STATS-CHECKPOINT, GENERATE, HOOK-GATE, VALIDATE, REFINE, VARIETY-GATE, JOY-CHECK, ANTI-AI, CLOSE-GATE, OUTPUT, CLEANUP. Use when writing articles, blog posts, or any content that uses a voice profile. Use for "write article", "blog post", "write in voice", "generate content", "draft article", "write about".
documentation
Critique-and-rewrite loop for voice fidelity validation.