# PixVerse v5 | Transition Create a smooth transition animation between two static images. Generate a surprising morph from the starting frame to the ending frame. ## API Information - **Model Slug:** pixverse-v5-transition - **Branded URL:** https://www.eachlabs.ai/pixverse/pixverse-v5/pixverse-v5-transition - **Provider:** PixVerse - **Category:** Image to Video - **Output Type:** video - **Status:** active - **Version:** 0.0.1 - **Base Cost:** Transition pricing depends on resolution and duration. A 5-second 540p transition costs 45 credits ($0.28), 720p costs 60 credits ($0.38). 8-second videos cost roughly double. - **Estimated Processing Time:** 55 seconds - **Last Updated:** 2026-03-26 - **Interactive Demo:** https://www.eachlabs.ai/ai-models/pixverse-v5-transition ## Pricing - **Charge Type:** dynamic - **Pricing Details:** Transition pricing depends on resolution and duration. A 5-second 540p transition costs 45 credits ($0.28), 720p costs 60 credits ($0.38). 8-second videos cost roughly double. ### Pricing Rules | Condition | Pricing | | --- | --- | | Rule 1 | Transition pricing depends on resolution and duration. A 5-second 540p transition costs 45 credits ($0.28), 720p costs 60 credits ($0.38). 8-second videos cost roughly double. | ## Input Schema | Parameter | Type | Required | Default | Constraints | Description | |-----------|------|----------|---------|-------------|-------------| | prompt | string | Yes | - | - | - | | first_frame_url | string | Yes | - | - | - | | last_frame_url | string | Yes | - | - | - | | duration | integer | Yes | 5 | 5,8 | - | | quality | string | No | 540p | 360p,540p,720p,1080p | The resolution quality of the video. | | motion_mode | string | No | normal | normal | Controls animation speed | | seed | integer | No | - | - | - | | sound_effect_content | string | No | - | - | - | | sound_effect_switch | boolean | No | true | - | - | | lip_sync_switch | boolean | No | false | - | Set to true if you want to enable this feature | | lip_sync_tts_content | string | No | - | - | ~140 (UTF-8) characters | | lip_sync_tts_speaker_id | string | No | - | { "1": { "title": "Emily", "audio": "https://storage.googleapis.com/magicpoint/inputs/pixverse-speakers/pixverse-speaker-emily.mp3" }, "2": { "title": "James", "audio": "https://storage.googleapis.com/magicpoint/inputs/pixverse-speakers/pixverse-speaker-james.mp3" }, "3": { "title": "Isabella", "audio": "https://storage.googleapis.com/magicpoint/inputs/pixverse-speakers/pixverse-speaker-isabella.mp3" }, "4": { "title": "Liam", "audio": "https://storage.googleapis.com/magicpoint/inputs/pixverse-speakers/pixverse-speaker-liam.mp3" }, "5": { "title": "Chloe", "audio": "https://storage.googleapis.com/magicpoint/inputs/pixverse-speakers/pixverse-speaker-chloe.mp3" }, "6": { "title": "Adrian", "audio": "https://storage.googleapis.com/magicpoint/inputs/pixverse-speakers/pixverse-speaker-adrian.mp3" }, "7": { "title": "Harper", "audio": "https://storage.googleapis.com/magicpoint/inputs/pixverse-speakers/pixverse-speaker-harperr.mp3" }, "8": { "title": "Ava", "audio": "https://storage.googleapis.com/magicpoint/inputs/pixverse-speakers/pixverse-speaker-ava.mp3" }, "9": { "title": "Sophia", "audio": "https://storage.googleapis.com/magicpoint/inputs/pixverse-speakers/pixverse-speaker-sophia.mp3" }, "10": { "title": "Julia", "audio": "https://storage.googleapis.com/magicpoint/inputs/pixverse-speakers/pixverse-speaker-julia.mp3" }, "11": { "title": "Mason", "audio": "https://storage.googleapis.com/magicpoint/inputs/pixverse-speakers/pixverse-speaker-mason.mp3" }, "12": { "title": "Jack", "audio": "https://storage.googleapis.com/magicpoint/inputs/pixverse-speakers/pixverse-speaker-jack.mp3" }, "13": { "title": "Oliver", "audio": "https://storage.googleapis.com/magicpoint/inputs/pixverse-speakers/pixverse-speaker-oliver.mp3" }, "14": { "title": "Ethan", "audio": "https://storage.googleapis.com/magicpoint/inputs/pixverse-speakers/pixverse-speaker-ethan.mp3" }, "Auto": { "title": "Auto", "audio": "https://storage.googleapis.com/magicpoint/inputs/pixverse-speakers/pixverse-speaker-eric.mp3" } } | - | ## Example Request ```bash curl -X POST https://api.eachlabs.ai/v1/prediction/ \ -H "X-API-Key: YOUR_API_KEY" \ -H "Content-Type: application/json" \ -d '{ "model": "pixverse-v5-transition", "input": { "duration": 5, "last_frame_url": "https://storage.googleapis.com/magicpoint/inputs/pixverse-v5-transition-last-frame.jpg", "first_frame_url": "https://storage.googleapis.com/magicpoint/inputs/pixverse-v5-transition-first-frame.jpg", "prompt": "driving, new body panels begin to gradually attach to the body, gradually covering the car body, transforming. Gradually, the vehicle transform into a sleek new car, the wheels are spinning" } }' ``` ## Output Schema Response returned by `GET /v1/prediction/{id}` when the job completes: ```json { "status": "success", "predictionID": "string", "output": "string (URL of generated video)", "metrics": { "predict_time": "number (seconds)" } } ``` ## Polling ```bash curl https://api.eachlabs.ai/v1/prediction/{PREDICTION_ID} \ -H "X-API-Key: YOUR_API_KEY" ``` | Status | Meaning | |--------|---------| | `processing` | Still running — poll again | | `success` | Done — read `output` | | `error` | Failed — read `message` / `details` | ## Webhook (alternative to polling) Pass `"webhook_url": "https://your.host/path"` in the create request. Eachlabs POSTs this payload when the job ends: ```json { "exec_id": "prediction-uuid", "status": "succeeded", "output": "https://...", "error": "" } ``` `status` is `"succeeded"` or `"failed"`. `exec_id` equals the `predictionID` from create. Return 2xx within 30 seconds. ## Errors Error body: `{ "status": "error", "message": "...", "details": "..." }` | Code | Meaning | |------|---------| | `400` | Invalid input | | `401` | Missing / invalid `X-API-Key` | | `404` | Unknown model or prediction id | | `429` | Rate limit — 100 creates / min, 10 concurrent per key | | `5xx` | Retry with backoff | ## Overview **pixverse-v5-transition — Image-to-Video AI Model** Developed by Pixverse as part of the **pixverse-v5** family, **pixverse-v5-transition** creates smooth transition animations between two static images, generating surprising morphs from starting frame to ending frame for dynamic **image-to-video AI model** outputs. This specialized mode excels in fluid transformations, maintaining subject fidelity and temporal consistency during complex scene changes, ideal for creators seeking cinematic motion without distortion. Users provide two images plus a descriptive prompt to guide the evolution, producing high-quality videos that bridge visuals seamlessly—perfect for **Pixverse image-to-video** applications like storytelling clips or product demos. With roots in Pixverse's advanced v5 architecture, it delivers professional-grade transitions that rival manual editing. ## Usage Notes - API Base URL: `https://api.eachlabs.ai/v1` - Authentication: send `X-API-Key: YOUR_API_KEY`. Generate a key from the Eachlabs dashboard at https://www.eachlabs.ai/dashboard/api-keys. - File-typed parameters (`*_url`, `image_url`, `video_url`, `audio_url`, etc.) accept publicly-reachable HTTPS URLs only. Upload your asset first (GCS / S3 / your CDN) and pass the resulting URL. Data-URIs and localhost URLs are rejected. - For structured parameters (arrays / objects) send real JSON values, not stringified payloads. - Monetary values are reported in USD; per-token / per-megapixel rates may be billed in micro-cents internally. - Prefer `webhook_url` over polling for long-running predictions — see the Webhook Callback section.