Mesh Scripting/fr: Difference between revisions

From FreeCAD Documentation
No edit summary
(Created page with "Pour créer un objet maillage vide il suffit d'utiliser la commande standard :")
Line 17: Line 17:
==Création==
==Création==


To create an empty mesh object just use the standard constructor:
Pour créer un objet maillage vide il suffit d'utiliser la commande standard :


{{Code|code=
{{Code|code=

Revision as of 15:57, 6 June 2020

Introduction

Pour accéder au module Mesh, vous devez d'abord l'importer:

import Mesh

Création

Pour créer un objet maillage vide il suffit d'utiliser la commande standard :

mesh = Mesh.Mesh()

Vous pouvez aussi créer un objet à partir d'un fichier

mesh = Mesh.Mesh("D:/temp/Something.stl")

ou créer un ensemble de triangles en les décrivant par leurs sommets (Vertex) :

triangles = [
# triangle 1
[-0.5000, -0.5000, 0.0000], [0.5000, 0.5000, 0.0000], [-0.5000, 0.5000, 0.0000],
#triangle 2
[-0.5000, -0.5000, 0.0000], [0.5000, -0.5000, 0.0000], [0.5000, 0.5000, 0.0000],
]
meshObject = Mesh.Mesh(triangles)
Mesh.show(meshObject)

Le Mesh-Kernel prend soin de créer une structure de données topologiquement correcte en triant les points et les bords coïncidents.

En haut

Modélisation

Pour créer des formes géométriques, vous pouvez utiliser le script Python BuildRegularGeoms.py.

m = Mesh.createTorus(8.0, 2.0, 50)
Mesh.show(m)

Les deux premiers paramètres définissent les rayons du tore, et le troisième paramètre est un facteur de sous-échantillonnage pour le nombre de triangles qui seront créés. Plus cette valeur est élevée plus la figure sera lisse et plus cette valeur est basse plus grossière sera la figure.
La classe Mesh offre un ensemble de fonctions booléennes qui peuvent êtres utilisées à des fins de modélisation. Il fournit l'union, l'intersection et la différence entre deux objets maillés.

The Mesh module also provides three Boolean methods: union(), intersection() and difference():

m1, m2              # are the input mesh objects
m3 = Mesh.Mesh(m1)  # create a copy of m1
m3.unite(m2)        # union of m1 and m2, the result is stored in m3
m4 = Mesh.Mesh(m1)
m4.intersect(m2)    # intersection of m1 and m2
m5 = Mesh.Mesh(m1)
m5.difference(m2)   # the difference of m1 and m2
m6 = Mesh.Mesh(m2)
m6.difference(m1)   # the difference of m2 and m1, usually the result is different to m5

Et ici, un exemple complet qui calcule l'intersection entre une sphère et un cylindre qui coupe la sphère.

import FreeCAD, Mesh
cylA = Mesh.createCylinder(2.0, 10.0, True, 1.0, 36)
cylB = Mesh.createCylinder(1.0, 12.0, True, 1.0, 36)
cylB.Placement.Base = (FreeCAD.Vector(-1, 0, 0)) # move cylB to avoid co-planar faces
pipe = cylA
pipe = pipe.difference(cylB)
pipe.flipNormals() # somehow required
doc = FreeCAD.ActiveDocument
obj = d.addObject("Mesh::Feature", "Pipe")
obj.Mesh = pipe
doc.recompute()

En haut

Remarques

Une extension (difficile à utiliser) de scripts Mesh qui est à tester. Dans cette compilation test, toutes les méthodes sont appelées et toutes les propriétés et attributs sont manipulés. Donc, si vous êtes assez audacieux, jetez un œil au module de test unitaire.

Voir aussi Mesh API

En haut