> ## 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.

# Генерация видео Gemini Omni Flash

>  - Официальная универсальная мультимодальная модель генерации видео Google Gemini Omni Flash
- Поддерживает Text-to-Video, Image-to-Video, Video-to-Video (редактирование), можно смешивать ввод текста + изображений + видео
- Вывод 720p / 24fps, 3–10 секунд, со звуком; поддерживает диалоговое многораундовое редактирование
- Асинхронный API задач: после отправки результат генерации запрашивается по идентификатору задачи 

<RequestExample>
  ```bash cURL theme={null}
  curl --request POST \
    --url https://api.apimart.ai/v1/videos/generations \
    --header 'Authorization: Bearer <token>' \
    --header 'Content-Type: application/json' \
    --data '{
      "model": "gemini-omni-flash-preview",
      "prompt": "a red apple on a wooden table, short cinematic clip",
      "aspect_ratio": "16:9"
    }'
  ```

  ```python Python theme={null}
  import requests

  url = "https://api.apimart.ai/v1/videos/generations"

  payload = {
      "model": "gemini-omni-flash-preview",
      "prompt": "a red apple on a wooden table, short cinematic clip",
      "aspect_ratio": "16:9"
  }

  headers = {
      "Authorization": "Bearer <token>",
      "Content-Type": "application/json"
  }

  response = requests.post(url, json=payload, headers=headers)

  print(response.json())
  ```

  ```javascript JavaScript theme={null}
  const url = "https://api.apimart.ai/v1/videos/generations";

  const payload = {
    model: "gemini-omni-flash-preview",
    prompt: "a red apple on a wooden table, short cinematic clip",
    aspect_ratio: "16:9"
  };

  const headers = {
    "Authorization": "Bearer <token>",
    "Content-Type": "application/json"
  };

  fetch(url, {
    method: "POST",
    headers: headers,
    body: JSON.stringify(payload)
  })
    .then(response => response.json())
    .then(data => console.log(data))
    .catch(error => console.error("Error:", error));
  ```

  ```go Go theme={null}
  package main

  import (
      "bytes"
      "encoding/json"
      "fmt"
      "io/ioutil"
      "net/http"
  )

  func main() {
      url := "https://api.apimart.ai/v1/videos/generations"

      payload := map[string]interface{}{
          "model":        "gemini-omni-flash-preview",
          "prompt":       "a red apple on a wooden table, short cinematic clip",
          "aspect_ratio": "16:9",
      }

      jsonData, _ := json.Marshal(payload)

      req, _ := http.NewRequest("POST", url, bytes.NewBuffer(jsonData))
      req.Header.Set("Authorization", "Bearer <token>")
      req.Header.Set("Content-Type", "application/json")

      client := &http.Client{}
      resp, err := client.Do(req)
      if err != nil {
          panic(err)
      }
      defer resp.Body.Close()

      body, _ := ioutil.ReadAll(resp.Body)
      fmt.Println(string(body))
  }
  ```
</RequestExample>

<ResponseExample>
  ```json 200 theme={null}
  {
    "code": 200,
    "data": [
      {
        "status": "submitted",
        "task_id": "task_01KS1H7ZYSJWH1N779S2FSHTKA"
      }
    ]
  }
  ```

  ```json 400 theme={null}
  {
    "error": {
      "code": 400,
      "message": "Недопустимые параметры запроса",
      "type": "invalid_request_error"
    }
  }
  ```

  ```json 401 theme={null}
  {
    "error": {
      "code": 401,
      "message": "Ошибка аутентификации, проверьте свой API-ключ",
      "type": "authentication_error"
    }
  }
  ```

  ```json 402 theme={null}
  {
    "error": {
      "code": 402,
      "message": "Недостаточно средств на счёте, пополните баланс и попробуйте снова",
      "type": "payment_required"
    }
  }
  ```

  ```json 429 theme={null}
  {
    "error": {
      "code": 429,
      "message": "Слишком много запросов, попробуйте позже",
      "type": "rate_limit_error"
    }
  }
  ```
</ResponseExample>

## Аутентификация

<ParamField header="Authorization" type="string" required>
  Все запросы требуют аутентификации по Bearer Token.

  Получение API-ключа:

  Перейдите на [страницу управления API-ключами](https://apimart.ai/keys), чтобы получить свой API-ключ.

  При выполнении запросов добавляйте в заголовок:

  ```
  Authorization: Bearer YOUR_API_KEY
  ```
</ParamField>

## Параметры запроса

<ParamField body="model" type="string" required>
  Название модели генерации видео, фиксированное значение `gemini-omni-flash-preview`.
</ParamField>

<ParamField body="prompt" type="string" required>
  Текстовая инструкция. Для Text-to-Video — описание сцены; для Image/Video-to-Video — инструкция по движению / стилю / редактированию.

  <Note>
    `prompt` и референсные материалы (`image_urls` / `video_urls`) — **необходимо предоставить хотя бы одно из них**.
  </Note>
</ParamField>

<ParamField body="image_urls" type="array<string>">
  Референсные изображения, максимум **16 штук**. Каждый элемент — URL вида `http(s)://`.

  Поддерживаются JPEG / PNG. Для нескольких субъектов (например, «кошка + клубок ниток») можно передать несколько изображений и описать в `prompt`, как они взаимодействуют.
</ParamField>

<ParamField body="video_urls" type="array<string>">
  Референсное / редактируемое видео, **максимум 1** (несколько видеоссылок не поддерживаются). Может быть прямой ссылкой `http(s)://` или `data:video/...`.

  <Warning>
    Референсное видео 1 \~ 24 секунды, официально рекомендуется **≤3 секунд**.
  </Warning>
</ParamField>

<ParamField body="aspect_ratio" type="string" default="16:9">
  Соотношение сторон видео, реально управляет ориентацией выводимого кадра.

  Поддерживаются только:

  * `16:9` - горизонтальное (по умолчанию)
  * `9:16` - вертикальное

  Другие значения обрабатываются как `16:9`.
</ParamField>

<ParamField body="resolution" type="string" default="720p">
  Разрешение видео. В настоящее время поддерживается только `720p`.
</ParamField>

<ParamField body="extend_from_task_id" type="string">
  Идентификатор предыдущей задачи: укажите \*\* `task_id`\*\* предыдущей задачи генерации.
</ParamField>

## Ответ

<ResponseField name="code" type="integer">
  Код состояния ответа. При успехе имеет значение `200`.
</ResponseField>

<ResponseField name="data" type="array">
  Возвращаемый массив задач.

  <Expandable title="Элемент массива">
    <ResponseField name="status" type="string">
      Начальный статус задачи. После успешной отправки имеет значение `submitted`.
    </ResponseField>

    <ResponseField name="task_id" type="string">
      Уникальный идентификатор задачи для запроса её статуса и результата.
    </ResponseField>
  </Expandable>
</ResponseField>

## Получение результата задачи

Генерация видео является асинхронной задачей. После отправки возвращается `task_id`. Используйте эндпоинт [Получить статус задачи](/ru/api-reference/tasks/status), чтобы узнать прогресс и результат генерации.

### Пример успешного результата

```json theme={null}
{
  "code": 200,
  "data": {
    "id": "task_01KS1H7ZYSJWH1N779S2FSHTKA",
    "status": "completed",
    "progress": 100,
    "created": 1779246294,
    "completed": 1779246334,
    "actual_time": 40,
    "estimated_time": 60,
    "cost": 1.0,
    "credits_cost": 10,
    "result": {
      "videos": [
        {
          "url": ["https://cdn.example.com/gemini_omni_xxx.mp4"],
          "expires_at": 1779332760
        }
      ]
    }
  }
}
```

## Сценарии использования

### Сценарий 1: Text-to-Video

```json theme={null}
{
  "model": "gemini-omni-flash-preview",
  "prompt": "a blue butterfly landing on a flower, macro, soft light",
  "aspect_ratio": "9:16"
}
```

### Сценарий 2: Image-to-Video

```json theme={null}
{
  "model": "gemini-omni-flash-preview",
  "prompt": "turn this drawing into realistic footage, use it only as a motion guide",
  "image_urls": ["https://example.com/sketch.jpg"]
}
```

### Сценарий 3: Video-to-Video

```json theme={null}
{
  "model": "gemini-omni-flash-preview",
  "prompt": "when the person touches the mirror, make it ripple like liquid",
  "video_urls": ["https://example.com/clip.mp4"]
}
```
