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.
Criar uma tarefa de Redimensionar
Este endpoint cria uma nova tarefa de redimensionamento.
Parâmetros
Somente um entre input_task_id ou model_url é obrigatório. Se ambos forem fornecidos, input_task_id terá prioridade.
- 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.
Exatamente um mode de redimensionamento é obrigatório: resize_height, resize_longest_side ou auto_size. Esses três parâmetros são mutuamente exclusivos.
- 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 comobottom, a menos queorigin_atseja 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_urlouinput_task_iddeve ser fornecido. - Mode de redimensionamento ausente: Pelo menos um entre
resize_height,resize_longest_sideouauto_sizedeve ser especificado. - Parâmetros mutuamente exclusivos:
resize_height,resize_longest_sideeauto_sizenão podem ser combinados. - Tarefa de entrada inválida: O
input_task_iddeve se referir a uma tarefa bem-sucedida. - Formato de modelo inválido: O
model_urlaponta 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
# 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"
}
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
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
}
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
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.
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
50itens.
- 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
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
}
]
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
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.