API de Redimensionar

A API de Redimensionar permite redimensionar modelos 3D existentes para dimensões do mundo real. Você pode especificar uma altura exata, uma restrição de lado mais longo ou permitir que a IA estime automaticamente o tamanho apropriado.


POST/openapi/v1/resize

Criar uma tarefa de Redimensionar

Este endpoint cria uma nova tarefa de redimensionamento.

Parâmetros

  • Name
    input_task_id
    Type
    string
    Obrigatório
    Description

    O ID de uma tarefa Meshy concluída cujo modelo você deseja redimensionar. A tarefa deve ter um status de SUCCEEDED. O formato de saída será GLB.

  • Name
    model_url
    Type
    string
    Obrigatório
    Description

    Uma URL ou Data URI acessível publicamente apontando para um arquivo de modelo 3D. Formatos compatíveis: .glb, .gltf, .obj, .fbx, .stl. Para Data URIs, use o MIME type: application/octet-stream. O formato de saída preservará o formato original do modelo de entrada.

  • Name
    resize_height
    Type
    number
    Description

    Redimensionar o modelo para uma altura específica medida em metros.

  • Name
    resize_longest_side
    Type
    number
    Description

    Redimensionar o modelo para que seu lado mais longo corresponda a este valor, medido em metros. A proporção é preservada.

  • Name
    auto_size
    Type
    boolean
    Description

    Quando definido como true, o serviço usa visão de IA para estimar automaticamente a altura real do objeto e redimensionar o modelo de acordo. A origem será definida por padrão como bottom, a menos que origin_at seja definido explicitamente.

  • Name
    origin_at
    Type
    string
    padrão bottom
    Description

    Posição da origem após o redimensionamento.

    Valores disponíveis: bottom, center.

Retornos

A propriedade result da resposta contém o id da tarefa de redimensionamento recém-criada.

Modos de falha

  • 400 - Bad Request

A solicitação era inaceitável. Causas comuns:

  • Parâmetro ausente: model_url ou input_task_id deve ser fornecido.
  • Mode de redimensionamento ausente: Pelo menos um entre resize_height, resize_longest_side ou auto_size deve ser especificado.
  • Parâmetros mutuamente exclusivos: resize_height, resize_longest_side e auto_size não podem ser combinados.
  • Tarefa de entrada inválida: O input_task_id deve se referir a uma tarefa bem-sucedida.
  • Formato de modelo inválido: O model_url aponta para um arquivo com uma extensão não compatível.
  • URL inacessível: Não foi possível baixar o model_url.
  • 401 - Unauthorized

Falha na autenticação. Verifique sua chave de API.

  • 402 - Payment Required

Créditos insuficientes para realizar esta tarefa.

  • 429 - Too Many Requests

Você excedeu seu limite de taxa.

Request

POST
/openapi/v1/resize
# Simple: resize to a specific height
curl https://api.meshy.ai/openapi/v1/resize \
-X POST \
-H "Authorization: Bearer ${YOUR_API_KEY}" \
-H 'Content-Type: application/json' \
-d '{
    "input_task_id": "018a210d-8ba4-705c-b111-1f1776f7f578",
    "resize_height": 1.8
  }'

# Advanced: resize longest side with custom origin
curl https://api.meshy.ai/openapi/v1/resize \
-X POST \
-H "Authorization: Bearer ${YOUR_API_KEY}" \
-H 'Content-Type: application/json' \
-d '{
    "model_url": "https://example.com/model.glb",
    "resize_longest_side": 2.0,
    "origin_at": "center"
  }'

Response

{
  "result": "0193bfc5-ee4f-73f8-8525-44b398884ce9"
}

GET/openapi/v1/resize/:id

Recuperar uma tarefa de Redimensionar

Este endpoint recupera uma tarefa de redimensionamento pelo seu ID.

Parâmetros

  • Name
    id
    Type
    path
    Description

    O ID da tarefa de redimensionamento a ser recuperada.

Retorna

O objeto da tarefa de Redimensionar.

Request

GET
/openapi/v1/resize/:id
curl https://api.meshy.ai/openapi/v1/resize/a43b5c6d-7e8f-901a-234b-567c890d1e2f \
-H "Authorization: Bearer ${YOUR_API_KEY}"

Response

{
  "id": "0193bfc5-ee4f-73f8-8525-44b398884ce9",
  "type": "resize",
  "model_urls": {
      "glb": "https://assets.meshy.ai/.../model.glb?Expires=..."
  },
  "progress": 100,
  "status": "SUCCEEDED",
  "created_at": 1699999999000,
  "started_at": 1700000000000,
  "finished_at": 1700000001000,
  "task_error": null,
  "consumed_credits": 1
}

DELETE/openapi/v1/resize/:id

Excluir uma tarefa de Redimensionar

Este endpoint exclui permanentemente uma tarefa de Redimensionar, incluindo todos os modelos e dados associados. Esta ação é irreversível.

Parâmetros de caminho

  • Name
    id
    Type
    path
    Description

    O ID da tarefa de Redimensionar a ser excluída.

Retornos

Retorna 200 OK em caso de sucesso.

Request

DELETE
/openapi/v1/resize/:id
curl --request DELETE \
  --url https://api.meshy.ai/openapi/v1/resize/a43b5c6d-7e8f-901a-234b-567c890d1e2f \
  -H "Authorization: Bearer ${YOUR_API_KEY}"

Response

// Returns 200 Ok on success.

GET/openapi/v1/resize

Listar tarefas de Redimensionar

Este endpoint permite recuperar uma lista de tarefas de redimensionamento.

Parâmetros

  • Name
    page_num
    Type
    integer
    padrão 1
    Description

    Número da página para paginação.

  • Name
    page_size
    Type
    integer
    padrão 10
    Description

    Limite de tamanho da página. O máximo permitido é de 50 itens.

  • Name
    sort_by
    Type
    string
    Description

    Campo pelo qual ordenar. Valores disponíveis:

    • +created_at: Ordenar por hora de criação em ordem crescente.
    • -created_at: Ordenar por hora de criação em ordem decrescente.

Retornos

Retorna uma lista paginada de Os objetos de tarefa de Redimensionar.

Request

GET
/openapi/v1/resize
curl https://api.meshy.ai/openapi/v1/resize?page_size=10 \
-H "Authorization: Bearer ${YOUR_API_KEY}"

Response

[
  {
    "id": "0193bfc5-ee4f-73f8-8525-44b398884ce9",
    "type": "resize",
    "model_urls": {
      "glb": "https://assets.meshy.ai/.../model.glb?Expires=..."
    },
    "progress": 100,
    "status": "SUCCEEDED",
    "created_at": 1699999999000,
    "started_at": 1700000000000,
    "finished_at": 1700000001000,
    "task_error": null,
    "consumed_credits": 1
  }
]

GET/openapi/v1/resize/:id/stream

Transmitir uma tarefa de Redimensionar

Este endpoint transmite atualizações em tempo real para uma tarefa de redimensionamento usando Server-Sent Events (SSE).

Parâmetros

  • Name
    id
    Type
    path
    Description

    Identificador único da tarefa de redimensionamento a ser transmitida em stream.

Retorna

Retorna um stream de Os objetos de tarefa de Redimensionar como Server-Sent Events.

Para tarefas PENDING ou IN_PROGRESS, o stream de resposta incluirá apenas os campos necessários progress e status.

Request

GET
/openapi/v1/resize/:id/stream
curl -N https://api.meshy.ai/openapi/v1/resize/a43b5c6d-7e8f-901a-234b-567c890d1e2f/stream \
-H "Authorization: Bearer ${YOUR_API_KEY}"

Response Stream

// Message event examples illustrate task progress.
event: message
data: {
  "id": "0193bfc5-ee4f-73f8-8525-44b398884ce9",
  "progress": 0,
  "status": "PENDING"
}

event: message
data: {
  "id": "0193bfc5-ee4f-73f8-8525-44b398884ce9",
  "type": "resize",
  "model_urls": {
    "glb": "https://assets.meshy.ai/.../model.glb?Expires=..."
  },
  "progress": 100,
  "status": "SUCCEEDED",
  "created_at": 1699999999000,
  "started_at": 1700000000000,
  "finished_at": 1700000001000,
  "task_error": null,
  "consumed_credits": 1
}

O objeto de tarefa Redimensionar

O objeto de tarefa Redimensionar representa um trabalho de redimensionamento.

Propriedades

  • id · string

Identificador exclusivo da tarefa.

  • type · string

Tipo da tarefa. O valor é resize.

  • model_urls · object

URL para download do arquivo de modelo redimensionado. Ao usar input_task_id, a saída é sempre GLB. Ao usar model_url, a saída preserva o formato original.

  • progress · integer

Progress da tarefa (0-100).

  • status · string

Status da tarefa. Valores possíveis: PENDING, IN_PROGRESS, SUCCEEDED, FAILED, CANCELED.

  • preceding_tasks · integer

A contagem de tarefas anteriores. Significativo apenas quando o status é PENDING.

  • created_at · carimbo de data/hora

Carimbo de data/hora de quando a tarefa foi criada, em milissegundos.

  • started_at · carimbo de data/hora

Carimbo de data/hora de quando a tarefa foi iniciada, em milissegundos. 0 se não tiver sido iniciada.

  • finished_at · carimbo de data/hora

Carimbo de data/hora de quando a tarefa foi concluída, em milissegundos. 0 se não tiver sido concluída.

  • task_error · object

Objeto de erro se a tarefa falhar. Consulte Erros para mais detalhes.

  • consumed_credits · integer

O número de créditos consumidos por esta tarefa (1 crédito por tarefa de redimensionamento). Retorna 0 para tarefas FAILED.