API Analyser l'imprimabilité
Analysez un modèle 3D pour l'imprimabilité FDM — étanchéité, volume, trous, arêtes non-manifold et faces dégénérées.
Créer une tâche Analyser l'imprimabilité
Ce point de terminaison crée une nouvelle tâche d'analyse de l'imprimabilité. La tâche évalue un modèle 3D et rapporte ses métriques d'imprimabilité.
Si la tâche d'entrée dispose déjà d'une imprimabilité mise en cache, la tâche renvoyée est immédiatement prête et le premier GET sur celle-ci renverra le résultat de l'analyse sans passer par le worker.
Paramètres
Seul l'un de input_task_id ou model_url est requis. Si les deux sont fournis, input_task_id est prioritaire.
- Name
- input_task_id
- Type
- string
- Requis
- Description
L'ID d'une tâche réussie que vous possédez. Types de tâches pris en charge : Image en 3D, Multi-image en 3D, Texte en 3D, Remaillage et Retexturisation. La tâche doit utiliser Meshy 6 (ou n'importe quel modèle Preview) et doit avoir un statut
SUCCEEDED.
- Name
- model_url
- Type
- string
- Requis
- Description
URL d'un modèle 3D à analyser. Formats pris en charge :
.glb,.gltf,.obj,.fbx,.stl. Taille maximale du fichier : 100 Mo. Doit utiliserhttp,httpsou une URLdata:(les URL de données contournent les vérifications d'extension).
Retours
La propriété result de la réponse contient l'id de la tâche Analyser l'imprimabilité nouvellement créée.
Modes d'échec
- Name
400 - Bad Request- Description
La requête était inacceptable. Causes courantes :
- Paramètre manquant : ni
input_task_idnimodel_urln'a été fourni. - UUID invalide :
input_task_idn'est pas un UUID valide. - URL de modèle invalide :
model_urlest mal formée, utilise un schéma non pris en charge ou possède une extension de fichier non prise en charge. - Fichier de modèle trop volumineux : le corps de
model_urla dépassé 100 Mo. - Tâche non réussie : la tâche référencée est toujours en attente, en cours ou a échoué.
- Paramètre manquant : ni
- Name
401 - Unauthorized- Description
L'authentification a échoué. Veuillez vérifier votre clé API.
- Name
403 - Forbidden- Description
La tâche existe mais appartient à un autre utilisateur.
- Name
404 - Not Found- Description
Causes courantes :
- La tâche n'existe pas ou a été supprimée.
- La tâche utilise un modèle antérieur à Meshy 6, ou son mode ne produit pas d'asset 3D.
- Le fichier de modèle sous-jacent n'est plus disponible dans le stockage.
- Name
429 - Too Many Requests- Description
Vous avez dépassé votre quota de tâches en attente ou votre limite de débit.
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"
}
Récupérer une tâche Analyser l'imprimabilité
Ce point de terminaison récupère une tâche d'analyse de l'imprimabilité par son ID.
Paramètres
- Name
- id
- Type
- path
- Description
L'ID de la tâche d'analyse de l'imprimabilité à récupérer.
Retours
L'objet de tâche Analyser l'imprimabilité. Le champ printability est null jusqu'à ce que la tâche atteigne 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
}
Supprimer une tâche Analyser l'imprimabilité
Ce point de terminaison supprime définitivement une tâche d'analyse de l'imprimabilité et son résultat mis en cache. Cette action est irréversible.
Paramètres de chemin
- Name
- id
- Type
- path
- Description
L'ID de la tâche d'analyse de l'imprimabilité à supprimer.
Retours
Renvoie 200 OK en cas de succès.
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.
Lister les tâches Analyser l'imprimabilité
Ce point de terminaison vous permet de récupérer une liste de tâches d'analyse de l'imprimabilité.
Paramètres
Attributs facultatifs
- Name
- page_num
- Type
- integer
- Description
Numéro de page pour la pagination. Commence à
1et utilise cette valeur par défaut.
- Name
- page_size
- Type
- integer
- Description
Limite de taille de page. La valeur par défaut est de
10éléments. Le maximum autorisé est de50éléments.
- Name
- sort_by
- Type
- string
- Description
Champ selon lequel trier. Valeurs disponibles :
+created_at: Trier par heure de création dans l'ordre croissant.-created_at: Trier par heure de création dans l'ordre décroissant.
Retours
Retourne une liste paginée d'objets de tâche Analyser l'imprimabilité.
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
}
]
Diffuser une tâche Analyser l'imprimabilité
Ce point de terminaison diffuse des mises à jour en temps réel pour une tâche d'analyse de l'imprimabilité à l'aide de Server-Sent Events (SSE).
Paramètres
- Name
- id
- Type
- path
- Description
Identifiant unique de la tâche d'analyse de l'imprimabilité à diffuser.
Retours
Retourne un flux d'objets de tâche Analyser l'imprimabilité sous forme de Server-Sent Events.
Pour les tâches PENDING ou IN_PROGRESS, le flux de réponse inclura uniquement les champs progress et status nécessaires. Le bloc printability n'est envoyé qu'une fois que la tâche atteint 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
}
L'objet de tâche Analyser l'imprimabilité
- Name
- id
- Type
- string
- Description
Identifiant unique de la tâche. Bien que nous utilisions un UUID triable par k pour les ids de tâche comme détail d’implémentation, vous ne devez pas faire d’hypothèses sur le format de l’id.
- Name
- type
- Type
- string
- Description
Type de la tâche analyze-printability. La valeur est
print-analyze.
- Name
- status
- Type
- string
- Description
Statut de la tâche. Les valeurs possibles sont l’une de
PENDING,IN_PROGRESS,SUCCEEDED,FAILED,CANCELED.
- Name
- progress
- Type
- integer
- Description
Progress de la tâche. Si la tâche n’a pas encore commencé, cette propriété sera
0. Une fois la tâche réussie, elle deviendra100.
- Name
- preceding_tasks
- Type
- integer
- Description
Le nombre de tâches précédentes.
La valeur de ce champ n’est significative que si le statut de la tâche est
PENDING.
- Name
- created_at
- Type
- timestamp
- Description
Horodatage de la création de la tâche, en millisecondes.
- Name
- started_at
- Type
- timestamp
- Description
Horodatage du démarrage de la tâche, en millisecondes. Si la tâche n’a pas encore commencé, cette propriété sera
0.
- Name
- finished_at
- Type
- timestamp
- Description
Horodatage de la fin de la tâche, en millisecondes. Si la tâche n’est pas encore terminée, cette propriété sera
0.
- Name
- expires_at
- Type
- timestamp
- Description
Horodatage du moment où le résultat de la tâche expirera du système, en millisecondes.
0si la tâche n’est pas encore terminée.
- Name
- task_error
- Type
- object
- Description
Informations d’erreur si la tâche a échoué. Cette propriété est
nullsi la tâche n’a pas échoué. Consultez Erreurs pour plus de détails.- Name
message- Type
- string
- Description
Message d’erreur décrivant ce qui s’est mal passé.
- Name
- printability
- Type
- object
- Description
Résultat de l’évaluation de l’imprimabilité.
nulljusqu’à ce que la tâche atteigneSUCCEEDED.- Name
_version- Type
- string
- Description
Version du schéma du résultat d’imprimabilité. Actuellement
v1.
- Name
status- Type
- string
- Description
Statut global. L’un de :
healthy: aucune erreur ni aucun avertissement.warning: au moins un avertissement, aucune erreur.error: au moins une erreur.unknown: le modèle n’a pas pu être analysé.
- Name
issue_count- Type
- integer
- Description
Nombre total de problèmes, égal à
error_count + warning_count.
- Name
error_count- Type
- integer
- Description
Nombre de problèmes de niveau erreur. Les erreurs sont levées lorsque le modèle n’est pas étanche, a un volume non positif ou comporte des arêtes non-manifold.
- Name
warning_count- Type
- integer
- Description
Nombre de problèmes de niveau avertissement. Les avertissements sont levés lorsque le modèle contient des faces dégénérées ou des trous.
- Name
metrics- Type
- object
- Description
Métriques de géométrie brutes renvoyées par l’évaluateur.
- Name
is_watertight- Type
- boolean
- Description
truelorsque le maillage n’a pas d’arêtes de bord (c.-à-d. qu’il est fermé).
- Name
volume- Type
- number
- Description
Volume du modèle en mètres cubes.
- Name
non_manifold_edges- Type
- integer
- Description
Nombre d’arêtes non-manifold.
- Name
degenerate_faces- Type
- integer
- Description
Nombre de faces dégénérées (faces de surface nulle ou invalides).
- Name
holes- Type
- integer
- Description
Nombre de trous (boucles de bord) dans le maillage.
- Name
evaluated_at- Type
- timestamp
- Description
Horodatage du calcul de l’analyse, en millisecondes depuis l’époque.
- Name
- consumed_credits
- Type
- integer
- Description
Toujours
0. Ce point de terminaison est gratuit.
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
}