Mesh Scripting/de: Difference between revisions

From FreeCAD Documentation
(Updating to match new version of source page)
(Updating to match new version of source page)
Line 47: Line 47:
planarMesh = [
planarMesh = [
# 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],
#triangle 2
#triangle 2
[-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)
planarMeshObject = Mesh.Mesh(planarMesh)
Line 55: Line 55:
}}
}}


<div class="mw-translate-fuzzy">
Der Mesh Kernel kümmert sich um die Schaffung einer topologisch richtigen Datenstruktur, durch Sortieren zusammenfallender Punkte und Kanten.
Der Mesh Kernel kümmert sich um die Schaffung einer topologisch richtigen Datenstruktur, durch Sortieren zusammenfallender Punkte und Kanten.
</div>


Später wirst Du sehen, wie Du Netzdaten testen und untersuchen kannst.
Später wirst Du sehen, wie Du Netzdaten testen und untersuchen kannst.

[[#top|top]]


<div class="mw-translate-fuzzy">
<div class="mw-translate-fuzzy">
Line 64: Line 68:
</div>
</div>


To create regular geometries you can use the Python script BuildRegularGeoms.py.
To create regular geometries you can use the Python script {{FileName|BuildRegularGeoms.py}}.


{{Code|code=
{{Code|code=
Line 70: Line 74:
}}
}}


<div class="mw-translate-fuzzy">
Dieses Skript bietet Methoden zur Definition einfacher Rotationskörper wie Kugeln, Ellipsoide, Zylinder, Toroide und Kegel. Und es hat auch eine Methode, um einen einfachen Würfel zu erstellen.
Dieses Skript bietet Methoden zur Definition einfacher Rotationskörper wie Kugeln, Ellipsoide, Zylinder, Toroide und Kegel. Und es hat auch eine Methode, um einen einfachen Würfel zu erstellen.
Um z.B. einen Ringkern zu erstellen, kann man wie folgt vorgehen:
Um z.B. einen Ringkern zu erstellen, kann man wie folgt vorgehen:
</div>


{{Code|code=
{{Code|code=
Line 78: Line 84:
}}
}}


<div class="mw-translate-fuzzy">
Die ersten beiden Parameter definieren die Radien des Torus und der dritte Parameter ist ein Teilabtastfaktor dafür, wie viele Dreiecke erzeugt werden. Je höher dieser Wert, desto glatter und je niedriger desto gröber ist der Körper.
Die ersten beiden Parameter definieren die Radien des Torus und der dritte Parameter ist ein Teilabtastfaktor dafür, wie viele Dreiecke erzeugt werden. Je höher dieser Wert, desto glatter und je niedriger desto gröber ist der Körper.
Die Mesh Klasse stellt eine Reihe von booleschen Funktionen zur Verfügung, die für Modellierungszwecke verwendet werden können. Es stellt die Verbindung, den Schnittpunkt und die Differenz zweier Netz Objekte dar.
Die Mesh Klasse stellt eine Reihe von booleschen Funktionen zur Verfügung, die für Modellierungszwecke verwendet werden können. Es stellt die Verbindung, den Schnittpunkt und die Differenz zweier Netz Objekte dar.
</div>


{{Code|code=
{{Code|code=
Line 97: Line 105:
{{Code|code=
{{Code|code=
import Mesh, BuildRegularGeoms
import Mesh, BuildRegularGeoms
sphere = Mesh.Mesh( BuildRegularGeoms.Sphere(5.0, 50) )
sphere = Mesh.Mesh(BuildRegularGeoms.Sphere(5.0, 50))
cylinder = Mesh.Mesh( BuildRegularGeoms.Cylinder(2.0, 10.0, True, 1.0, 50) )
cylinder = Mesh.Mesh(BuildRegularGeoms.Cylinder(2.0, 10.0, True, 1.0, 50))
diff = sphere
diff = sphere
diff = diff.difference(cylinder)
diff = diff.difference(cylinder)
d = FreeCAD.newDocument()
d = FreeCAD.newDocument()
d.addObject("Mesh::Feature","Diff_Sphere_Cylinder").Mesh=diff
d.addObject("Mesh::Feature", "Diff_Sphere_Cylinder").Mesh = diff
d.recompute()
d.recompute()
}}
}}


[[#top|top]]
<div class="mw-translate-fuzzy">
=== Untersuchen and Testen ===
</div>

<div class="mw-translate-fuzzy">
=== Schreiben Sie Ihre eigenen Algorithmen ===
</div>


<div class="mw-translate-fuzzy">
<div class="mw-translate-fuzzy">
Line 125: Line 127:
}}
}}


[[#top|top]]
<div class="mw-translate-fuzzy">
=== Gui verwandte Themen ===
</div>


<div class="mw-translate-fuzzy">
<div class="mw-translate-fuzzy">
Line 141: Line 141:


Siehe auch [[Mesh_API/de|Mesh API]]
Siehe auch [[Mesh_API/de|Mesh API]]

[[#top|top]]


<div class="mw-translate-fuzzy">
<div class="mw-translate-fuzzy">

Revision as of 08:49, 28 May 2020

Einleitung

Zunächst einmal müssen Sie das Netz (Mesh) Modul importieren:

First of all you have to import the Mesh module:

import Mesh

Danach hast Du Zugriff auf das Mesh Modul und die Mesh Klasse, die die Funktionen des FreeCAD C++ Mesh Kernels erleichtern.

Erstellen und Laden

Um ein leeres Mesh Objekt zu erstellen, benutze einfach den Standard Konstruktor:

mesh = Mesh.Mesh()

Du kannst auch ein Objekt aus einer Datei erstellen

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

(Eine Liste der kompatiblen Dateitypen findest Du unter 'Meshes' hier.)

Oder erstelle es aus einer Reihe von durch ihre Eckpunkte beschriebenen Dreiecken:

planarMesh = [
# 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],
]
planarMeshObject = Mesh.Mesh(planarMesh)
Mesh.show(planarMeshObject)

Der Mesh Kernel kümmert sich um die Schaffung einer topologisch richtigen Datenstruktur, durch Sortieren zusammenfallender Punkte und Kanten.

Später wirst Du sehen, wie Du Netzdaten testen und untersuchen kannst.

top

Modellieren

Um regelmäßige Geometrien zu erstellen, kannst Du das Python Skript BuildRegularGeoms.py verwenden.

To create regular geometries you can use the Python script BuildRegularGeoms.py.

import BuildRegularGeoms

Dieses Skript bietet Methoden zur Definition einfacher Rotationskörper wie Kugeln, Ellipsoide, Zylinder, Toroide und Kegel. Und es hat auch eine Methode, um einen einfachen Würfel zu erstellen. Um z.B. einen Ringkern zu erstellen, kann man wie folgt vorgehen:

t = BuildRegularGeoms.Toroid(8.0, 2.0, 50) # list with several thousands triangles
m = Mesh.Mesh(t)

Die ersten beiden Parameter definieren die Radien des Torus und der dritte Parameter ist ein Teilabtastfaktor dafür, wie viele Dreiecke erzeugt werden. Je höher dieser Wert, desto glatter und je niedriger desto gröber ist der Körper. Die Mesh Klasse stellt eine Reihe von booleschen Funktionen zur Verfügung, die für Modellierungszwecke verwendet werden können. Es stellt die Verbindung, den Schnittpunkt und die Differenz zweier Netz Objekte dar.

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

Schließlich ein vollständiges Beispiel, das die Schnittmenge zwischen einer Kugel und einem Zylinder, der die Kugel schneidet berechnet.

import Mesh, BuildRegularGeoms
sphere = Mesh.Mesh(BuildRegularGeoms.Sphere(5.0, 50))
cylinder = Mesh.Mesh(BuildRegularGeoms.Cylinder(2.0, 10.0, True, 1.0, 50))
diff = sphere
diff = diff.difference(cylinder)
d = FreeCAD.newDocument()
d.addObject("Mesh::Feature", "Diff_Sphere_Cylinder").Mesh = diff
d.recompute()

top

Exportieren

Du kannst das Mesh sogar in ein Python Modul schreiben:

m.write("D:/Develop/Projekte/FreeCAD/FreeCAD_0.7/Mod/Mesh/SavedMesh.py")
import SavedMesh
m2 = Mesh.Mesh(SavedMesh.faces)

top

Krimskrams

Eine umfangreiche (wenn auch schwer zu bedienende) Quelle für auf Mesh bezogenes Skripting sind die Einheitstestkripte des Mesh Moduls. In diesen Komponententests werden buchstäblich alle Methoden aufgerufen und alle Eigenschaften/Attribute optimiert. Wenn Du also kühn genug bist, schau Dir das Komponententestmodul an.

An extensive (though hard to use) source of Mesh related scripting are the unit test scripts of the Mesh-Module. In this unit tests literally all methods are called and all properties/attributes are tweaked. So if you are bold enough, take a look at the Unit Test module.

Siehe auch Mesh API

top