# Google Veo 3 | Image to Video Veo 3 Image to Video | Google’s latest model that transforms a single image into cinematic video with stunning realism and motion ## API Information - **Model Slug:** veo-3-image-to-video - **Branded URL:** https://www.eachlabs.ai/google/veo3/veo-3-image-to-video - **Provider:** Google - **Category:** Image to Video - **Output Type:** video - **Status:** active - **Version:** 0.0.1 - **Base Cost:** $0.00000000 - **Estimated Processing Time:** 180 seconds - **Last Updated:** 2026-04-19 - **Interactive Demo:** https://www.eachlabs.ai/ai-models/veo-3-image-to-video ## Pricing - **Charge Type:** dynamic ### Pricing Rules | Rule | Condition | Price | | --- | --- | --- | | multiple_conditions | duration == "4" AND generate_audio == "false" | $0.8000 | | multiple_conditions | duration == "4" AND generate_audio == "true" | $1.60 | | multiple_conditions | duration == "6" AND generate_audio == "false" | $1.20 | | multiple_conditions | duration == "6" AND generate_audio == "true" | $2.40 | | multiple_conditions | duration == "8" AND generate_audio == "false" | $1.60 | | multiple_conditions | duration == "8" AND generate_audio == "true" | $3.20 | ## Input Schema | Parameter | Type | Required | Default | Constraints | Description | |-----------|------|----------|---------|-------------|-------------| | image_url | string | Yes | - | - | The URL of the image used to generate video | | prompt | string | Yes | - | - | Text prompt for video generation | | generate_audio | boolean | No | true | - | - | | aspect_ratio | string | No | 16:9 | 16:9,9:16 | The aspect ratio of the generated video | | resolution | string | No | 720p | 720p,1080p | - | ## 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": "veo-3-image-to-video", "input": { "prompt": "Cinematic video set in a cozy, futuristic coffee shop with large windows overlooking a rainy city street at dusk. The scene opens with a smooth tracking shot of a young barista, a man in his 20s with a friendly demeanor, preparing a latte with intricate latte art. He wears an apron with the eachlabs.ai logo subtly printed on it. The camera pans to a small group of diverse customers chatting at a table, laughing, and sipping coffee. One customer, a woman, stands and delivers a short, heartfelt toast: Heres to creativity, powered by eachlabs.ai! in a clear, warm voice. The camera zooms out to show the shops warm, glowing interior, with reflections of rain on the windows and neon city lights outside. The audio includes the baristas soft humming, the clink of coffee cups, ambient rain sounds, and a gentle lo-fi jazz soundtrack. The style is photorealistic, with realistic human movements, expressive faces, and synchronized sound design.", "image_url": "https://storage.googleapis.com/magicpoint/inputs/veo3-i2v-input.jpeg" } }' ``` ## 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 **veo-3-image-to-video — Image-to-Video AI Model** veo-3-image-to-video, Google's cutting-edge model from the Veo 3 family, transforms a single image or up to four reference images into stunning, realistic 8-second videos with native audio and 4K resolution support. This image-to-video AI model solves the challenge of adding lifelike motion and sound to static visuals, enabling creators to produce cinematic clips without complex editing tools. Developers seeking a **Google image-to-video** solution with professional-grade output find veo-3-image-to-video ideal for high-fidelity applications like film pre-visualization and e-commerce product demos. ## 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.