Difference between revisions of "Mesh Scripting/fr"

From FreeCAD Documentation
Jump to navigation Jump to search
 
(17 intermediate revisions by 3 users not shown)
Line 1: Line 1:
 
<languages/>
 
<languages/>
 
{{Docnav/fr
 
{{Docnav/fr
|[[FreeCAD_Scripting_Basics/fr|Débuter avec les scripts]]
+
|[[Topological_data_scripting/fr|Scripts pour création topologique]]
|[[Topological_data_scripting/fr|Script pour des pièces]]
+
|[[Mesh_to_Part/fr|Du maillage à l'objet Part]]
 
}}
 
}}
  
Line 9: Line 9:
 
== Introduction ==
 
== Introduction ==
  
Vous devez tout d'abord importer le module Mesh:
+
Pour accéder au module {{incode|Mesh}}, vous devez d'abord l'importer:
  
 
{{Code|code=
 
{{Code|code=
Line 15: Line 15:
 
}}
 
}}
  
Dès que vous avez importé le module de maillage de la classe Mesh, vous accéderez facilitent aux fonctions C++ Mesh-Kernel de FreeCAD.
+
==Création==
  
==Création et chargement==
 
 
Pour créer un objet maillage vide il suffit d'utiliser la commande standard :
 
Pour créer un objet maillage vide il suffit d'utiliser la commande standard :
  
Line 24: Line 23:
 
}}
 
}}
  
Vous pouvez aussi créer un objet à partir d'un fichier
+
Vous pouvez aussi créer un objet à partir d'un fichier:
  
 
{{Code|code=
 
{{Code|code=
mesh = Mesh.Mesh('D:/temp/Something.stl')
+
mesh = Mesh.Mesh("D:/temp/Something.stl")
 
}}
 
}}
 
(Une liste de fichiers compatibles avec "Mesh" (maillage) est disponible '''[[Feature_list/fr#Fonctions_principales|ici]]''').
 
  
 
ou créer un ensemble de triangles en les décrivant par leurs sommets (Vertex) :
 
ou créer un ensemble de triangles en les décrivant par leurs sommets (Vertex) :
  
 
{{Code|code=
 
{{Code|code=
planarMesh = [
+
triangles = [
 
# triangle 1
 
# triangle 1
 
[-0.5000, -0.5000, 0.0000], [0.5000, 0.5000, 0.0000], [-0.5000, 0.5000, 0.0000],
 
[-0.5000, -0.5000, 0.0000], [0.5000, 0.5000, 0.0000], [-0.5000, 0.5000, 0.0000],
Line 41: Line 38:
 
[-0.5000, -0.5000, 0.0000], [0.5000, -0.5000, 0.0000], [0.5000, 0.5000, 0.0000],
 
[-0.5000, -0.5000, 0.0000], [0.5000, -0.5000, 0.0000], [0.5000, 0.5000, 0.0000],
 
]
 
]
planarMeshObject = Mesh.Mesh(planarMesh)
+
meshObject = Mesh.Mesh(triangles)
Mesh.show(planarMeshObject)
+
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.
+
Le Mesh-Kernel prend soin de créer une structure de données topologiquement correcte en triant les points et les bords coïncidents.
 
 
Plus tard, vous verrez comment tester et examiner les données de maillage.
 
  
 
[[#top|En haut]]
 
[[#top|En haut]]
Line 53: Line 48:
 
== Modélisation ==
 
== Modélisation ==
  
Pour créer des formes géométriques, vous pouvez utiliser le script Python {{FileName|BuildRegularGeoms.py}}.
+
Pour créer des formes géométriques, vous pouvez utiliser l'une des méthodes {{incode|create*()}}. Un tore, par exemple, peut être créé comme suit:
  
 
{{Code|code=
 
{{Code|code=
import BuildRegularGeoms
+
m = Mesh.createTorus(8.0, 2.0, 50)
 +
Mesh.show(m)
 
}}
 
}}
  
Ce script fournit les méthodes pour construire des figures simples qui ont besoin d'une rotation comme des sphères, ellipsoïdes, cylindres, tores et cônes. Il existe aussi une méthode pour créer un simple cube.<br />
+
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.
Un tore, par exemple, peut être créé comme suit:
 
  
{{Code|code=
+
Le module {{incode|Mesh}} propose également trois méthodes booléennes: {{incode|union()}}, {{incode|intersection()}} et {{incode|difference()}}:
t = BuildRegularGeoms.Toroid(8.0, 2.0, 50) # list with several thousands triangles
 
m = Mesh.Mesh(t)
 
}}
 
 
 
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.<br />
 
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.
 
  
 
{{Code|code=
 
{{Code|code=
Line 82: Line 71:
 
}}
 
}}
  
Et ici, un exemple complet qui calcule l'intersection entre une sphère et un cylindre qui coupe la sphère.
+
Voici un exemple qui crée un tube en utilisant la méthode {{incode|difference()}}:
  
 
{{Code|code=
 
{{Code|code=
import Mesh, BuildRegularGeoms
+
import FreeCAD, Mesh
sphere = Mesh.Mesh(BuildRegularGeoms.Sphere(5.0, 50))
+
cylA = Mesh.createCylinder(2.0, 10.0, True, 1.0, 36)
cylinder = Mesh.Mesh(BuildRegularGeoms.Cylinder(2.0, 10.0, True, 1.0, 50))
+
cylB = Mesh.createCylinder(1.0, 12.0, True, 1.0, 36)
diff = sphere
+
cylB.Placement.Base = (FreeCAD.Vector(-1, 0, 0)) # move cylB to avoid co-planar faces
diff = diff.difference(cylinder)
+
pipe = cylA
d = FreeCAD.newDocument()
+
pipe = pipe.difference(cylB)
d.addObject("Mesh::Feature", "Diff_Sphere_Cylinder").Mesh = diff
+
pipe.flipNormals() # somehow required
d.recompute()
+
doc = FreeCAD.ActiveDocument
 +
obj = d.addObject("Mesh::Feature", "Pipe")
 +
obj.Mesh = pipe
 +
doc.recompute()
 
}}
 
}}
  
 
[[#top|En haut]]
 
[[#top|En haut]]
  
== Exporter ==
+
==Remarques==
Vous pouvez même écrire votre modèle de maillage dans un module Python :
 
  
{{Code|code=
+
Les scripts, bien que difficile à utiliser, de test unitaire du module {{incode|Mesh}} constituent une source étendue de scripts liés au maillage.
m.write("D:/Develop/Projekte/FreeCAD/FreeCAD_0.7/Mod/Mesh/SavedMesh.py")
+
Dans ces tests unitaires, toutes les méthodes sont appelées et toutes les propriétés / attributs sont modifiés.
import SavedMesh
+
Donc, si vous êtes assez audacieux, jetez un œil au [https://github.com/FreeCAD/FreeCAD/blob/master/src/Mod/Mesh/App/MeshTestsApp.py module de test unitaire].
m2 = Mesh.Mesh(SavedMesh.faces)
 
}}
 
  
[[#top|top]]
+
Voir aussi: [[Mesh_API/fr|Mesh API]].
  
<div class="mw-translate-fuzzy">
+
[[#top|En haut]]
== Quelques points en plus ==
 
</div>
 
 
 
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 [https://github.com/FreeCAD/FreeCAD/blob/master/src/Mod/Mesh/App/MeshTestsApp.py module de test unitaire].
 
 
 
Voir aussi [[Mesh_API/fr|Mesh API]]
 
 
 
[[#top|top]]
 
  
 
{{Docnav/fr
 
{{Docnav/fr
|[[FreeCAD_Scripting_Basics/fr|Débuter avec les scripts]]
+
|[[Topological_data_scripting/fr|Scripts pour création topologique]]
|[[Topological_data_scripting/fr|Script pour des pièces]]
+
|[[Mesh_to_Part/fr|Du maillage à l'objet Part]]
 
}}
 
}}
  
{{Mesh Tools navi{{#translation:}}}}
 
 
{{Powerdocnavi{{#translation:}}}}
 
{{Powerdocnavi{{#translation:}}}}
 +
[[Category:Developer Documentation{{#translation:}}]]
 
[[Category:Python Code{{#translation:}}]]
 
[[Category:Python Code{{#translation:}}]]
 +
{{Mesh Tools navi{{#translation:}}}}
 
{{clear}}
 
{{clear}}

Latest revision as of 18:23, 14 June 2020

Other languages:
Bahasa Indonesia • ‎Deutsch • ‎English • ‎Türkçe • ‎español • ‎français • ‎italiano • ‎polski • ‎română • ‎svenska • ‎čeština • ‎русский • ‎中文(中国大陆)‎

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 l'une des méthodes create*(). Un tore, par exemple, peut être créé comme suit:

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.

Le module Mesh propose également trois méthodes booléennes: union(), intersection() et 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

Voici un exemple qui crée un tube en utilisant la méthode difference():

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

Les scripts, bien que difficile à utiliser, de test unitaire du module Mesh constituent une source étendue de scripts liés au maillage. Dans ces tests unitaires, toutes les méthodes sont appelées et toutes les propriétés / attributs sont modifiés. Donc, si vous êtes assez audacieux, jetez un œil au module de test unitaire.

Voir aussi: Mesh API.

En haut