Zum Hauptinhalt springen
POST
/
v1
/
seedance2
/
private-avatar
curl --request POST \
  --url https://api.apimart.ai/v1/seedance2/private-avatar \
  --header 'Authorization: Bearer <token>' \
  --header 'Content-Type: application/json' \
  --data '{
    "group": {
      "name": "virtual-avatar-group",
      "description": "demo group"
    },
    "project_name": "default",
    "asset_type": "Image",
    "assets": [
      {
        "url": "https://example.com/avatar-a.png",
        "name": "avatar-a"
      },
      {
        "url": "https://example.com/avatar-b.png",
        "name": "avatar-b"
      }
    ]
  }'
{
  "code": 200,
  "data": {
    "id": "task_01K...",
    "object": "seedance.avatar.asset.task",
    "status": "processing",
    "progress": 10,
    "model": "doubao-seedance-2.0"
  }
}

Documentation Index

Fetch the complete documentation index at: https://docs.apimart.ai/llms.txt

Use this file to discover all available pages before exploring further.

curl --request POST \
  --url https://api.apimart.ai/v1/seedance2/private-avatar \
  --header 'Authorization: Bearer <token>' \
  --header 'Content-Type: application/json' \
  --data '{
    "group": {
      "name": "virtual-avatar-group",
      "description": "demo group"
    },
    "project_name": "default",
    "asset_type": "Image",
    "assets": [
      {
        "url": "https://example.com/avatar-a.png",
        "name": "avatar-a"
      },
      {
        "url": "https://example.com/avatar-b.png",
        "name": "avatar-b"
      }
    ]
  }'
{
  "code": 200,
  "data": {
    "id": "task_01K...",
    "object": "seedance.avatar.asset.task",
    "status": "processing",
    "progress": 10,
    "model": "doubao-seedance-2.0"
  }
}

Authentifizierung

Authorization
string
erforderlich
Alle Anfragen erfordern eine Bearer-Token-AuthentifizierungHolen Sie Ihren API Key:Besuchen Sie die Seite zur API-Key-Verwaltung, um Ihren API Key zu erhaltenFügen Sie den folgenden Header zu jeder Anfrage hinzu:
Authorization: Bearer YOUR_API_KEY

Anfrageparameter

group
object
Informationen zur Asset-GruppeWenn group_id nicht angegeben ist, erstellt der Server automatisch eine AIGC-Asset-Gruppe basierend auf diesem FeldBeispiel:
{
  "group": {
    "name": "virtual-avatar-group",
    "description": "demo group"
  }
}
Schließt sich mit group_id gegenseitig aus — geben Sie nicht beide gleichzeitig an
group_id
string
ID einer bestehenden Asset-GruppeWenn angegeben, wird die Gruppenerstellung übersprungen und die Assets werden direkt an die angegebene Gruppe gesendet
Schließt sich mit group gegenseitig aus — geben Sie nicht beide gleichzeitig an
project_name
string
Standard:"default"
ProjektnameStandard: default
asset_type
string
Standard:"Image"
Asset-TypOptionen:
  • Image — Bild-Asset (Standard)
  • Video — Video-Asset
  • Audio — Audio-Asset
Standard: Image
assets
array
Asset-Liste, unterstützt die Einreichung mehrerer Assets in einer Anfrage
Maximal 20 Assets pro Einreichung
Beispiel:
{
  "assets": [
    {
      "url": "https://example.com/avatar-a.png",
      "name": "avatar-a"
    },
    {
      "url": "https://example.com/avatar-b.png",
      "name": "avatar-b"
    }
  ]
}
url
string
Kurzform für ein einzelnes Asset: Asset-URL
Verwenden Sie entweder das Array assets oder dieses Feld — nicht beide. Geeignet zum Einreichen eines einzelnen Assets.
name
string
Kurzform für ein einzelnes Asset: Asset-Name
Verwenden Sie entweder das Array assets oder dieses Feld — nicht beide. Geeignet zum Einreichen eines einzelnen Assets.

Antwort

code
integer
Antwortstatuscode, 200 bei Erfolg
data
object
Aufgabeninformationen

Beispiele

Beispiel 1: Stapeleinreichung (Gruppe automatisch erstellen)

Wenn group_id nicht angegeben ist, erstellt der Server vor der Einreichung automatisch eine AIGC-Asset-Gruppe.
{
  "group": {
    "name": "virtual-avatar-group",
    "description": "demo group"
  },
  "project_name": "default",
  "asset_type": "Image",
  "assets": [
    {
      "url": "https://example.com/avatar-a.png",
      "name": "avatar-a"
    },
    {
      "url": "https://example.com/avatar-b.png",
      "name": "avatar-b"
    }
  ]
}

Beispiel 2: Assets zu einer bestehenden Gruppe hinzufügen

Geben Sie group_id an, um die Gruppenerstellung zu überspringen und direkt einzureichen.
{
  "group_id": "group_xxx",
  "project_name": "default",
  "asset_type": "Image",
  "assets": [
    {
      "url": "https://example.com/avatar-a.png",
      "name": "avatar-a"
    }
  ]
}

Beispiel 3: Kurzform für ein einzelnes Asset

Verwenden Sie für ein einzelnes Asset direkt die Felder url und name auf oberster Ebene.
{
  "group_id": "group_xxx",
  "url": "https://example.com/avatar.png",
  "asset_type": "Image",
  "name": "avatar-1"
}

Prüfergebnis abfragen

Die Asset-Einreichung ist eine asynchrone Aufgabe. Verwenden Sie den Endpunkt Aufgabenstatus abrufen zur Abfrage:
GET /v1/tasks/{id}

Alle genehmigt

{
  "code": 200,
  "data": {
    "id": "task_01K...",
    "status": "completed",
    "progress": 100,
    "result": {
      "assets": [
        {
          "asset_id": "asset_a",
          "asset_url": "asset://asset_a",
          "status": "Active"
        },
        {
          "asset_id": "asset_b",
          "asset_url": "asset://asset_b",
          "status": "Active"
        }
      ],
      "usable_assets": [
        {
          "asset_id": "asset_a",
          "asset_url": "asset://asset_a",
          "status": "Active"
        },
        {
          "asset_id": "asset_b",
          "asset_url": "asset://asset_b",
          "status": "Active"
        }
      ],
      "failed_assets": []
    }
  }
}

Teilweiser Fehler

Wenn ein Asset die Prüfung nicht besteht, wird der Aufgabenstatus zu failed. Erfolgreich genehmigte Assets bleiben nutzbar und erscheinen in result.usable_assets.
{
  "code": 200,
  "data": {
    "id": "task_01K...",
    "status": "failed",
    "progress": 100,
    "result": {
      "assets": [
        {
          "asset_id": "asset_a",
          "asset_url": "asset://asset_a",
          "status": "Active"
        },
        {
          "asset_id": "asset_b",
          "asset_url": "asset://asset_b",
          "status": "Failed"
        }
      ],
      "usable_assets": [
        {
          "asset_id": "asset_a",
          "asset_url": "asset://asset_a",
          "status": "Active"
        }
      ],
      "failed_assets": [
        {
          "asset_id": "asset_b",
          "asset_url": "asset://asset_b",
          "status": "Failed"
        }
      ]
    },
    "error": {
      "code": "task_failed",
      "message": "Some assets failed review"
    }
  }
}
  • result.usable_assets[].asset_url kann direkt in der Videogenerierung mit Seedance 2.0 verwendet werden
  • Assets in result.failed_assets müssen ersetzt oder erneut eingereicht werden
  • Aufgaben mit nur einem Asset geben aus Kompatibilitätsgründen auch result.asset_url zurück

Verwendung genehmigter Assets

Übergeben Sie die asset://...-URL direkt an den Endpunkt Videogenerierung mit Seedance 2.0:
{
  "model": "doubao-seedance-2.0",
  "prompt": "The character walks naturally along a city street",
  "image_urls": ["asset://asset_a"],
  "duration": 5,
  "resolution": "720p"
}
Sobald der Server das Präfix asset:// erkennt, reicht er die Generierungsaufgabe direkt ein, ohne eine erneute Asset-Prüfung auszulösen.