FFmpeg Media · FFmpeg Media
Extract FramesComing Soon
🚧 Coming soon — docs preview only, online run not yet available.
📌 What is this:Export image frames by interval or FPS.
💡 When to use:Use to turn a video into an image sequence.
Endpoints
| Usage | Method | Path |
|---|---|---|
| Submit task | POST | /v1/ffmpeg/frames |
| Query Result | GET | /v1/ffmpeg/info?id={taskId} |
⏱ Recommended polling interval:Poll every 3-5s (response includes progress 0-100) until status = succeeded / failed. Single-task timeout is 300s with auto-refund.
Request Parameters
| Param | Type | Required | Description |
|---|---|---|---|
| inputUrl | string | Required | Input media URL, must be on the platform CDN allowlist (upload first to obtain it) |
| interval | number | — | Interval (sec) [0.5,60], default 1; or use fps |
| fps | number | — | Frames per sec [0.1,5]; or use interval |
| format | string | — | Image format: jpg / png, default jpg |
| webhookUrl | string | — | Completion webhook URL (optional) |
Request Example
curl -X POST https://api.cqtai.com/v1/ffmpeg/frames \
-H 'Authorization: Bearer <API_KEY>' \
-H 'Content-Type: application/json' \
-d '{ "inputUrl": "https://cdn.novapi.ai/tmp/video.mp4", "interval": 2, "format": "jpg" }'
# -> { "code":200, "data":"<taskId>" }Response Example
{
"code": 200,
"msg": "success",
"data": {
"taskId": "<taskId>",
"operation": "transcode",
"status": "succeeded",
"progress": 100,
"resultUrl": "https://cdn.novapi.ai/ffmpeg/xxx.mp4",
"costPoints": 3,
"errorMsg": null
}
}Billing & Credits
Factor 1.2, billed by input length (x your user rate). Auto-refunded on failure.