Utilisez l'API RunComfy pour exécuter happyhorse/happyhorse-1.0/image-to-video. Pour les entrées et sorties acceptées, voir le schéma.
curl --request POST \
--url https://model-api.runcomfy.net/v1/models/happyhorse/happyhorse-1.0/image-to-video \
--header "Content-Type: application/json" \
--header "Authorization: Bearer <token>" \
--data '{
"image_url": "https://playgrounds-storage-public.runcomfy.net/tools/7345/media-files/ref-promo.webp",
"prompt": "Slow cinematic camera drift around the subject, soft natural motion, identity-stable face and clothing, gentle wind moving hair, premium photoreal look."
}'Définissez la variable d'environnement YOUR_API_TOKEN avec votre clé API (gestion dans Profil) et incluez à chaque requête un jeton Bearer dans l'en-tête Authorization : Authorization: Bearer $YOUR_API_TOKEN.
Soumettez une tâche de génération asynchrone et recevez immédiatement un request_id ainsi que des URLs pour le statut, les résultats et l'annulation.
curl --request POST \
--url https://model-api.runcomfy.net/v1/models/happyhorse/happyhorse-1.0/image-to-video \
--header "Content-Type: application/json" \
--header "Authorization: Bearer <token>" \
--data '{
"image_url": "https://playgrounds-storage-public.runcomfy.net/tools/7345/media-files/ref-promo.webp",
"prompt": "Slow cinematic camera drift around the subject, soft natural motion, identity-stable face and clothing, gentle wind moving hair, premium photoreal look."
}'Récupère l'état actuel pour un request_id (« in_queue », « in_progress », « completed » ou « cancelled »).
curl --request GET \
--url https://model-api.runcomfy.net/v1/requests/{request_id}/status \
--header "Authorization: Bearer <token>"Récupère les sorties finales et métadonnées pour le request_id ; si le travail n'est pas terminé, la réponse indique l'état actuel pour poursuivre le polling.
curl --request GET \
--url https://model-api.runcomfy.net/v1/requests/{request_id}/result \
--header "Authorization: Bearer <token>"Annule un travail en file d'attente via request_id ; les travaux en cours ne peuvent pas être annulés.
curl --request POST \
--url https://model-api.runcomfy.net/v1/requests/{request_id}/cancel \
--header "Authorization: Bearer <token>"Fournissez une URL HTTPS accessible publiquement. L'hôte doit autoriser les récupérations côté serveur (sans login/cookies), sans limitation de débit ni blocage des bots. Recommandé : images ≤ 50 Mo (~4K), vidéos ≤ 100 Mo (~2–5 min en 720p). Préférez des URL stables ou pré-signées pour les actifs privés.
{
"type": "object",
"title": "Schéma d'entrée",
"required": [
"image_url",
"prompt"
],
"properties": {
"image_url": {
"title": "Image de la première image",
"description": "Image source à animer (première image). Formats : JPEG, JPG, PNG ou WEBP. Min 300px par côté ; aspect entre 1:2,5 et 2,5:1 ; maximum 10 Mo.",
"type": "string",
"default": "https://playgrounds-storage-public.runcomfy.net/tools/7345/media-files/ref-promo.webp"
},
"prompt": {
"title": "Prompt",
"description": "Décrivez le mouvement, la caméra, l'éclairage et l'atmosphère. Jusqu'à 5 000 caractères non chinois ou 2 500 caractères chinois (les entrées plus longues sont tronquées).",
"type": "string",
"default": "Slow cinematic camera drift around the subject, soft natural motion, identity-stable face and clothing, gentle wind moving hair, premium photoreal look.",
"maxLength": 5000
},
"resolution": {
"title": "Résolution",
"description": "Résolution vidéo de sortie. HappyHorse 1.0 I2V prend en charge 720P ou 1080P.",
"type": "string",
"enum": [
"720P",
"1080P"
],
"default": "1080P"
},
"duration": {
"title": "Durée",
"description": "Durée de la vidéo de sortie en secondes. Valeurs autorisées : 3 à 15.",
"type": "integer",
"enum": [
3,
4,
5,
6,
7,
8,
9,
10,
11,
12,
13,
14,
15
],
"default": 5
},
"seed": {
"title": "Graine",
"description": "Semence facultative pour des générations reproductibles. Utilisez 0 pour laisser le fournisseur randomiser.",
"type": "integer",
"minimum": 0,
"maximum": 2147483647,
"default": 0
},
"watermark": {
"title": "Filigrane",
"description": "S'il faut conserver le filigrane du fournisseur sur la vidéo générée.",
"type": "boolean",
"default": false
}
}
}{
"output": {
"type": "object",
"properties": {
"image": {
"type": "string",
"format": "uri",
"description": "URL d'une seule image"
},
"video": {
"type": "string",
"format": "uri",
"description": "URL d'une seule vidéo"
},
"images": {
"type": "array",
"description": "plusieurs URLs d'images",
"items": {
"type": "string",
"format": "uri"
}
},
"videos": {
"type": "array",
"description": "plusieurs URLs de vidéos",
"items": {
"type": "string",
"format": "uri"
}
}
}
}
}RunComfy est la première ComfyUI plateforme, offrant des ComfyUI en ligne environnement et services, ainsi que des workflows ComfyUI proposant des visuels époustouflants. RunComfy propose également AI Models, permettant aux artistes d'utiliser les derniers outils d'IA pour créer des œuvres d'art incroyables.