DreamActor V2 transfers motion from a driving video to characters in an image. Great performance for non-human and multiple characters. Ready-to-use REST inference API, best performance, no coldstarts, affordable pricing.
Idle
$0.05per run·~20 / $1
DreamActor V2 is advanced motion transfer model that animates any character image using a driving video. Upload a portrait or character image and a reference video — the model makes your character perform the same movements, expressions, and gestures as the person in the driving video.
Motion transfer Transfer movements, expressions, and gestures from a driving video to any character image.
Any character Works with photos, illustrations, anime characters, or any portrait-style image.
Expression capture Accurately captures facial expressions, head movements, and body gestures.
Natural animation Generates smooth, realistic motion that matches the driving video timing.
Simple workflow Just two inputs — an image and a video — no complex setup required.
| Parameter | Required | Description |
|---|---|---|
| image | Yes | Character image to animate (URL or upload) |
| video | Yes | Driving video with movements to transfer (URL or upload) |
| Video Duration | Cost |
|---|---|
| 1 second | $0.05 |
| 5 seconds | $0.25 |
| 10 seconds | $0.50 |
| 30 seconds | $1.50 |
Grab a WaveSpeedAI API key, then call POST https://api.wavespeed.ai/api/v3/bytedance/dreamactor-v2 with your input as JSON. The endpoint returns a prediction id; poll the prediction endpoint until status flips to completed, then read the output URL from data.outputs[0]. Examples for Dreamactor v2 below.
# Submit the prediction
curl -X POST "https://api.wavespeed.ai/api/v3/bytedance/dreamactor-v2" \
-H "Content-Type: application/json" \
-H "Authorization: Bearer $WAVESPEED_API_KEY" \
-d '{
"image": "https://example.com/your-input.jpg",
"video": "https://example.com/your-input.mp4",
"enable_sync_mode": false,
"enable_base64_output": false
}'
# Response includes a prediction id. Poll for the result:
curl -X GET "https://api.wavespeed.ai/api/v3/predictions/{request_id}/result" \
-H "Authorization: Bearer $WAVESPEED_API_KEY"
# When status is "completed", read the output from data.outputs[0].// npm install wavespeed
const WaveSpeed = require('wavespeed');
const client = new WaveSpeed(); // reads WAVESPEED_API_KEY from env
const result = await client.run("bytedance/dreamactor-v2", {
"image": "https://example.com/your-input.jpg",
"video": "https://example.com/your-input.mp4",
"enable_sync_mode": false,
"enable_base64_output": false
});
console.log(result.outputs[0]); // → URL of the generated output# pip install wavespeed
import wavespeed
output = wavespeed.run(
"bytedance/dreamactor-v2",
{
"image": "https://example.com/your-input.jpg",
"video": "https://example.com/your-input.mp4",
"enable_sync_mode": false,
"enable_base64_output": false
}
)
print(output["outputs"][0]) # → URL of the generated outputDreamactor v2 is a ByteDance model for pose / motion driven video, exposed as a REST API on WaveSpeedAI. DreamActor V2 transfers motion from a driving video to characters in an image. Great performance for non-human and multiple characters. Ready-to-use REST inference API, best performance, no coldstarts, affordable pricing. You can call it programmatically or try it from the playground above.
POST your input parameters to the model's REST endpoint (shown in the API tab of this playground) with your WaveSpeedAI API key in the Authorization header. Submission returns a prediction ID; poll the prediction endpoint until status flips to "completed", then read the output URL from the result. The playground generates a ready-to-paste code sample in Python, JavaScript, or cURL for whatever inputs you've set. Full request/response shape is documented at https://wavespeed.ai/docs/docs-api/bytedance/bytedance-dreamactor-v2.
Dreamactor v2 starts at $0.050 per run. That figure is the base price — the final charge scales with the parameters you set in the form (output size, length, count, references, or whatever knobs this model exposes), so a higher-quality or larger output costs more than a minimal one. The exact cost for your current input is shown live next to the Generate button before you submit, and the actual per-call charge is recorded on the prediction afterwards.
Key inputs: `image`, `video`, `enable_base64_output`, `enable_sync_mode`. The full JSON schema (types, defaults, allowed values) is rendered above the Generate button and mirrored in the API reference at https://wavespeed.ai/docs/docs-api/bytedance/bytedance-dreamactor-v2.
Sign up for a free WaveSpeedAI account to claim starter credits, copy your API key from /accesskey, then call the endpoint shown in the API tab of the playground. The playground also auto-generates a code sample in Python, JavaScript, or cURL for the parameters you've set.
Commercial usage rights depend on the model's license, set by its provider (ByteDance). The license summary appears on the model card above; see WaveSpeedAI's Terms of Service for platform-level conditions.