remotion-scaffold
npx skills add https://github.com/ncklrs/startup-os-skills --skill remotion-scaffold
Agent 安装分布
Skill 文档
Remotion Scaffold
Creates the foundational folder structure, configuration files, and organizational framework for Remotion video projects. This skill focuses exclusively on project setup and does NOT generate animation logic or component implementation.
What This Skill Does
Generates project scaffolding for:
- Directory structure â Organized folder layout for compositions, scenes, assets
- Configuration files â Base constants.ts, types.ts with empty templates
- Empty scene templates â Placeholder scene components with TODO markers
- Asset directories â Organized folders for images, audio, fonts
- Registration setup â Composition registration in Root.tsx
Scope Boundaries
IN SCOPE:
- Creating folder structure
- Writing empty file templates
- Setting up configuration skeleton
- Directory organization patterns
OUT OF SCOPE:
- Animation implementation (use
/remotion-animation) - Scene component logic (use
/remotion-component-gen) - Sequence composition (use
/remotion-composition) - Component generation (use
/remotion-component-gen)
Input/Output Formats
Input Format: Project Requirements
Accepts project setup requirements:
Natural Language:
Create a new Remotion project scaffold for a 30-second video with 4 scenes.
Structured Format:
## Project Requirements
**Project Name:** ProductDemo
**Duration:** 30 seconds
**Frame Rate:** 30 fps
**Dimensions:** 1920x1080 (16:9)
**Number of Scenes:** 4 (Intro, Features, Demo, CTA)
**Asset Types:** Images, Audio (music + SFX)
Output Format: SCAFFOLD_MANIFEST.md
Generates a manifest documenting created structure:
# Scaffold Manifest: ProductDemo
## Status
â
Directory structure created
â
Configuration files generated
â
Scene templates created (empty)
â³ Ready for implementation
## Generated Structure
src/remotion/compositions/ProductDemo/ âââ index.tsx # â Created – Main composition (empty) âââ constants.ts # â Created – Constants template âââ types.ts # â Created – Type definitions âââ scenes/ âââ Scene1Intro.tsx # â Created – Empty template âââ Scene2Features.tsx # â Created – Empty template âââ Scene3Demo.tsx # â Created – Empty template âââ Scene4CTA.tsx # â Created – Empty template
public/ âââ images/ # â Created – Empty directory âââ audio/ â âââ music/ # â Created – Empty directory â âââ sfx/ # â Created – Empty directory âââ fonts/ # â Created – Empty directory
## File Templates Created
### Main Composition: `index.tsx`
```typescript
import { AbsoluteFill, Sequence } from "remotion";
import { SCENE_TIMING } from "./constants";
import { Scene1Intro } from "./scenes/Scene1Intro";
import { Scene2Features } from "./scenes/Scene2Features";
import { Scene3Demo } from "./scenes/Scene3Demo";
import { Scene4CTA } from "./scenes/Scene4CTA";
import type { ProductDemoProps } from "./types";
export function ProductDemo({}: ProductDemoProps) {
return (
<AbsoluteFill>
{/* TODO: Add composition layout via /remotion-composition */}
<Sequence
from={SCENE_TIMING.intro.start}
durationInFrames={SCENE_TIMING.intro.duration}
>
<Scene1Intro />
</Sequence>
{/* Additional scenes... */}
</AbsoluteFill>
);
}
Constants: constants.ts
// TODO: Define color palette
export const COLORS = {
// Add colors here
} as const;
// TODO: Configure spring animations via /remotion-animation
export const SPRING_CONFIGS = {
// Add spring configs here
} as const;
// Scene timing (30fps, 30 seconds total = 900 frames)
const FPS = 30;
export const SCENE_TIMING = {
intro: { start: 0, duration: 5 * FPS },
features: { start: 5 * FPS, duration: 10 * FPS },
demo: { start: 15 * FPS, duration: 10 * FPS },
cta: { start: 25 * FPS, duration: 5 * FPS },
} as const;
Types: types.ts
export interface ProductDemoProps {
// Add custom props here
}
export interface SceneProps {
// Common scene props
}
Scene Template: scenes/Scene1Intro.tsx
import { AbsoluteFill } from "remotion";
export function Scene1Intro() {
return (
<AbsoluteFill>
{/* TODO: Implement scene via /remotion-component-gen */}
</AbsoluteFill>
);
}
Next Steps
- Define animations â Run
/remotion-animationto generate animation configs - Build composition â Run
/remotion-compositionto structure Sequence layout - Implement scenes â Run
/remotion-component-genfor each scene - Configure render â Run
/remotion-render-configfor output settings - Add assets â Run
/remotion-asset-coordinatorfor asset preparation
Configuration Summary
| Setting | Value |
|---|---|
| Composition ID | ProductDemo |
| Duration | 30 seconds (900 frames) |
| Frame Rate | 30 fps |
| Dimensions | 1920×1080 (16:9) |
| Scenes | 4 (Intro, Features, Demo, CTA) |
| Status | Scaffold complete, ready for implementation |
File Locations
All files created in:
- Composition:
/path/to/project/src/remotion/compositions/ProductDemo/ - Assets:
/path/to/project/public/
Scaffold Checklist
Creation checklist:
- Create composition folder structure
- Generate main composition file (
index.tsx) with TODO markers - Generate constants file (
constants.ts) as template - Generate types file (
types.ts) - Create empty scene component files
- Create asset directories (
public/images/,public/audio/) - Add composition registration skeleton
- Animation implementation (next:
/remotion-animation) - Composition logic (next:
/remotion-composition) - Scene implementation (next:
/remotion-component-gen)
## Directory Structure Patterns
### Pattern 1: Simple Project (1-2 scenes)
src/remotion/compositions/VideoName/ âââ index.tsx # Main composition âââ constants.ts # Configuration constants âââ types.ts # TypeScript types
### Pattern 2: Multi-Scene Project (3+ scenes)
src/remotion/compositions/VideoName/ âââ index.tsx # Main composition âââ constants.ts # Shared constants âââ types.ts # Type definitions âââ scenes/ âââ Scene1.tsx âââ Scene2.tsx âââ Scene3.tsx
### Pattern 3: Complex Project (with audio)
src/remotion/compositions/VideoName/ âââ index.tsx # Main composition âââ constants.ts # Configuration âââ types.ts # Types âââ audio.ts # Audio configuration âââ scenes/ âââ …
### Pattern 4: Component Library Project
src/remotion/ âââ components/ â âââ particles/ â âââ text/ â âââ progress/ â âââ transitions/ âââ compositions/ â âââ VideoName/ âââ utils/ âââ seededRandom.ts âââ timing.ts
## File Templates
### Empty Main Composition
```typescript
import { AbsoluteFill } from "remotion";
import type { VideoNameProps } from "./types";
export function VideoName({}: VideoNameProps) {
return (
<AbsoluteFill>
{/* TODO: Add composition structure via /remotion-composition */}
</AbsoluteFill>
);
}
Empty Constants Template
// TODO: Define via /remotion-animation
export const COLORS = {} as const;
export const SPRING_CONFIGS = {} as const;
export const SCENE_TIMING = {} as const;
Empty Types Template
export interface VideoNameProps {
// Add props here
}
Empty Scene Template
import { AbsoluteFill } from "remotion";
export function Scene1() {
return (
<AbsoluteFill>
{/* TODO: Implement via /remotion-component-gen */}
</AbsoluteFill>
);
}
Registration Template
Add to src/remotion/Root.tsx:
import { Composition } from "remotion";
import { VideoName } from "./compositions/VideoName";
// Add to RemotionRoot component:
<Composition
id="VideoName"
component={VideoName}
durationInFrames={900} // TODO: Calculate based on requirements
fps={30}
width={1920}
height={1080}
defaultProps={{}}
/>
Video Format Presets
Quick reference for common video formats:
// YouTube (16:9)
{ width: 1920, height: 1080, fps: 30 }
// Instagram Reels / TikTok (9:16)
{ width: 1080, height: 1920, fps: 30 }
// Twitter/X (16:9)
{ width: 1920, height: 1080, fps: 30 }
// Square (1:1)
{ width: 1080, height: 1080, fps: 30 }
Asset Directory Organization
Standard asset directory structure:
public/
âââ images/
â âââ logos/
â âââ backgrounds/
â âââ icons/
âââ audio/
â âââ music/
â âââ sfx/
âââ fonts/
âââ [custom-fonts].woff2
Scaffold Workflow
- Parse requirements â Extract project name, duration, scenes, format
- Create directories â Generate folder structure
- Write empty templates â Create files with TODO markers
- Setup registration â Add composition to Root.tsx
- Generate manifest â Document created structure in SCAFFOLD_MANIFEST.md
- Hand off â Direct to specialized skills for implementation
Integration with Other Skills
This skill is the FIRST STEP in the pipeline:
remotion-scaffold (this skill)
â outputs: SCAFFOLD_MANIFEST.md
remotion-animation
â outputs: ANIMATION_CONFIG.md
remotion-composition
â outputs: COMPOSITION_STRUCTURE.md
remotion-component-gen (per scene)
â outputs: SCENE_COMPONENT.md
remotion-render-config
â outputs: RENDER_CONFIG.md
Works with:
/motion-designerâ Project requirements may come from design specs/remotion-animationâ Next step for animation configuration/remotion-compositionâ Next step for composition structure/remotion-component-genâ Next step for scene implementation/remotion-render-configâ Final step for render settings
This skill provides clean, minimal project scaffolding that serves as the foundation for the Remotion implementation pipeline.