Hasilkan video dan gambar dari alat Anda sendiri
Buat kunci, panggil API dengan autentikasi Bearer, dan polling status task hingga hasil siap. Berfungsi dengan Claude Code, Codex, dan klien HTTP apa pun.
Mulai Cepat
Langkah 1
Buat kunci
Buat kunci API di dashboard Anda. Kunci ini hanya ditampilkan sekali, jadi simpan di tempat yang aman.
Langkah 2
Panggil API
Kirim permintaan POST dengan kunci Bearer Anda dan header Idempotency-Key.
Langkah 3
Polling Hasil
Lakukan polling pada endpoint status tugas hingga status menjadi selesai atau gagal, lalu baca hasilnya.
Autentikasi
Setiap permintaan diautentikasi dengan kunci API Bearer di header Authorization.
Authorization: Bearer sk_live_your_api_key
Content-Type: application/json
Idempotency-Key: a-unique-id-per-requestSeedance 2 Video
Teks, gambar, atau media menjadi video.
Kirim Tugas
/api/v1/video/seedance2Parameter
| Parameter | Tipe | Wajib | Default | Nilai yang diizinkan |
|---|---|---|---|---|
modeGeneration mode. | string | Opsional | text-to-video | text-to-videoimage-to-videomedia-to-video |
quality_tierQuality tier. | string | Opsional | standard | ministandardpro |
channelRendering channel. | string | Opsional | standard | standardrealwild |
promptText prompt. | string | Wajib | — | 3–10000 chars |
aspect_ratioAspect ratio. | string | Opsional | 16:9 | 1:121:94:33:416:99:16adaptive |
durationClip duration. | string | Opsional | 5 | 4–15 (seconds) |
resolutionOutput resolution. 1080p-plus and 4k are available on pro only. | string | Opsional | 720p | 720p1080p1080p-plus4k |
image_urlStart frame — required for image-to-video. | string (URL) | Opsional | — | public https URL |
end_image_urlOptional end frame. | string (URL) | Opsional | — | public https URL |
media_urlsRequired for media-to-video. Video URLs must support duration probing. | string[] (URL) | Opsional | — | ≤ 12 public https image/video URLs |
generate_audioGenerate an audio track. | boolean | Opsional | true | truefalse |
fixed_lensLock the camera lens. | boolean | Opsional | false | truefalse |
seedNot supported on the real channel or mini tier. | integer | Opsional | — | -1 – 4294967295 |
Seedance prompt guide
Seedance prompts work best as concrete director instructions. Describe the subject, action, scene, camera motion, visual style, and constraints, then map every reference asset to the right API parameter.
- Use image_url for the opening frame, end_image_url for the closing frame, and media_urls for character, motion, style, source-video, or extension references.
- Describe asset roles in natural language inside prompt. Do not send raw asset ids, asset:// URLs, or in-app-only labels such as @图片1.
- For edits say “strictly edit the supplied source video”; for extensions say “continue from the supplied previous clip.”
- For complex scenes, use ordered shots plus a style and constraint package: stable faces, natural motion, no deformation, no watermark, no logo, and no subtitles unless intended.
Permintaan
curl -X POST https://seedance2ai.io/api/v1/video/seedance2 \
-H "Authorization: Bearer $SEEDANCE_API_KEY" \
-H "Content-Type: application/json" \
-H "Idempotency-Key: demo-video-001" \
-d '{
"mode": "text-to-video",
"quality_tier": "standard",
"prompt": "A cinematic shot of a glass train crossing a snowy mountain bridge",
"aspect_ratio": "16:9",
"duration": "5",
"resolution": "720p"
}'Respons202
{
"id": "sd2_xxxxx",
"status": "processing",
"model": "seedance2",
"quality_tier": "standard",
"channel": "standard",
"credits_used": 30
}Periksa status tugas
/api/v1/tasks/{id}Permintaan
curl https://seedance2ai.io/api/v1/tasks/sd2_xxxxx \
-H "Authorization: Bearer $SEEDANCE_API_KEY"Respons200
{
"id": "sd2_xxxxx",
"status": "completed",
"model": "seedance2",
"quality_tier": "standard",
"channel": "standard",
"credits_used": 30,
"credits_refunded": 0,
"output": {
"video_url": "https://...",
"last_frame_url": "https://...",
"seed": 123
},
"error": null,
"created_at": "2026-06-03T10:00:00.000Z",
"updated_at": "2026-06-03T10:03:12.000Z"
}status: processing · completed · failed
Kode error
All errors share this shape:
{ "error": { "code": "invalid_request", "message": "Invalid request body" } }| Kode | HTTP | Arti |
|---|---|---|
unauthorized | 401 | Missing, invalid, or revoked API key. |
invalid_request | 400 | Bad input or unsupported field. |
insufficient_credits | 402 | Not enough credits on the balance. |
rate_limited | 429 | Too many requests — limit is 30 requests per 60 seconds per account. Retry after the Retry-After response header (in seconds). |
idempotency_conflict | 409 | Same Idempotency-Key reused with a different body, or still running. |
service_busy | 503 | Temporary upstream or credit-concurrency issue. Retry. |
not_found | 404 | Task does not exist or does not belong to this key owner. |
internal_error | 500 | Unexpected server-side failure. |
Gunakan dengan Claude Code
Klik Salin agar AI mengambil API lengkap sebagai Markdown bersih, tempelkan ke Claude Code atau Codex, dan biarkan AI menyiapkan integrasi. Atau arahkan agen langsung ke endpoint teks mentah.
Skill
Pasang skill Seedance di Claude Code, Codex, atau agen mana pun — skill ini menulis prompt sinematik dan merendernya melalui API untuk Anda.
# Download the one-file skill from Seedance 2 AI
mkdir -p ~/.claude/skills/seedance
curl -L https://seedance2ai.io/downloads/seedance-skill.md -o ~/.claude/skills/seedance/SKILL.mdFAQ
Siapa yang bisa menggunakan API?
Siapa pun yang memiliki kredit. Tidak ada batasan paket — akun mana pun yang memiliki kredit dapat membuat kunci dan memanggil API.
Bagaimana cara mendapatkan kredit?
Isi ulang atau berlangganan di halaman harga. Kredit langsung ditambahkan ke saldo Anda.
Apakah kredit dibagi antara website dan API?
Ya — saldo kredit pribadi Anda mendukung pembuatan di web dan panggilan API. Dalam tim, panggilan API menggunakan saldo pribadi masing-masing anggota, bukan pool bersama tim.
Bagaimana cara memulainya?
Buat kunci API di dasbor Anda, lalu panggil endpoint dengan token Bearer (lihat Quickstart di atas).
Bagaimana jika suatu panggilan mengembalikan insufficient_credits?
Saldo Anda kosong — isi ulang di halaman harga dan coba lagi.