Skywork Ai Skyreels V3 Pro Single Avatar
Playground
Try it on WavespeedAI!SkyReels V3 Pro Single Avatar is a high-quality AI talking avatar video generation model that creates audio-driven avatar videos from one image, one audio file, and a motion prompt. Ready-to-use REST inference API for digital humans, virtual presenters, product explainers, marketing videos, education content, social media clips, and professional avatar video workflows with simple integration, no coldstarts, and affordable pricing.
Features
Skywork AI SkyReels V3 Pro Single Avatar
Skywork AI SkyReels V3 Pro Single Avatar generates a talking avatar video from a single reference image and an audio clip. It is designed for higher-quality avatar performance, with stronger realism, smoother facial animation, and more polished lip-sync than the Standard variant, making it suitable for digital presenters, spokesperson videos, short-form content, and character-driven speaking clips.
Why Choose This?
-
Higher-quality avatar generation The Pro variant is built for stronger visual quality, more natural expression, and more refined speaking performance.
-
Single-image avatar workflow Turn one portrait image into a speaking avatar video.
-
Audio-driven lip-sync Use an uploaded audio clip to drive speech timing and mouth movement.
-
Prompt-guided behavior Add a short prompt to influence expression, delivery style, or overall presentation.
-
Simple production workflow Upload an image, upload audio, write a prompt, and generate a polished talking avatar clip.
-
Production-ready API Suitable for virtual presenters, social content, marketing spokespeople, and short-form avatar media.
Parameters
| Parameter | Required | Description |
|---|---|---|
| prompt | Yes | Text instruction describing the desired avatar behavior, style, or delivery. |
| image | Yes | Reference image used as the avatar source. |
| audio | Yes | Audio track used to drive the avatar’s speaking performance. |
How to Use
- Upload your image — provide a clear portrait image of the person you want to animate.
- Upload your audio — use a clean audio clip to drive the speaking performance.
- Write your prompt — describe the desired motion, expression, or delivery style.
- Submit — run the model and download the generated avatar video.
Example Prompt
Let the man speak naturally with subtle head movement, calm expression, and realistic lip-sync.
Pricing
Pricing is based on the uploaded audio duration.
| Audio Duration | Cost |
|---|---|
| 5s | $0.40 |
| 10s | $0.80 |
| 15s | $1.20 |
Billing Rules
- Pricing is $0.08 per second
- Total price = $0.08 × audio duration
- Longer audio increases cost linearly
Best Use Cases
- Talking portrait videos — Animate a single portrait into a speaking clip.
- Digital spokesperson content — Create presenter-style videos for announcements, marketing, or onboarding.
- Virtual presenters — Generate clean speaking-avatar videos for explainers and business content.
- Short-form social media clips — Turn portraits and voice clips into speaking content quickly.
- Narration-based character videos — Pair a portrait with speech audio for expressive delivery.
Pro Tips
- Use a clear, front-facing portrait for better avatar stability and facial animation.
- Upload clean audio for stronger lip-sync and more natural speaking performance.
- Keep the prompt simple and focused on expression or delivery style.
- Shorter audio clips are easier to test when iterating on quality.
- Use the Pro variant when you want better realism and polish than the Standard workflow.
Notes
prompt,image, andaudioare required.- Pricing depends on the uploaded audio duration.
- A clean portrait and high-quality audio generally improve results.
- This workflow is intended for single-avatar speaking video generation.
Related Models
- Skywork AI SkyReels V3 Standard Single Avatar — Standard single-avatar workflow at a lower price point.
- Skywork AI SkyReels V3 Standard Multi Avatar — Multi-avatar workflow in the Standard product line.
- Skywork AI SkyReels V3 Pro Multi Avatar — Higher-tier multi-avatar generation for more advanced character scenes.
Authentication
For authentication details, please refer to the Authentication Guide.
API Endpoints
Submit Task & Query Result
# Submit the task
curl --location --request POST "https://api.wavespeed.ai/api/v3/skywork-ai/skyreels-v3-pro/single-avatar" \
--header "Content-Type: application/json" \
--header "Authorization: Bearer ${WAVESPEED_API_KEY}" \
--data-raw '{}'
# Get the result
curl --location --request GET "https://api.wavespeed.ai/api/v3/predictions/${requestId}/result" \
--header "Authorization: Bearer ${WAVESPEED_API_KEY}"
Parameters
Task Submission Parameters
Request Parameters
| Parameter | Type | Required | Default | Range | Description |
|---|---|---|---|---|---|
| prompt | string | Yes | - | Text prompt describing the scene, action, camera, or avatar behavior. | |
| image | string | Yes | - | Input image URL. | |
| audio | string | Yes | - | - | Input audio URL. |
Response Parameters
| Parameter | Type | Description |
|---|---|---|
| code | integer | HTTP status code (e.g., 200 for success) |
| message | string | Status message (e.g., “success”) |
| data.id | string | Unique identifier for the prediction, Task Id |
| data.model | string | Model ID used for the prediction |
| data.outputs | array | Array of URLs to the generated content (empty when status is not completed) |
| data.urls | object | Object containing related API endpoints |
| data.urls.get | string | URL to retrieve the prediction result |
| data.status | string | Status of the task: created, processing, completed, or failed |
| data.created_at | string | ISO timestamp of when the request was created (e.g., “2023-04-01T12:34:56.789Z”) |
| data.error | string | Error message (empty if no error occurred) |
| data.timings | object | Object containing timing details |
| data.timings.inference | integer | Inference time in milliseconds |
Result Request Parameters
| Parameter | Type | Required | Default | Description |
|---|---|---|---|---|
| id | string | Yes | - | Task ID |
Result Response Parameters
| Parameter | Type | Description |
|---|---|---|
| code | integer | HTTP status code (e.g., 200 for success) |
| message | string | Status message (e.g., “success”) |
| data | object | The prediction data object containing all details |
| data.id | string | Unique identifier for the prediction, the ID of the prediction to get |
| data.model | string | Model ID used for the prediction |
| data.outputs | string | Array of URLs to the generated content. |
| data.urls | object | Object containing related API endpoints |
| data.urls.get | string | URL to retrieve the prediction result |
| data.status | string | Status of the task: created, processing, completed, or failed |
| data.created_at | string | ISO timestamp of when the request was created (e.g., “2023-04-01T12:34:56.789Z”) |
| data.error | string | Error message (empty if no error occurred) |
| data.timings | object | Object containing timing details |
| data.timings.inference | integer | Inference time in milliseconds |