Video Body Swap replaces the body in a target video with your face. Upload a face image and a body video to get a seamless swap. Ready-to-use REST inference API, no coldstarts, affordable pricing.
Idle
$0.2per run·~50 / $10
Video Body Swap replaces the body in a target video with your face. Upload a face image and a body video — AI seamlessly composites your likeness onto the moving subject, frame by frame, with natural blending and consistent identity throughout the clip.
Seamless face-to-body compositing Advanced AI tracks the subject across every frame and blends your face naturally onto the body in motion, maintaining consistent identity and lighting.
Simple two-input workflow Just a face image and a body video — no masking, no manual keyframing, no technical setup required.
Wide range of use cases Works across talking head videos, dancing clips, fitness content, and more.
Production-ready API No cold starts, predictable per-second pricing, and a ready-to-use REST endpoint for seamless integration.
| Parameter | Required | Description |
|---|---|---|
| image | Yes | Face image to composite onto the body video. |
| video | Yes | Target body video. Billing is based on this video's duration. |
$0.08 per second of input video, with a minimum charge of 5 seconds and a maximum billable duration of 120 seconds.
| Video Duration | Cost |
|---|---|
| 5s (minimum) | $0.40 |
| 10s | $0.80 |
| 30s | $2.40 |
| 60s | $4.80 |
| 120s (maximum) | $9.60 |
Grab a WaveSpeedAI API key, then call POST https://api.wavespeed.ai/api/v3/wavespeed-ai/video-body-swap 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 Video Body Swap below.
# Submit the prediction
curl -X POST "https://api.wavespeed.ai/api/v3/wavespeed-ai/video-body-swap" \
-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"
}'
# 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("wavespeed-ai/video-body-swap", {
"image": "https://example.com/your-input.jpg",
"video": "https://example.com/your-input.mp4"
});
console.log(result.outputs[0]); // → URL of the generated output# pip install wavespeed
import wavespeed
output = wavespeed.run(
"wavespeed-ai/video-body-swap",
{
"image": "https://example.com/your-input.jpg",
"video": "https://example.com/your-input.mp4"
}
)
print(output["outputs"][0]) # → URL of the generated outputVideo Body Swap is a WaveSpeedAI model for AI inference, exposed as a REST API on WaveSpeedAI. Video Body Swap replaces the body in a target video with your face. Upload a face image and a body video to get a seamless swap. Ready-to-use REST inference API, 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/wavespeed-ai/video-body-swap.
Video Body Swap starts at $0.20 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`. 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/wavespeed-ai/video-body-swap.
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 (WaveSpeedAI). The license summary appears on the model card above; see WaveSpeedAI's Terms of Service for platform-level conditions.