Zum Hauptinhalt springen
POST
/
v1
/
videos
/
generations
curl --request POST \ --url https://api.evolink.ai/v1/videos/generations \ --header 'Authorization: Bearer <token>' \ --header 'Content-Type: application/json' \ --data ' { "model": "happyhorse-1.0-reference-to-video", "prompt": "A woman in a red qipao character1, the camera first frames the slim cut of the qipao from a side medium shot, then switches to a low-angle upward shot capturing details as she gracefully lifts her hand to open a folding fan character2, with tasseled earrings character3 swaying lightly as she turns her head.", "image_urls": [ "https://cdn.example.com/girl.jpg", "https://cdn.example.com/folding-fan.jpg", "https://cdn.example.com/earrings.jpg" ], "quality": "720p", "aspect_ratio": "16:9", "duration": 5 } '
{
  "created": 1761313744,
  "id": "task-unified-1761313744-h1r2vef0",
  "model": "happyhorse-1.0-reference-to-video",
  "object": "video.generation.task",
  "progress": 0,
  "status": "pending",
  "task_info": {
    "can_cancel": true,
    "estimated_time": 2400,
    "video_duration": 5
  },
  "type": "video",
  "usage": {
    "billing_rule": "per_second",
    "credits_reserved": 607500,
    "user_group": "default"
  }
}

Autorisierungen

Authorization
string
header
erforderlich

##Alle Schnittstellen erfordern eine Authentifizierung mit Bearer Token##

API Key erhalten:

Besuchen Sie die API-Key-Verwaltungsseite, um Ihren API Key zu erhalten

Im Anfrage-Header hinzufügen:

Authorization: Bearer YOUR_API_KEY

Body

application/json
model
enum<string>
Standard:happyhorse-1.0-reference-to-video
erforderlich

Name des Videogenerierungsmodells

Verfügbare Optionen:
happyhorse-1.0-reference-to-video
Beispiel:

"happyhorse-1.0-reference-to-video"

prompt
string
erforderlich

Textprompt, erforderlich

Längengrenzen:

  • Chinesisch: bis zu 2500 Zeichen
  • Nicht-Chinesisch: bis zu 5000 Zeichen
  • Überschüssiger Inhalt wird automatisch abgeschnitten

Konvention für Charakterreferenzen (wichtig):

  • Der Prompt muss explizit character1, character2, character3 ... Schlüsselwörter verwenden, um in Reihenfolge auf Bilder in image_urls zu verweisen
  • Das 1. Bild entspricht character1, das 2. character2, usw.
  • Fehlende explizite Verweise können zu Charakterverwechslungen führen
Beispiel:

"A woman in a red qipao character1, the camera first frames the slim cut of the qipao from a side medium shot, then switches to a low-angle upward shot capturing details as she gracefully lifts her hand to open a folding fan character2, with tasseled earrings character3 swaying lightly as she turns her head."

image_urls
string<uri>[]
erforderlich

Referenzbild-URL-Array, erforderlich, 1 ~ 9 Bilder

Bildanforderungen:

  • Unterstützte Formate: JPEG, JPG, PNG, WEBP
  • Auflösung: kurze Kante ≥ 400 px; 720P oder höhere Qualitätsbilder werden empfohlen (vermeiden Sie extrem kleine, unscharfe oder stark komprimierte Bilder)
  • Empfohlenes Seitenverhältnis: kurze Kante / lange Kante ≥ 0.4, mit konsistenten Proportionen über alle Bilder (nahe am Ziel-Videoverhältnis)
  • Dateigröße: ≤ 10MB pro Bild
  • Bild-URLs müssen öffentlich zugänglich (HTTP oder HTTPS) sein; private OSS-, Intranet- oder authentifizierte Links werden nicht unterstützt

Reihenfolge: Die Array-Reihenfolge entspricht den character1, character2 ... Verweisen im Prompt

Required array length: 1 - 9 elements
Beispiel:
[
  "https://cdn.example.com/girl.jpg",
  "https://cdn.example.com/folding-fan.jpg",
  "https://cdn.example.com/earrings.jpg"
]
quality
enum<string>
Standard:720p

Videoauflösungsstufe, Standard ist 720p

Optionen:

  • 720p: Standardauflösung, dies ist der Standardwert
  • 1080p: HD-Auflösung

Abrechnungshinweis: Die Auflösungsstufe wirkt sich direkt auf die Abrechnung aus

Verfügbare Optionen:
720p,
1080p
Beispiel:

"720p"

aspect_ratio
enum<string>
Standard:16:9

Video-Seitenverhältnis, Standard ist 16:9

Optionen:

  • 16:9 (Querformat)
  • 9:16 (Hochformat)
  • 1:1 (Quadrat)
  • 4:3
  • 3:4
Verfügbare Optionen:
16:9,
9:16,
1:1,
4:3,
3:4
Beispiel:

"16:9"

duration
integer
Standard:5

Videodauer (Sekunden), Standard ist 5 Sekunden

Bereich:

  • Ganzzahl 3 ~ 15
  • Die Dauer wirkt sich direkt auf die Abrechnung aus
Erforderlicher Bereich: 3 <= x <= 15
Beispiel:

5

seed
integer

Zufalls-Seed, Standard ist zufällig

Details:

  • Bereich: 1 ~ 2147483647
  • Ein fester Seed reduziert parameterbedingte Variationen beim Iterieren über Prompts und verbessert die Reproduzierbarkeit
Erforderlicher Bereich: 1 <= x <= 2147483647
Beispiel:

42

callback_url
string<uri>

HTTPS-Callback-URL nach Aufgabenabschluss

Callback-Zeitpunkt:

  • Wird ausgelöst, wenn die Aufgabe abgeschlossen, fehlgeschlagen oder abgebrochen ist
  • Wird nach Abschluss der Abrechnungsbestätigung gesendet

Sicherheitseinschränkungen:

  • Nur HTTPS-Protokoll wird unterstützt
  • Callbacks an private IP-Adressen sind verboten (127.0.0.1, 10.x.x.x, 172.16-31.x.x, 192.168.x.x usw.)
  • URL-Länge darf 2048 Zeichen nicht überschreiten

Callback-Mechanismus:

  • Timeout: 10 Sekunden
  • Bis zu 3 Wiederholungsversuche nach Fehler (jeweils nach 1/2/4 Sekunden)
  • Format des Callback-Antwort-Bodys entspricht dem Antwortformat der Task-Query-API
  • Ein 2xx-Statuscode gilt als Erfolg; andere Statuscodes lösen Wiederholungsversuche aus
Beispiel:

"https://your-domain.com/webhooks/video-task-completed"

Antwort

Videogenerierungsaufgabe erfolgreich erstellt

created
integer

Zeitstempel der Aufgabenerstellung

Beispiel:

1761313744

id
string

Aufgaben-ID

Beispiel:

"task-unified-1761313744-h1r2vef0"

model
string

Tatsächlich verwendeter Modellname

Beispiel:

"happyhorse-1.0-reference-to-video"

object
enum<string>

Spezifischer Aufgabentyp

Verfügbare Optionen:
video.generation.task
progress
integer

Aufgabenfortschritt in Prozent (0-100)

Erforderlicher Bereich: 0 <= x <= 100
Beispiel:

0

status
enum<string>

Aufgabenstatus

Verfügbare Optionen:
pending,
processing,
completed,
failed,
cancelled
Beispiel:

"pending"

task_info
object

Detaillierte Informationen zur Videoaufgabe

type
enum<string>

Ausgabetyp der Aufgabe

Verfügbare Optionen:
text,
image,
audio,
video
Beispiel:

"video"

usage
object

Nutzungs- und Abrechnungsinformationen