API de Remesh
A API de Remesh permite refazer a malha e exportar modelos 3D existentes gerados por outras APIs da Meshy (como Imagem para 3D ou Texto para 3D) em vários formatos. Esta seção fornece detalhes sobre como usar a API de Remesh.
Criar uma tarefa de Remesh
Este endpoint cria uma nova tarefa de Remesh.
Para conversão de formato e redimensionamento, use a API de Converter e a API de Redimensionar dedicadas. Os parâmetros obsoleto abaixo continuarão funcionando, mas recomendamos os novos endpoints para novas integrações.
Parâmetros
Apenas 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 da tarefa concluída de Imagem para 3D ou Texto para 3D cuja malha você deseja refazer. Esta tarefa deve ser uma das seguintes tarefas: Prévia de Texto para 3D, Refinamento de Texto para 3D, Imagem para 3D ou Retexturizar. Além disso, ela deve ter um status de
SUCCEEDED.
- Name
- model_url
- Type
- string
- Obrigatório
- Description
Forneça um modelo 3D para que o Meshy refaça a malha por meio de uma URL publicamente acessível ou Data URI. Formatos compatíveis:
.glb,.gltf,.obj,.fbx,.stl.Para Data URIs, use o MIME type:
application/octet-stream.
- Name
- target_formats
- Type
- string[]
- padrão ["glb"]
- Description
Uma lista de formatos de destino para o modelo com malha refeita. Quando omitido, apenas GLB é gerado.
Valores disponíveis:
glb,fbx,obj,usdz,blend,stl,3mf.
- Name
- topology
- Type
- string
- padrão triangle
- Description
Especifique a topology do modelo gerado.
Valores disponíveis:
quad: Gera uma malha predominantemente quad.triangle: Gera uma malha triangular simplificada.
- Name
- target_polycount
- Type
- integer
- padrão 30,000
- Description
Especifique o número alvo de polígonos no modelo gerado. O número real de polígonos pode diferir do alvo dependendo da complexidade da geometria.
O intervalo de valores válido varia dependendo do nível do usuário:
- 100 a 300.000 (inclusive)
- Name
- decimation_mode
- Type
- integer
- Description
Habilite a decimação adaptativa definindo um nível de contagem de polígonos. Quando definido,
target_polycounté ignorado.Valores disponíveis:
1: Adaptativo — contagem de polígonos ultra.2: Adaptativo — contagem de polígonos alta.3: Adaptativo — contagem de polígonos média.4: Adaptativo — contagem de polígonos baixa.
- Name
- resize_height
- Type
- number
- ⚠ obsoleto
- padrão 0
- Description
Redimensione o modelo para uma determinada altura medida em metros. Recomendamos usar a API de Redimensionar dedicada.
auto_size,resize_heighteresize_longest_sidesão mutuamente exclusivos.
- Name
- resize_longest_side
- Type
- number
- ⚠ obsoleto
- padrão 0
- Description
Redimensione o modelo para que a dimensão mais longa da caixa delimitadora seja igual ao valor especificado em metros. Recomendamos usar a API de Redimensionar dedicada.
auto_size,resize_heighteresize_longest_sidesão mutuamente exclusivos.
- Name
- auto_size
- Type
- boolean
- ⚠ obsoleto
- padrão false
- 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. Recomendamos usar a API de Redimensionar dedicada.auto_size,resize_heighteresize_longest_sidesão mutuamente exclusivos.
auto_size = true- Name
- origin_at
- Type
- string
- ⚠ obsoleto
- padrão bottom
- Description
Posição da origem. Recomendamos usar a API de Redimensionar dedicada.
Valores disponíveis:
bottom,center.
- Name
- convert_format_only
- Type
- boolean
- ⚠ obsoleto
- Description
Se
true, o serviço apenas alterará o formato do arquivo de modelo de entrada, ignorando outras entradas comotopology,resize_heightetarget_polycount. Recomendamos usar a API de Converter dedicada.target_formatsdeve ser fornecido seconvert_format_onlyestiver definido comotrue.
- Name
- alpha_thumbnail
- Type
- boolean
- padrão false
- Description
Quando definido como
true, a tarefa também renderiza uma versão com fundo transparente (RGBA) da prévia e a retorna comoalpha_thumbnail_urlna resposta GET. O campothumbnail_urlexistente permanece inalterado.
Retornos
A propriedade result da resposta contém o id da tarefa de Remesh recém-criada.
Modos de falha
- Name
400 - Bad Request- Description
A solicitação não foi aceitável. Causas comuns:
- Parâmetro ausente:
model_urlouinput_task_iddeve ser fornecido. - Tarefa de entrada inválida: O
input_task_iddeve se referir a uma tarefa bem-sucedida de um modelo compatível. - Formato de modelo inválido: O
model_urlaponta para um arquivo com uma extensão não compatível. - URL inacessível: O
model_urlnão pôde ser baixado. - Topology inválida: O parâmetro
topologyé inválido. - Parâmetros mutuamente exclusivos:
auto_sizeeresize_heightnão podem ser definidos ao mesmo tempo.
- Parâmetro ausente:
- Name
401 - Unauthorized- Description
Falha na autenticação. Verifique sua chave de API.
- Name
402 - Payment Required- Description
Créditos insuficientes para executar esta tarefa.
- Name
429 - Too Many Requests- Description
Você excedeu seu limite de taxa.
Request
# Basic remesh with custom formats and resize
curl https://api.meshy.ai/openapi/v1/remesh \
-X POST \
-H "Authorization: Bearer ${YOUR_API_KEY}" \
-H 'Content-Type: application/json' \
-d '{
"input_task_id": "018a210d-8ba4-705c-b111-1f1776f7f578",
"target_formats": ["glb", "fbx"],
"topology": "quad",
"target_polycount": 50000,
"resize_height": 1.0,
"origin_at": "bottom"
}'
# Quad remesh with auto-size
curl https://api.meshy.ai/openapi/v1/remesh \
-X POST \
-H "Authorization: Bearer ${YOUR_API_KEY}" \
-H 'Content-Type: application/json' \
-d '{
"input_task_id": "018a210d-8ba4-705c-b111-1f1776f7f578",
"target_formats": ["glb", "fbx"],
"topology": "quad",
"target_polycount": 50000,
"auto_size": true
}'
Response
{
"result": "0193bfc5-ee4f-73f8-8525-44b398884ce9"
}
Recuperar uma tarefa de Remesh
Este endpoint recupera uma tarefa de Remesh pelo seu ID.
Parâmetros
- Name
- id
- Type
- path
- Description
O ID da tarefa de Remesh a ser recuperada.
Retornos
O objeto da tarefa de Remesh.
Request
curl https://api.meshy.ai/openapi/v1/remesh/a43b5c6d-7e8f-901a-234b-567c890d1e2f \
-H "Authorization: Bearer ${YOUR_API_KEY}"
Response
{
"id": "0193bfc5-ee4f-73f8-8525-44b398884ce9",
"type": "remesh",
"model_urls": {
"glb": "https://assets.meshy.ai/***/tasks/0193bfc5-ee4f-73f8-8525-44b398884ce9/output/model.glb?Expires=***",
"fbx": "https://assets.meshy.ai/***/tasks/0193bfc5-ee4f-73f8-8525-44b398884ce9/output/model.fbx?Expires=***",
"obj": "https://assets.meshy.ai/***/tasks/0193bfc5-ee4f-73f8-8525-44b398884ce9/output/model.obj?Expires=***",
"usdz": "https://assets.meshy.ai/***/tasks/0193bfc5-ee4f-73f8-8525-44b398884ce9/output/model.usdz?Expires=***",
"blend": "https://assets.meshy.ai/***/tasks/0193bfc5-ee4f-73f8-8525-44b398884ce9/output/model.blend?Expires=***",
"stl": "https://assets.meshy.ai/***/tasks/0193bfc5-ee4f-73f8-8525-44b398884ce9/output/model.stl?Expires=***"
},
"progress": 100,
"status": "SUCCEEDED",
"created_at": 1699999999000,
"started_at": 1700000000000,
"finished_at": 1700000001000,
"task_error": null,
}
Excluir uma tarefa de Remesh
Este endpoint exclui permanentemente uma tarefa de remesh, 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 remesh a ser excluída.
Retornos
Retorna 200 OK em caso de sucesso.
Request
curl --request DELETE \
--url https://api.meshy.ai/openapi/v1/remesh/a43b5c6d-7e8f-901a-234b-567c890d1e2f \
-H "Authorization: Bearer ${YOUR_API_KEY}"
Response
// Returns 200 Ok on success.
Listar tarefas de Remesh
Este endpoint permite recuperar uma lista de tarefas de Remesh.
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 horário de criação em ordem crescente.-created_at: Ordenar por horário de criação em ordem decrescente.
Retornos
Retorna uma lista paginada de Objetos de tarefa de Remesh.
Request
curl https://api.meshy.ai/openapi/v1/remesh?page_size=10 \
-H "Authorization: Bearer ${YOUR_API_KEY}"
Response
[
{
"id": "0193bfc5-ee4f-73f8-8525-44b398884ce9",
"type": "remesh",
"model_urls": {
"glb": "https://assets.meshy.ai/***/tasks/0193bfc5-ee4f-73f8-8525-44b398884ce9/output/model.glb?Expires=***",
"fbx": "https://assets.meshy.ai/***/tasks/0193bfc5-ee4f-73f8-8525-44b398884ce9/output/model.fbx?Expires=***",
"obj": "https://assets.meshy.ai/***/tasks/0193bfc5-ee4f-73f8-8525-44b398884ce9/output/model.obj?Expires=***",
"usdz": "https://assets.meshy.ai/***/tasks/0193bfc5-ee4f-73f8-8525-44b398884ce9/output/model.usdz?Expires=***",
"blend": "https://assets.meshy.ai/***/tasks/0193bfc5-ee4f-73f8-8525-44b398884ce9/output/model.blend?Expires=***",
"stl": "https://assets.meshy.ai/***/tasks/0193bfc5-ee4f-73f8-8525-44b398884ce9/output/model.stl?Expires=***"
},
"progress": 100,
"status": "SUCCEEDED",
"created_at": 1699999999000,
"started_at": 1700000000000,
"finished_at": 1700000001000,
"task_error": null
}
]
Transmitir uma tarefa de Remesh
Este endpoint transmite atualizações em tempo real para uma tarefa de Remesh usando Server-Sent Events (SSE).
Parâmetros
- Name
- id
- Type
- path
- Description
Identificador exclusivo da tarefa de Remesh a ser transmitida.
Retorno
Retorna um fluxo de objetos de tarefa de Remesh como Server-Sent Events.
Para tarefas PENDING ou IN_PROGRESS, o fluxo de resposta incluirá apenas os campos necessários progress e status.
Request
curl -N https://api.meshy.ai/openapi/v1/remesh/a43b5c6d-7e8f-901a-234b-567c890d1e2f/stream \
-H "Authorization: Bearer ${YOUR_API_KEY}"
Response Stream
// Error event example
event: error
data: {
"status_code": 404,
"message": "Task not found"
}
// Message event examples illustrate task progress.
// For PENDING or IN_PROGRESS tasks, the response stream will not include all fields.
event: message
data: {
"id": "0193bfc5-ee4f-73f8-8525-44b398884ce9",
"progress": 0,
"status": "PENDING"
}
event: message
data: {
"id": "0193bfc5-ee4f-73f8-8525-44b398884ce9",
"type": "remesh",
"model_urls": {
"glb": "https://assets.meshy.ai/***/tasks/0193bfc5-ee4f-73f8-8525-44b398884ce9/output/model.glb?Expires=***",
"fbx": "https://assets.meshy.ai/***/tasks/0193bfc5-ee4f-73f8-8525-44b398884ce9/output/model.fbx?Expires=***",
"obj": "https://assets.meshy.ai/***/tasks/0193bfc5-ee4f-73f8-8525-44b398884ce9/output/model.obj?Expires=***",
"usdz": "https://assets.meshy.ai/***/tasks/0193bfc5-ee4f-73f8-8525-44b398884ce9/output/model.usdz?Expires=***",
"blend": "https://assets.meshy.ai/***/tasks/0193bfc5-ee4f-73f8-8525-44b398884ce9/output/model.blend?Expires=***",
"stl": "https://assets.meshy.ai/***/tasks/0193bfc5-ee4f-73f8-8525-44b398884ce9/output/model.stl?Expires=***"
},
"progress": 100,
"status": "SUCCEEDED",
"created_at": 1699999999000,
"started_at": 1700000000000,
"finished_at": 1700000001000,
"task_error": null,
}
O Objeto de Tarefa de Remesh
O objeto de Tarefa de Remesh representa uma unidade de trabalho que o Meshy usa para refazer a malha e exportar um modelo 3D existente em vários formatos. O objeto tem as seguintes propriedades:
Propriedades
- Name
- id
- Type
- string
- Description
Identificador exclusivo da tarefa. Embora usemos um UUID k-sortable para ids de tarefa como detalhe de implementação, você não deve fazer nenhuma suposição sobre o formato do id.
- Name
- type
- Type
- string
- Description
Tipo da tarefa Remesh. O valor é
remesh.
- Name
- model_urls
- Type
- object
- Description
URL para download do arquivo de modelo 3D texturizado gerado pela Meshy. A propriedade para um formato será omitida se o formato não for gerado, em vez de retornar uma string vazia.
- Name
glb- Type
- string
- Description
URL para download do arquivo GLB.
- Name
fbx- Type
- string
- Description
URL para download do arquivo FBX.
- Name
obj- Type
- string
- Description
URL para download do arquivo OBJ.
- Name
usdz- Type
- string
- Description
URL para download do arquivo USDZ.
- Name
blend- Type
- string
- Description
URL para download do arquivo Blender.
- Name
stl- Type
- string
- Description
URL para download do arquivo STL.
- Name
3mf- Type
- string
- Description
URL para download do arquivo 3MF. Presente apenas quando
3mffoi solicitado viatarget_formats.
- Name
- thumbnail_url
- Type
- string
- Description
URL para download de uma imagem de pré-visualização renderizada a partir do modelo com malha refeita.
- Name
- alpha_thumbnail_url
- Type
- string
- Description
URL para download de uma versão com fundo transparente (RGBA) de
thumbnail_url. Presente apenas quando a tarefa foi criada comalpha_thumbnail: truee a pré-visualização transparente foi renderizada com sucesso; caso contrário, este campo é omitido.
- Name
- progress
- Type
- integer
- Description
Progress da tarefa. Se a tarefa ainda não tiver sido iniciada, esta propriedade será
0. Assim que a tarefa tiver sido concluída com sucesso, isto se tornará100.
- Name
- status
- Type
- string
- Description
Status da tarefa. Os valores possíveis são um de
PENDING,IN_PROGRESS,SUCCEEDED,FAILED.
- Name
- preceding_tasks
- Type
- integer
- Description
A contagem de tarefas anteriores.
O valor deste campo é significativo apenas se o status da tarefa for
PENDING.
- Name
- created_at
- Type
- timestamp
- Description
Carimbo de data/hora de quando a tarefa foi criada, em milissegundos.
- Name
- started_at
- Type
- timestamp
- Description
Carimbo de data/hora de quando a tarefa foi iniciada, em milissegundos. Se a tarefa ainda não tiver sido iniciada, esta propriedade será
0.
- Name
- finished_at
- Type
- timestamp
- Description
Carimbo de data/hora de quando a tarefa foi finalizada, em milissegundos. Se a tarefa ainda não tiver sido finalizada, esta propriedade será
0.
- Name
- task_error
- Type
- object
- Description
Detalhes do erro para tarefas com falha. Consulte Erros para a referência completa do objeto
task_error.
- Name
- consumed_credits
- Type
- integer
- Description
O número de créditos consumidos por esta tarefa. Presente quando o status da tarefa é
PENDING,IN_PROGRESSouSUCCEEDED. Retorna0para tarefasFAILED(os créditos são reembolsados em caso de falha).
Example Remesh Task Object
{
"id": "0193bfc5-ee4f-73f8-8525-44b398884ce9",
"type": "remesh",
"model_urls": {
"glb": "https://assets.meshy.ai/***/tasks/0193bfc5-ee4f-73f8-8525-44b398884ce9/output/model.glb?Expires=***",
"fbx": "https://assets.meshy.ai/***/tasks/0193bfc5-ee4f-73f8-8525-44b398884ce9/output/model.fbx?Expires=***",
"obj": "https://assets.meshy.ai/***/tasks/0193bfc5-ee4f-73f8-8525-44b398884ce9/output/model.obj?Expires=***",
"usdz": "https://assets.meshy.ai/***/tasks/0193bfc5-ee4f-73f8-8525-44b398884ce9/output/model.usdz?Expires=***",
"blend": "https://assets.meshy.ai/***/tasks/0193bfc5-ee4f-73f8-8525-44b398884ce9/output/model.blend?Expires=***",
"stl": "https://assets.meshy.ai/***/tasks/0193bfc5-ee4f-73f8-8525-44b398884ce9/output/model.stl?Expires=***"
},
"progress": 100,
"status": "SUCCEEDED",
"preceding_tasks": 0,
"created_at": 1699999999000,
"started_at": 1700000000000,
"finished_at": 1700000001000,
"task_error": {
"message": ""
},
"consumed_credits": 5
}