Veo 3.1 Fast API
Faster, cheaper Veo 3.1 for drafts.
Integrate Veo 3.1 Fast with a single API call — one key, one unified endpoint, and shared billing across every model on Apiframe.
model: "veo-3.1-fast" What's special about Veo 3.1 Fast
- Outputs at 720p / 1080p.
- 5 aspect ratios, including 1:1, 3:4, 4:3.
- Generates clips from 4s to 8s.
- Image-to-video and reference-image support.
- Generates natively synchronized audio.
- Fast turnaround — about 45s per generation on average.
- Pay-as-you-go pricing with no Google account required — you only pay for successful generations.
- One API key, unified billing, idempotency and webhooks across every Apiframe model.
Made with Veo 3.1 Fast
A few outputs generated through the Veo 3.1 Fast API on Apiframe.
Drone shot flying over a tropical coastline at sunrise, smooth cinematic motion
A vintage car driving through a rainy neon city at night, reflections on the asphalt
Time-lapse of clouds rolling over a mountain range in warm golden light
Overview
- Endpoint
- POST /v2/videos/generate
- Model ID
- veo-3.1-fast
- Params key
- veoParams
- Modality
- video
- Provider
- Pricing
- Pay-as-you-go
- Avg. completion
- ~45s
Capabilities
Quick start
Send a single POST /v2/videos/generate request with your API key to
generate with Veo 3.1 Fast. The call returns a jobId you can poll or
receive via webhook.
curl -X POST https://api.apiframe.ai/v2/videos/generate \
-H "X-API-Key: afk_your_api_key_here" \
-H "Content-Type: application/json" \
-d '{
"prompt": "a cinematic sunrise over a futuristic cityscape, smooth camera push-in",
"model": "veo-3.1-fast",
"veoParams": {
"image": "https://example.com/input.jpg",
"resolution": "720p",
"generate_audio": true,
"last_frame": "https://example.com/input.jpg"
}
}'import requests
response = requests.post(
"https://api.apiframe.ai/v2/videos/generate",
headers={
"X-API-Key": "afk_your_api_key_here",
"Content-Type": "application/json",
},
json={
"prompt": "a cinematic sunrise over a futuristic cityscape, smooth camera push-in",
"model": "veo-3.1-fast",
"veoParams": {
"image": "https://example.com/input.jpg",
"resolution": "720p",
"generate_audio": True,
"last_frame": "https://example.com/input.jpg"
}
},
)
print(response.json()) # { "jobId": "...", "status": "QUEUED" }const response = await fetch("https://api.apiframe.ai/v2/videos/generate", {
method: "POST",
headers: {
"X-API-Key": "afk_your_api_key_here",
"Content-Type": "application/json",
},
body: JSON.stringify({
"prompt": "a cinematic sunrise over a futuristic cityscape, smooth camera push-in",
"model": "veo-3.1-fast",
"veoParams": {
"image": "https://example.com/input.jpg",
"resolution": "720p",
"generate_audio": true,
"last_frame": "https://example.com/input.jpg"
}
}),
});
const { jobId } = await response.json();
console.log(jobId);Response & job lifecycle
Generation is asynchronous. A successful submission returns 202 Accepted
with a jobId. Poll GET /v2/jobs/{id} (or supply a
webhook_url) until the status is COMPLETED; the
result field then holds the output URL(s).
1. Submission response (202)
{
"jobId": "b2c3d4e5-f6a7-8901-bcde-f23456789012",
"status": "QUEUED"
}2. Poll for the result
curl https://api.apiframe.ai/v2/jobs/JOB_ID \
-H "X-API-Key: afk_your_api_key_here"import requests, time
while True:
job = requests.get(
"https://api.apiframe.ai/v2/jobs/JOB_ID",
headers={"X-API-Key": "afk_your_api_key_here"},
).json()
if job["status"] in ("COMPLETED", "FAILED"):
break
time.sleep(2)
print(job["result"])let job;
do {
await new Promise((r) => setTimeout(r, 2000));
job = await fetch("https://api.apiframe.ai/v2/jobs/JOB_ID", {
headers: { "X-API-Key": "afk_your_api_key_here" },
}).then((r) => r.json());
} while (job.status !== "COMPLETED" && job.status !== "FAILED");
console.log(job.result);Input schema
Request parameters accepted by the Veo 3.1 Fast endpoint. Model-specific options are nested under the params object shown below.
| Parameter | Type | Required | Default | Allowed / range | Description |
|---|---|---|---|---|---|
| prompt | string | required | — | — | Text description of what to generate. |
| model | string | required | "veo-3.1-fast" | "veo-3.1-fast" | The model identifier for this endpoint. |
| veoParams.image | string (URL) | optional | — | — | Use a still as the first frame. |
| veoParams.resolution | string | optional | "720p" | "720p", "1080p" | Resolution |
| veoParams.generate_audio | boolean | optional | true | — | Generate audio |
| veoParams.last_frame | string (URL) | optional | — | — | Last frame (URL) |
| veoParams.reference_images | string[] (URLs) | optional | — | — | Reference images |
| veoParams.negative_prompt | string | optional | — | — | Negative prompt |
| veoParams.seed | number | optional | — | step 1 | Reuse a number to reproduce the same result. |
Frequently Asked Questions
Common questions about the Veo 3.1 Fast API.
Is there an API for Veo 3.1 Fast?
Yes. Apiframe exposes Veo 3.1 Fast through a single REST endpoint (`POST /v2/videos/generate` with `model: "veo-3.1-fast"`). You get one unified API, key, and billing across every supported model — no separate Google account required.
How much does the Veo 3.1 Fast API cost?
Veo 3.1 Fast uses simple pay-as-you-go pricing on Apiframe — you only pay for successful generations. See the pricing page for plans and volume discounts.
How do I call the Veo 3.1 Fast API?
Send a POST request to `/v2/videos/generate` with your `X-API-Key` and a JSON body containing `model: "veo-3.1-fast"`. The call returns a `jobId`; poll `GET /v2/jobs/{id}` or use a webhook to receive the result.
What parameters does Veo 3.1 Fast support?
Veo 3.1 Fast accepts 7 model-specific parameters (nested under `veoParams`) plus the common `prompt` and `webhook_url` fields. See the input schema above for the full list with types and defaults.
Still have questions?
Start building with the Veo 3.1 Fast API
Get your API key and integrate Veo 3.1 Fast in minutes — Pay-as-you-go.
Questions? Join our Discord or contact sales.