> ## Documentation Index
> Fetch the complete documentation index at: https://docs.evolink.ai/llms.txt
> Use this file to discover all available pages before exploring further.

# Seedance 2.0 Reference-to-Video 멀티모달 참조 비디오

> - 참조 이미지(0~9장) + 참조 비디오(0~3개) + 참조 오디오(0~3개) + 텍스트 프롬프트로 비디오를 생성합니다
- 새로운 생성, 비디오 편집, 비디오 연장 등 다양한 창작 시나리오를 지원합니다
- **AIGC 유형 실사 소재 지원**
- 비동기 처리 모드로, 반환된 작업 ID를 사용하여 [조회하세요](/ko/api-manual/task-management/get-task-detail)
- 생성된 비디오 링크는 24시간 동안 유효하며, 가능한 빨리 저장하세요



## OpenAPI

````yaml ko/api-manual/video-series/seedance2.0/seedance-2.0-reference-to-video.json POST /v1/videos/generations
openapi: 3.1.0
info:
  title: Seedance 2.0 Reference-to-Video API
  description: Seedance 2.0 멀티모달 참조 비디오 API, 이미지, 비디오, 오디오 참조 소재를 혼합하여 생성을 지원합니다
  license:
    name: MIT
  version: 1.0.0
servers:
  - url: https://api.evolink.ai
    description: 프로덕션 환경
security:
  - bearerAuth: []
tags:
  - name: 비디오 생성
    description: AI 비디오 생성 관련 API
paths:
  /v1/videos/generations:
    post:
      tags:
        - 비디오 생성
      summary: Seedance 2.0 Reference-to-Video 멀티모달 참조 비디오
      description: >-
        - 참조 이미지(0~9장) + 참조 비디오(0~3개) + 참조 오디오(0~3개) + 텍스트 프롬프트로 비디오를 생성합니다

        - 새로운 생성, 비디오 편집, 비디오 연장 등 다양한 창작 시나리오를 지원합니다

        - **AIGC 유형 실사 소재 지원**

        - 비동기 처리 모드로, 반환된 작업 ID를 사용하여
        [조회하세요](/ko/api-manual/task-management/get-task-detail)

        - 생성된 비디오 링크는 24시간 동안 유효하며, 가능한 빨리 저장하세요
      operationId: createSeedance20ReferenceToVideo
      requestBody:
        required: true
        content:
          application/json:
            schema:
              $ref: '#/components/schemas/VideoGenerationRequest'
            examples:
              multimodal:
                summary: 멀티모달 참조 (이미지 + 비디오 + 오디오)
                value:
                  model: seedance-2.0-reference-to-video
                  prompt: >-
                    Use the first-person perspective framing of video 1
                    throughout, use audio 1 as background music throughout.
                    First-person perspective fruit tea promotional video...
                  image_urls:
                    - https://example.com/ref1.jpg
                    - https://example.com/ref2.jpg
                  video_urls:
                    - https://example.com/reference.mp4
                  audio_urls:
                    - https://example.com/bgm.mp3
                  duration: 10
                  quality: 720p
                  aspect_ratio: '16:9'
                  generate_audio: true
                  content_filter: true
              video_edit:
                summary: 비디오 편집 (요소 교체)
                value:
                  model: seedance-2.0-reference-to-video
                  prompt: >-
                    Replace the perfume in the gift box in video 1 with the face
                    cream in image 1, keep the camera movement unchanged
                  image_urls:
                    - https://example.com/cream.jpg
                  video_urls:
                    - https://example.com/original.mp4
                  duration: 5
                  aspect_ratio: '16:9'
              video_extend:
                summary: 비디오 연장 (다중 세그먼트 연결)
                value:
                  model: seedance-2.0-reference-to-video
                  prompt: >-
                    The arched window in video 1 opens, entering the art gallery
                    interior, continuing with video 2, then the camera enters
                    the painting, continuing with video 3
                  video_urls:
                    - https://example.com/part1.mp4
                    - https://example.com/part2.mp4
                    - https://example.com/part3.mp4
                  duration: 8
                  aspect_ratio: '16:9'
                  generate_audio: true
                  content_filter: true
      responses:
        '200':
          description: 비디오 생성 작업이 성공적으로 생성되었습니다
          content:
            application/json:
              schema:
                $ref: '#/components/schemas/VideoGenerationResponse'
        '400':
          description: 요청 파라미터 오류
          content:
            application/json:
              schema:
                $ref: '#/components/schemas/ErrorResponse'
              example:
                error:
                  code: invalid_request
                  message: Invalid request parameters
                  type: invalid_request_error
        '401':
          description: 미인증, Token이 유효하지 않거나 만료됨
          content:
            application/json:
              schema:
                $ref: '#/components/schemas/ErrorResponse'
              example:
                error:
                  code: unauthorized
                  message: Invalid or expired token
                  type: authentication_error
        '402':
          description: 할당량 부족, 충전 필요
          content:
            application/json:
              schema:
                $ref: '#/components/schemas/ErrorResponse'
              example:
                error:
                  code: insufficient_quota
                  message: Insufficient quota. Please top up your account.
                  type: insufficient_quota
        '403':
          description: 접근 권한 없음
          content:
            application/json:
              schema:
                $ref: '#/components/schemas/ErrorResponse'
              example:
                error:
                  code: model_access_denied
                  message: >-
                    Token does not have access to model:
                    seedance-2.0-reference-to-video
                  type: invalid_request_error
        '429':
          description: 요청 빈도 초과
          content:
            application/json:
              schema:
                $ref: '#/components/schemas/ErrorResponse'
              example:
                error:
                  code: rate_limit_exceeded
                  message: Too many requests, please try again later
                  type: rate_limit_error
        '500':
          description: 서버 내부 오류
          content:
            application/json:
              schema:
                $ref: '#/components/schemas/ErrorResponse'
              example:
                error:
                  code: internal_error
                  message: Internal server error
                  type: api_error
components:
  schemas:
    VideoGenerationRequest:
      type: object
      required:
        - model
        - prompt
      properties:
        model:
          type: string
          description: 비디오 생성 모델 이름
          enum:
            - seedance-2.0-reference-to-video
          default: seedance-2.0-reference-to-video
          example: seedance-2.0-reference-to-video
        prompt:
          type: string
          description: >-
            생성할 비디오를 설명하는 텍스트 프롬프트. 중국어와 영어를 지원하며, 중국어는 500자 이내를 권장합니다. 프롬프트 최대
            길이: 10000 tokens


            **설명:**

            - 자연어로 각 소재의 용도를 지정할 수 있습니다. 예: 「첫 프레임은 이미지1」, 「비디오1의 카메라 워크를 전체
            사용」, 「오디오1을 배경 음악으로 사용」

            - 모델이 소재 번호와 용도의 대응 관계를 자동으로 이해합니다
          example: >-
            Use the first-person perspective framing of video 1 throughout, use
            audio 1 as background music throughout. First-person perspective
            fruit tea promotional video...
        image_urls:
          type: array
          description: >-
            참조 이미지 URL 배열, **0~9장**


            **역할 설명:**


            | 미디어 유형 | 역할 | 일반적인 용도 |

            |---------|------|----------|

            | 이미지 | `reference_image` | 스타일 참조, 제품 이미지, 첫/끝 프레임(prompt로 지정) |


            **이미지 요구사항:**

            - 지원 형식: `.jpeg`, `.png`, `.webp`

            - 화면 비율(너비/높이): `0.4` ~ `2.5`

            - 너비/높이 픽셀: `300` ~ `6000` px

            - 단일 파일 크기: `30MB` 이하

            - 요청 본문 총 크기 `64MB` 이하, Base64 인코딩을 사용하지 마세요

            - 이미지 URL은 서버에서 직접 접근 가능해야 합니다


            **주의:** `audio_urls`만 단독으로 전달할 수 없으며, 최소 1장의 이미지(`image_urls`) 또는
            1개의 비디오(`video_urls`)가 포함되어야 합니다
          items:
            type: string
            format: uri
          maxItems: 9
          example:
            - https://example.com/ref1.jpg
            - https://example.com/ref2.jpg
        video_urls:
          type: array
          description: >-
            참조 비디오 URL 배열, **0~3개**


            **역할 설명:**


            | 미디어 유형 | 역할 | 일반적인 용도 |

            |---------|------|----------|

            | 비디오 | `reference_video` | 카메라 워크 참조, 동작 참조, 편집/연장할 원본 비디오 |


            **비디오 요구사항:**

            - 지원 형식: `.mp4`, `.mov`

            - 해상도: 480p, 720p, 1080p

            - 단일 비디오 길이: `2` ~ `15`초, 최대 3개, 모든 비디오 총 길이 <= `15`초

            - 화면 비율(너비/높이): `0.4` ~ `2.5`

            - 너비/높이 픽셀: `300` ~ `6000` px

            - 화면 픽셀(너비 x 높이): `409,600` ~ `2,086,876`(예: 640x640 ~ 2206x946)

            - 단일 파일 크기: `50MB` 이하

            - 프레임 레이트: `24` ~ `60` FPS

            - 요청 본문 총 크기 `64MB` 이하, Base64 인코딩을 사용하지 마세요

            - 비디오 참조 사용 시 추가 비용이 발생합니다(입력 비디오 길이가 과금에 포함)

            - 비디오 URL은 서버에서 직접 접근 가능해야 합니다


            **주의:** `audio_urls`만 단독으로 전달할 수 없으며, 최소 1장의 이미지(`image_urls`) 또는
            1개의 비디오(`video_urls`)가 포함되어야 합니다
          items:
            type: string
            format: uri
          maxItems: 3
          example:
            - https://example.com/reference.mp4
        audio_urls:
          type: array
          description: |-
            참조 오디오 URL 배열, **0~3개**

            **역할 설명:**

            | 미디어 유형 | 역할 | 일반적인 용도 |
            |---------|------|----------|
            | 오디오 | `reference_audio` | 배경 음악, 효과음, 음성/대사 참조 |

            **오디오 요구사항:**
            - 지원 형식: `.wav`, `.mp3`
            - 단일 오디오 길이: `2` ~ `15`초, 최대 3개, 모든 오디오 총 길이 <= `15`초
            - 단일 파일 크기: `15MB` 이하
            - 요청 본문 총 크기 `64MB` 이하, Base64 인코딩을 사용하지 마세요
            - 오디오 URL은 서버에서 직접 접근 가능해야 합니다

            **주의:** 오디오만 단독으로 입력할 수 없으며, 최소 1개의 참조 비디오 또는 이미지가 포함되어야 합니다
          items:
            type: string
            format: uri
          maxItems: 3
          example:
            - https://example.com/bgm.mp3
        duration:
          type: integer
          description: |-
            출력 비디오 길이(초), 기본값은 `5`초

            **설명:**
            - `4`~`15`초 사이의 임의의 정수값을 지원합니다
            - 재생 시간은 과금에 직접적으로 영향을 미칩니다
          default: 5
          minimum: 4
          maximum: 15
          example: 10
        quality:
          type: string
          description: |-
            비디오 해상도, 기본값은 `720p`

            **선택 가능한 값:**
            - `480p`: 낮은 해상도, 낮은 가격
            - `720p`: 표준 해상도, 기본값
            - `1080p`: 초고해상도
            - `4k`: 4K 초고해상도
          enum:
            - 480p
            - 720p
            - 1080p
            - 4k
          default: 720p
          example: 720p
        aspect_ratio:
          type: string
          description: |-
            비디오 화면 비율, 기본값은 `16:9`

            **선택 가능한 값:**
            - `16:9`(가로), `9:16`(세로), `1:1`(정사각형), `4:3`, `3:4`, `21:9`(울트라와이드)
            - `adaptive`: 프롬프트 의도에 따라 판단, 우선순위: 비디오 > 이미지 > 프롬프트

            **각 해상도별 픽셀 값:**

            | 화면 비율 | 480p | 720p | 1080p | 4K |
            |:------:|:----:|:----:|:-----:|:----:|
            | 16:9 | 864×496 | 1280×720 | 1920×1080 | 3840×2160 |
            | 4:3 | 752×560 | 1112×834 | 1664×1248 | 3326×2494 |
            | 1:1 | 640×640 | 960×960 | 1440×1440 | 2880×2880 |
            | 3:4 | 560×752 | 834×1112 | 1248×1664 | 2494×3326 |
            | 9:16 | 496×864 | 720×1280 | 1080×1920 | 2160×3840 |
            | 21:9 | 992×432 | 1470×630 | 2206×946 | 4398×1886 |
          enum:
            - '16:9'
            - '9:16'
            - '1:1'
            - '4:3'
            - '3:4'
            - '21:9'
            - adaptive
          default: '16:9'
          example: '16:9'
        generate_audio:
          type: boolean
          description: |-
            동기화된 오디오 생성 여부, 기본값은 `true`

            **선택 가능한 값:**
            - `true`: 비디오에 동기화된 오디오가 포함되며, 추가 요금이 없습니다
            - `false`: 무음 비디오 출력
          default: true
          example: true
        content_filter:
          type: boolean
          description: >-
            콘텐츠 필터, 기본값은 `true`


            **선택 가능한 값:**

            - `true`: 표준 콘텐츠 안전 검사, 기본값입니다

            - `false`: 콘텐츠 제한을 완화하며 +10%(`1.1x`)가 청구됩니다. 불법 및 금지된 콘텐츠는 이 설정과
            관계없이 항상 적용됩니다
          default: true
          example: true
        callback_url:
          type: string
          description: >-
            작업 완료 후 HTTPS 콜백 주소


            **콜백 시점:**

            - 작업 완료(completed), 실패(failed) 또는 취소(cancelled) 시 트리거

            - 과금 확인 완료 후 전송


            **보안 제한:**

            - HTTPS 프로토콜만 지원

            - 내부 네트워크 IP 주소로의 콜백 금지(127.0.0.1, 10.x.x.x, 172.16-31.x.x,
            192.168.x.x 등)

            - URL 길이는 `2048`자를 초과할 수 없습니다


            **콜백 메커니즘:**

            - 타임아웃: `10`초

            - 실패 시 최대 `3`회 재시도(실패 후 각각 `1`/`2`/`4`초 후 재시도)

            - 콜백 응답 본문 형식은 작업 조회 API 반환 형식과 동일

            - 2xx 상태 코드를 성공으로 간주하며, 다른 상태 코드는 재시도를 트리거합니다
          format: uri
          example: https://your-domain.com/webhooks/video-task-completed
    VideoGenerationResponse:
      type: object
      properties:
        created:
          type: integer
          description: 작업 생성 타임스탬프
          example: 1761313744
        id:
          type: string
          description: 작업 ID
          example: task-unified-1774857405-abc123
        model:
          type: string
          description: 실제 사용된 모델 이름
          example: seedance-2.0-reference-to-video
        object:
          type: string
          enum:
            - video.generation.task
          description: 작업의 구체적 유형
        progress:
          type: integer
          description: 작업 진행률 (0-100)
          minimum: 0
          maximum: 100
          example: 0
        status:
          type: string
          description: 작업 상태
          enum:
            - pending
            - processing
            - completed
            - failed
          example: pending
        task_info:
          $ref: '#/components/schemas/VideoTaskInfo'
          description: 비디오 작업 상세 정보
        type:
          type: string
          enum:
            - text
            - image
            - audio
            - video
          description: 작업의 출력 유형
          example: video
        usage:
          $ref: '#/components/schemas/VideoUsage'
          description: 사용량 및 과금 정보
    ErrorResponse:
      type: object
      properties:
        error:
          type: object
          properties:
            code:
              type: string
              description: 오류 코드 식별자
            message:
              type: string
              description: 오류 설명 정보
            type:
              type: string
              description: 오류 유형
    VideoTaskInfo:
      type: object
      properties:
        can_cancel:
          type: boolean
          description: 작업 취소 가능 여부
          example: true
        estimated_time:
          type: integer
          description: 예상 완료 시간(초)
          minimum: 0
          example: 165
        video_duration:
          type: integer
          description: 비디오 길이(초)
          example: 8
    VideoUsage:
      type: object
      description: 사용량 및 과금 정보
      properties:
        billing_rule:
          type: string
          description: 과금 규칙
          enum:
            - per_call
            - per_token
            - per_second
          example: per_second
        credits_reserved:
          type: number
          description: 예상 소비 크레딧 수
          minimum: 0
          example: 50
        user_group:
          type: string
          description: 사용자 그룹 카테고리
          example: default
  securitySchemes:
    bearerAuth:
      type: http
      scheme: bearer
      description: |-
        ##모든 API는 Bearer Token 인증이 필요합니다##

        **API Key 얻기:**

        [API Key 관리 페이지](https://evolink.ai/dashboard/keys)에서 API Key를 받으세요

        **요청 헤더에 다음을 추가하세요:**
        ```
        Authorization: Bearer YOUR_API_KEY
        ```

````