Ludo AI Game Assets
OfficialLudo AI MCP Server
Generate game assets using AI through the Model Context Protocol (MCP).
Features
Category | Capabilities |
Images | Sprites, icons, screenshots, backgrounds, UI assets, textures, background removal |
3D Models | Convert 2D images to GLB models with PBR textures |
Animation | Animated spritesheets from static sprites (4-64 frames), motion transfer from video or presets |
Video | Generate short videos from images (1-15 seconds, varies by model) |
Audio | Sound effects, background music, character voices, TTS |
Related MCP server: ComfyUI MCP Server
Quick Start
1. Get an API Key
Sign up at ludo.ai and get your API key from app.ludo.ai.
2. Configure Your MCP Client
Claude Desktop
Add to ~/Library/Application Support/Claude/claude_desktop_config.json (macOS) or %APPDATA%\Claude\claude_desktop_config.json (Windows):
{
"mcpServers": {
"ludo": {
"url": "https://mcp.ludo.ai/mcp",
"headers": {
"Authorization": "ApiKey YOUR_API_KEY"
}
}
}
}Cursor
Add to your MCP settings in Cursor preferences:
{
"mcpServers": {
"ludo": {
"url": "https://mcp.ludo.ai/mcp",
"headers": {
"Authorization": "ApiKey YOUR_API_KEY"
}
}
}
}Available Tools
Image Generation (createImage)
Generate sprites, icons, backgrounds, UI assets, and textures from a text prompt alone (no source image needed). To match the art style of an existing image use generateWithStyle, to modify an existing image use editImage, and to cut out a subject use removeBackground.
Parameter | Required | Description |
| Yes | Detailed description of the image |
| Yes |
|
| No |
|
| No |
|
| No |
|
| No | Number of variations (1-8, default: 1) |
| No | Client-provided ID to retrieve results later |
Credits: 0.5 per image
Edit Image (editImage)
Modify an existing image using text instructions (smart editing).
Parameter | Required | Description |
| Yes | URL or base64-encoded image to edit |
| Yes | Description of changes (e.g., "remove the background", "make it darker", "add clouds to the sky") |
| No | URL or base64 reference image for style/content guidance |
| No | Number of variations (1-4, default: 1) |
| No | Client-provided ID to retrieve results later |
Credits: 0.5 per image
Generate with Style (generateWithStyle)
Generate new content while maintaining the visual style of a reference image.
Parameter | Required | Description |
| Yes | URL or base64-encoded reference image for style matching |
| Yes | Description of what to generate (e.g., "a warrior character", "a treasure chest") |
| Yes |
|
| No | Number of variations (1-4, default: 1) |
| No | Client-provided ID to retrieve results later |
Credits: 0.5 per image
Generate Pose (generatePose)
Generate a new pose for an existing sprite. Use this BEFORE animateSprite to get the best animation results - the starting pose should match your intended animation.
Parameter | Required | Description |
| Yes | URL or base64-encoded sprite image |
| Yes | Target pose: |
| No | Additional instructions to guide pose generation |
| No | Number of variations (1-4, default: 1) |
| No | Client-provided ID to retrieve results later |
Returns: url, pose, motion_prompt
Example workflow:
Generate a "Walk (Left)" pose with
generatePoseUse the returned
motion_promptdirectly inanimateSpritefor optimal animation results
Credits: 0.5 per image
Rotate Sprite (rotateSprite)
Rotate the camera view of an existing sprite to a new angle, keeping the same character and pose. Useful for generating turnaround / directional views of a sprite.
Parameter | Required | Description |
| Yes | URL or base64-encoded sprite image |
| Yes | Camera azimuth in degrees: |
| No | Camera tilt in degrees: |
| No | Number of variations (1-4, default: 1) |
| No | Client-provided ID to retrieve results later |
Returns: url, camera_rotation, camera_elevation
Credits: 0.5 per image
Remove Background (removeBackground)
Remove the background from a single image, returning the subject isolated on a transparent background. For broader edits (not just cutting out the subject), use editImage instead.
Parameter | Required | Description |
| Yes | URL or base64-encoded image |
| No | Trim the result to the subject's bounding box (default: false) |
| No | Higher-quality output that may not match the input pixel-for-pixel (default: true) |
| No | Client-provided ID to retrieve results later |
Returns: a single result with url (transparent PNG)
Credits: 0.5 per image
3D Model Generation (create3DModel)
Convert a 2D image to a 3D GLB model with textures.
Parameter | Required | Description |
| Yes | URL or base64-encoded image |
| No |
|
| No |
|
| No | Triangle count 1,000-200,000 (default: 50,000) |
| No | Client-provided ID to retrieve results later |
Returns: model_url (GLB file) + 4 snapshot images from different angles
Credits: 3 per model Processing time: 60-120 seconds
Sprite Animation (animateSprite)
Create animated spritesheets from static images.
Parameter | Required | Description |
| Yes | URL or base64 of the starting frame |
| Yes | Animation description (e.g., "walking cycle", "idle breathing", "attack slash") |
| No |
|
| No |
|
| No |
|
| No | Seamless loop (default: true) |
| No | Crop frames to fit content; smaller spritesheets but inconsistent frame sizes |
| No | Padding around the sprite as a ratio 0.0–1.0 (only used when |
| No |
|
| No | Augment the motion prompt behind the scenes (default: true) |
| No |
|
| No | Depends on model — Blitz: |
| No | Ending frame for interpolation |
| No | Generate an animated GIF (default: false) |
| No | Extract individual frame images (default: false) |
| No | Also return the spritesheet with background intact, before background removal (default: false) |
| No | Client-provided ID to retrieve results later |
Returns: spritesheet_url, video_url, gif_url, individual_frame_urls, spritesheet_with_background_url, individual_frame_with_background_urls, num_frames, num_cols, num_rows
Credits: Varies by duration and model. Standard model: 1.9 credits/sec with a 4-credit minimum (e.g. ~1.2s = 4, 3s ≈ 5.7, 4s ≈ 7.6). Higher-quality models cost more per second. Processing time: 30-90 seconds
Animation Presets (listAnimationPresets)
List available animation presets for use with motion transfer. Returns preset animations, perspectives, and directions — no video URLs are exposed.
Returns:
animations— Array of presets withid,name,category,description,duration,preview_urlperspectives— Array withid,name,description(all animations support all perspectives)directions—["N", "NE", "E", "SE", "S", "SW", "W", "NW"](all animations support all directions)
Credits: Free
Motion Transfer (transferMotion)
Transfer motion from a video or animation preset onto a static sprite, producing an animated spritesheet.
Parameter | Required | Description |
| Yes | URL or base64-encoded sprite image |
| No | URL of the video to use as motion source. You can use videos from the animateSprite endpoint or provide your own. Videos up to 4 seconds will produce better results. Either |
| No | ID of an animation preset to use instead of a video URL. Use the animation-presets endpoint to list available presets. When using a preset, |
| No | Direction for the animation preset. When using a preset, |
| No | Perspective ID to use with the animation preset. When using a preset, |
| No | Number of frames in the output spritesheet |
| No | Size of each frame in pixels |
| No | Trim animation for seamless loop |
| No | Crop frames to fit content |
| No | Padding around sprite (0.0-1.0) |
| No |
|
| No | Generate an animated GIF (default: false) |
| No | Extract individual frame images (default: false) |
| No | Also return the spritesheet with background intact, before background removal (default: false) |
| No | Client-provided ID to retrieve results later |
Returns: spritesheet_url, video_url, gif_url, individual_frame_urls, spritesheet_with_background_url, individual_frame_with_background_urls, num_frames, num_cols, num_rows
Credits: Varies by duration: 4 credits/sec with a 4-credit minimum (default 1.5s = 6, up to 16 at 4s)
Video Generation (createVideo)
Generate short videos from images.
Parameter | Required | Description |
| Yes | URL or base64 starting frame |
| Yes | Motion description (e.g., "camera zooms in", "character walks forward") |
| No | Depends on model (defaults to the model's shortest) — Blitz: |
| No |
|
| No | Ending frame for interpolation |
| No | Client-provided ID to retrieve results later |
Credits: Varies by duration and model. Standard model: 1 credit/sec (3s = 3, 5s = 5, 8s = 8, 10s = 10). Higher-quality models cost more per second.
Sound Effect Generation (createSoundEffect)
Generate game sound effects from text descriptions.
Parameter | Required | Description |
| Yes | Sound description (e.g., "laser gun firing", "footsteps on gravel", "coin pickup") |
| No | 0-10 seconds (0 = automatic) |
| No | Client-provided ID to retrieve results later |
Credits: 2 per sound
Ambiance Generation (createAmbiance)
Generate ambient soundscapes and background atmospheres from text descriptions.
Parameter | Required | Description |
| Yes | Ambiance description (e.g., "windy forest at dusk", "busy medieval market", "spaceship engine hum") |
| No | Duration in seconds (0 = automatic, based on the description) |
| No | Augment the prompt behind the scenes (default: true) |
| No | Client-provided ID to retrieve results later |
Credits: 2 per generation
Music Generation (createMusic)
Generate background music and themes.
Parameter | Required | Description |
| Yes | Music description (e.g., "epic orchestral battle theme", "calm piano melody", "8-bit chiptune") |
| No | Optional lyrics for vocal tracks |
| No | Client-provided ID to retrieve results later |
Credits: 3 per track
Audio Transform (createAudioTransform)
Remix or transform an existing audio sample using a text prompt.
Parameter | Required | Description |
| Yes | URL or base64-encoded source audio sample to remix (15MB max) |
| Yes | Description guiding the remix (e.g., "make it sound like an 80s synthwave track") |
| No | Duration in seconds: |
| No | How strongly the source is modified (0 = close to original) |
| No | Augment the prompt behind the scenes (default: true) |
| No | Client-provided ID to retrieve results later |
Credits: 3 per generation
Voice Generation (createVoice)
Generate unique character voices.
Parameter | Required | Description |
| Yes | Character description (e.g., "gruff old warrior", "cheerful young girl") |
| Yes | Text to speak (max 200 characters) |
| No |
|
| No | Client-provided ID to retrieve results later |
Credits: 1 per voice
Text-to-Speech (createSpeech)
Clone a voice from an audio sample.
Parameter | Required | Description |
| Yes | Text to speak (max 1000 characters) |
| Yes | URL or base64 audio sample for voice cloning |
| No | Client-provided ID to retrieve results later |
Credits: 1 per generation
Text-to-Speech Preset (createSpeechPreset)
Use preset voices for text-to-speech.
Parameter | Required | Description |
| Yes | Text to speak (max 1000 characters) |
| Yes |
|
| No |
|
| No |
|
| No | Client-provided ID to retrieve results later |
Credits: 1 per generation
Retrieve Image Results (getImageResults)
Retrieve your recent API-generated images.
Parameter | Required | Description |
| No | Filter to a specific request |
Returns: Array of image objects with url, request_id, created_at
Credits: Free
Retrieve Sprite Results (getSpriteResults)
Retrieve your recent API-generated spritesheets.
Parameter | Required | Description |
| No | Filter to a specific request |
Returns: Array of spritesheet objects with request_id, created_at
Credits: Free
Retrieve Video Results (getVideoResults)
Retrieve your recent API-generated videos.
Parameter | Required | Description |
| No | Filter to a specific request |
Returns: Array of video objects with url, request_id, created_at
Credits: Free
Retrieve Audio Results (getAudioResults)
Retrieve your recent API-generated audio.
Parameter | Required | Description |
| No | Filter to a specific request |
Returns: Array of audio objects with request_id, created_at
Credits: Free
Retrieve 3D Model Results (get3DModelResults)
Retrieve your recent API-generated 3D models.
Parameter | Required | Description |
| No | Filter to a specific request |
Returns: Array of 3D asset objects with request_id, created_at
Credits: Free
How Generation Calls Work
Every generation tool is synchronous: the call blocks until the asset is ready and returns the result (with its URLs) directly in the response. There is no separate polling step, and dropping the connection before the call returns cancels the request. Long-running operations such as 3D models and animations can take 30–120 seconds, so allow a generous client-side timeout.
Retrieving Results Later
Every generation tool also accepts an optional request_id. This does not make the call asynchronous — it tags the result so you can fetch it again afterwards from the matching results endpoint (for example from a different session, or to list everything tied to one request). The result is persisted only after the synchronous call has completed successfully.
# Generate a sprite animation — this call blocks and returns the spritesheet directly
animateSprite with request_id="my-anim-001", initial_image="url", motion_prompt="walking"
# Later, re-fetch that same result (e.g. in another session) by its request_id
getSpriteResults with request_id="my-anim-001"Results are available for 7 days, and each results endpoint is free and returns up to 100 recent API-generated assets.
Asset URL Expiration
All generated asset URLs (images, spritesheets, videos, audio, 3D models) are temporary and expire after 7 days. If you need to keep an asset, download it before it expires.
Example Prompts
Creating Game Assets
Create a pixel art knight character with sword and shield, side view, 16-bit styleGenerate an isometric treasure chest icon for a mobile RPGCreate a low-poly stylized tree for a casual mobile gameAnimations
Animate this character with a smooth walking cycle, 16 framesCreate an idle breathing animation for this character spriteAnimate this fire sprite as a looping VFX effectAudio
Create a satisfying coin pickup sound effect for a platformerGenerate an epic orchestral boss battle theme, intense and dramaticCreate a voice for a wise old wizard saying "The journey begins now"API Documentation
Full API documentation with all parameters and response formats: api.ludo.ai/api-documentation
Support
License
Proprietary - See ludo.ai/terms for terms of service.
This server cannot be installed
Maintenance
Latest Blog Posts
MCP directory API
We provide all the information about MCP servers via our MCP API.
curl -X GET 'https://glama.ai/api/mcp/v1/servers/Ludo-AI/ludo-mcp'
If you have feedback or need assistance with the MCP directory API, please join our Discord server