API Analisar imprimibilidade
Analise um modelo 3D quanto à imprimibilidade FDM — estanqueidade, volume, furos, arestas non-manifold e faces degeneradas.
Criar uma tarefa de Analisar imprimibilidade
Este endpoint cria uma nova tarefa de análise de imprimibilidade. A tarefa avalia um modelo 3D e relata suas métricas de imprimibilidade.
Se a tarefa de entrada já tiver a imprimibilidade em cache, a tarefa retornada estará pronta imediatamente e o primeiro GET nela retornará o resultado da análise sem passar pelo worker.
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 de uma tarefa bem-sucedida de sua propriedade. Tipos de tarefa compatíveis: Imagem para 3D, Multi-imagem para 3D, Texto para 3D, Remesh e Retexturizar. A tarefa deve usar Meshy 6 (ou qualquer modelo Preview) e deve ter um status de
SUCCEEDED.
- Name
- model_url
- Type
- string
- Obrigatório
- Description
URL de um modelo 3D a ser analisado. Formatos compatíveis:
.glb,.gltf,.obj,.fbx,.stl. Tamanho máximo do arquivo: 100 MB. Deve usarhttp,httpsou uma URLdata:(URLs data ignoram as verificações de extensão).
Retorna
A propriedade result da resposta contém o id da tarefa de análise de imprimibilidade recém-criada.
Modos de falha
- Name
400 - Bad Request- Description
A solicitação não foi aceitável. Causas comuns:
- Parâmetro ausente: nem
input_task_idnemmodel_urlforam fornecidos. - UUID inválido:
input_task_idnão é um UUID válido. - URL de modelo inválida:
model_urlestá malformada, usa um esquema não compatível ou tem uma extensão de arquivo não compatível. - Arquivo de modelo muito grande: o corpo de
model_urlexcedeu 100 MB. - Tarefa não bem-sucedida: a tarefa referenciada ainda está pendente, em progress ou falhou.
- Parâmetro ausente: nem
- Name
401 - Unauthorized- Description
A autenticação falhou. Verifique sua chave de API.
- Name
403 - Forbidden- Description
A tarefa existe, mas pertence a um usuário diferente.
- Name
404 - Not Found- Description
Causas comuns:
- A tarefa não existe ou foi excluída.
- A tarefa usa um modelo anterior ao Meshy 6, ou seu mode não produz um asset 3D.
- O arquivo de modelo subjacente não está mais disponível no armazenamento.
- Name
429 - Too Many Requests- Description
Você excedeu sua cota de tarefas pendentes ou o limite de taxa.
Request
# Analyze an existing task
curl https://api.meshy.ai/openapi/v1/print/analyze \
-X POST \
-H "Authorization: Bearer ${YOUR_API_KEY}" \
-H 'Content-Type: application/json' \
-d '{
"input_task_id": "018a210d-8ba4-705c-b111-1f1776f7f578"
}'
# Or analyze a model URL directly
curl https://api.meshy.ai/openapi/v1/print/analyze \
-X POST \
-H "Authorization: Bearer ${YOUR_API_KEY}" \
-H 'Content-Type: application/json' \
-d '{
"model_url": "https://example.com/model.glb"
}'
Response
{
"result": "0193bfc5-ee4f-73f8-8525-44b398884ce9"
}
Recuperar uma tarefa de Analisar imprimibilidade
Este endpoint recupera uma tarefa de análise de imprimibilidade pelo seu ID.
Parâmetros
- Name
- id
- Type
- path
- Description
O ID da tarefa de análise de imprimibilidade a ser recuperada.
Retorna
O Objeto de tarefa de Analisar imprimibilidade. O campo printability é null até que a tarefa alcance SUCCEEDED.
Request
curl https://api.meshy.ai/openapi/v1/print/analyze/a43b5c6d-7e8f-901a-234b-567c890d1e2f \
-H "Authorization: Bearer ${YOUR_API_KEY}"
Response
{
"id": "0193bfc5-ee4f-73f8-8525-44b398884ce9",
"type": "print-analyze",
"status": "SUCCEEDED",
"progress": 100,
"created_at": 1699999999000,
"started_at": 1700000000000,
"finished_at": 1700000001000,
"expires_at": 1715725401000,
"task_error": null,
"printability": {
"_version": "v1",
"status": "warning",
"issue_count": 1,
"error_count": 0,
"warning_count": 1,
"metrics": {
"is_watertight": true,
"volume": 1.316167354292668,
"non_manifold_edges": 0,
"degenerate_faces": 43242,
"holes": 0
},
"evaluated_at": 1700000001000
},
"consumed_credits": 0
}
Excluir uma tarefa de Analisar imprimibilidade
Este endpoint exclui permanentemente uma tarefa de Analisar imprimibilidade e seu resultado em cache. Esta ação é irreversível.
Parâmetros de caminho
- Name
- id
- Type
- path
- Description
O ID da tarefa de Analisar imprimibilidade a ser excluída.
Retornos
Retorna 200 OK em caso de sucesso.
Request
curl --request DELETE \
--url https://api.meshy.ai/openapi/v1/print/analyze/a43b5c6d-7e8f-901a-234b-567c890d1e2f \
-H "Authorization: Bearer ${YOUR_API_KEY}"
Response
// Returns 200 Ok on success.
Listar tarefas de Analisar imprimibilidade
Este endpoint permite recuperar uma lista de tarefas de Analisar imprimibilidade.
Parâmetros
Atributos opcionais
- Name
- page_num
- Type
- integer
- Description
Número da página para paginação. Começa e usa
1como padrão.
- Name
- page_size
- Type
- integer
- Description
Limite de tamanho da página. O padrão é
10itens. O máximo permitido é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 Objetos de tarefa de Analisar imprimibilidade.
Request
curl https://api.meshy.ai/openapi/v1/print/analyze?page_size=10 \
-H "Authorization: Bearer ${YOUR_API_KEY}"
Response
[
{
"id": "0193bfc5-ee4f-73f8-8525-44b398884ce9",
"type": "print-analyze",
"status": "SUCCEEDED",
"progress": 100,
"preceding_tasks": 0,
"created_at": 1699999999000,
"started_at": 1700000000000,
"finished_at": 1700000001000,
"expires_at": 1715725401000,
"task_error": null,
"printability": {
"_version": "v1",
"status": "warning",
"issue_count": 1,
"error_count": 0,
"warning_count": 1,
"metrics": {
"is_watertight": true,
"volume": 1.316167354292668,
"non_manifold_edges": 0,
"degenerate_faces": 43242,
"holes": 0
},
"evaluated_at": 1700000001000
},
"consumed_credits": 0
}
]
Transmitir em stream uma tarefa de Analisar imprimibilidade
Este endpoint transmite atualizações em tempo real para uma tarefa de analisar imprimibilidade usando Server-Sent Events (SSE).
Parâmetros
- Name
- id
- Type
- path
- Description
Identificador exclusivo da tarefa de analisar imprimibilidade a ser transmitida em stream.
Retorna
Retorna um stream de Objetos de tarefa de Analisar imprimibilidade como Server-Sent Events.
Para tarefas PENDING ou IN_PROGRESS, o stream de resposta incluirá apenas os campos necessários progress e status. O bloco printability é enviado somente quando a tarefa atinge SUCCEEDED.
Request
curl -N https://api.meshy.ai/openapi/v1/print/analyze/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": "a43b5c6d-7e8f-901a-234b-567c890d1e2f",
"progress": 0,
"status": "PENDING"
}
event: message
data: {
"id": "a43b5c6d-7e8f-901a-234b-567c890d1e2f",
"type": "print-analyze",
"status": "SUCCEEDED",
"progress": 100,
"preceding_tasks": 0,
"created_at": 1699999999000,
"started_at": 1700000000000,
"finished_at": 1700000001000,
"expires_at": 1715725401000,
"task_error": null,
"printability": {
"_version": "v1",
"status": "warning",
"issue_count": 1,
"error_count": 0,
"warning_count": 1,
"metrics": {
"is_watertight": true,
"volume": 1.316167354292668,
"non_manifold_edges": 0,
"degenerate_faces": 43242,
"holes": 0
},
"evaluated_at": 1700000001000
},
"consumed_credits": 0
}
O objeto da tarefa Analisar imprimibilidade
- Name
- id
- Type
- string
- Description
Identificador único 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 analyze-printability. O valor é
print-analyze.
- Name
- status
- Type
- string
- Description
Status da tarefa. Os valores possíveis são um de
PENDING,IN_PROGRESS,SUCCEEDED,FAILED,CANCELED.
- Name
- progress
- Type
- integer
- Description
Progress da tarefa. Se a tarefa ainda não foi iniciada, esta propriedade será
0. Quando a tarefa for concluída com sucesso, isto se tornará100.
- Name
- preceding_tasks
- Type
- integer
- Description
A contagem de tarefas precedentes.
O valor deste campo só é significativo 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 foi 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 foi finalizada, esta propriedade será
0.
- Name
- expires_at
- Type
- timestamp
- Description
Carimbo de data/hora de quando o resultado da tarefa expirará do sistema, em milissegundos.
0se a tarefa ainda não foi finalizada.
- Name
- task_error
- Type
- object
- Description
Informações de erro se a tarefa falhou. Esta propriedade é
nullse a tarefa não falhou. Consulte Erros para mais detalhes.- Name
message- Type
- string
- Description
Mensagem de erro descrevendo o que deu errado.
- Name
- printability
- Type
- object
- Description
Resultado da avaliação de imprimibilidade.
nullaté que a tarefa atinjaSUCCEEDED.- Name
_version- Type
- string
- Description
Versão do esquema do resultado de imprimibilidade. Atualmente
v1.
- Name
status- Type
- string
- Description
Status geral. Um de:
healthy: sem erros e sem avisos.warning: pelo menos um aviso, sem erros.error: pelo menos um erro.unknown: o modelo não pôde ser analisado.
- Name
issue_count- Type
- integer
- Description
Contagem total de problemas, igual a
error_count + warning_count.
- Name
error_count- Type
- integer
- Description
Número de problemas de nível de erro. Erros são gerados quando o modelo não é watertight, tem volume não positivo ou tem arestas non-manifold.
- Name
warning_count- Type
- integer
- Description
Número de problemas de nível de aviso. Avisos são gerados quando o modelo contém faces degeneradas ou furos.
- Name
metrics- Type
- object
- Description
Métricas brutas de geometria retornadas pelo avaliador.
- Name
is_watertight- Type
- boolean
- Description
truequando a malha não tem arestas de limite (ou seja, está fechada).
- Name
volume- Type
- number
- Description
Volume do modelo em metros cúbicos.
- Name
non_manifold_edges- Type
- integer
- Description
Contagem de arestas non-manifold.
- Name
degenerate_faces- Type
- integer
- Description
Contagem de faces degeneradas (faces de área zero ou inválidas).
- Name
holes- Type
- integer
- Description
Contagem de furos (loops de limite) na malha.
- Name
evaluated_at- Type
- timestamp
- Description
Carimbo de data/hora de quando a análise foi computada, em milissegundos desde a época.
- Name
- consumed_credits
- Type
- integer
- Description
Sempre
0. Este endpoint é gratuito.
The Analyze Printability Task Object
{
"id": "0193bfc5-ee4f-73f8-8525-44b398884ce9",
"type": "print-analyze",
"status": "SUCCEEDED",
"progress": 100,
"preceding_tasks": 0,
"created_at": 1699999999000,
"started_at": 1700000000000,
"finished_at": 1700000001000,
"expires_at": 1715725401000,
"task_error": null,
"printability": {
"_version": "v1",
"status": "warning",
"issue_count": 1,
"error_count": 0,
"warning_count": 1,
"metrics": {
"is_watertight": true,
"volume": 1.316167354292668,
"non_manifold_edges": 0,
"degenerate_faces": 43242,
"holes": 0
},
"evaluated_at": 1700000001000
},
"consumed_credits": 0
}