Netz Skripting

From FreeCAD Documentation
Jump to navigation Jump to search
This page is a translated version of the page Mesh Scripting and the translation is 10% complete.
Outdated translations are marked like this.
Other languages:
Bahasa Indonesia • ‎Deutsch • ‎English • ‎Türkçe • ‎español • ‎français • ‎italiano • ‎polski • ‎română • ‎svenska • ‎čeština • ‎русский • ‎中文(中国大陆)‎

Einleitung

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

To get access to the Mesh module you have to import it first:

import Mesh

Erstellen und Laden

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

To create an empty mesh object just use the standard constructor:

mesh = Mesh.Mesh()

Du kannst auch ein Objekt aus einer Datei erstellen

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

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

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)

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

top

Modellieren

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

To create regular geometries you can use one of the create*() methods. A torus, for instance, can be created as follows:

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

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.

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

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

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()

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 these 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

Template:Powerdocnavi/de