Sketcher scripting/de

Erstellen eines Sketch-Objekts mit Python
So wird ein Sketch-Objekt erstellt:

Es werden der neu erstellten Skizze auch noch drei Linien hinzugefügt.

Erstellen einer Beschränkung mit Python
Die geometrischen Randbedingungen und die spezielle Randbedingung InterneAusrichtung können mit Makros und von der Python-Konsole aus durch Verwendung des folgenden Befehls erstellt werden:

Die maßlichen Randbedingungen        und die spezielle Randbedingung  Lichtbrechung (nach Snellius-Gesetz) festlegen können mit Makros und von der Python-Konsole aus durch Verwendung des folgenden Befehls erstellt werden:

z. B.

Das erste Argument wird weiter unten unter  Arten von Randbedingungen beschrieben.

Eine Randbedingung kann bis zu sechs Argumente besitzen; das können Kanten sein oder Angaben, welcher Bestandteil einer Kante von der Randbedingung verwendet wird. In den Dokumentationen der einzelnen Randbedingungen findet man Details zu den Kombinationen von Kanten und Bestandteilen von Kanten, die als Argumente übergeben werden können. Das Hauptproblem bei dieser Funktion besteht darin, die Liniennummer und die Knotennummer der zu bearbeitenden Linien korrekt zu identifizieren. Die folgenden Abschnitte beschreiben, wie man die Nummerierung einer Linie und die Nummerierung der Bestandteile einer Linie herausfindet.

Arten von Randbedingungen
Bei geometrischen Randbedingungen ist das erste Argument eines der folgenden. Die möglichen Kombinationen von Argumenten, die für jede Beschränkung zulässig sind, findet man auf der Referenzseite der zugehörigen Funktion.

Die Randbedingung Interne Ausrichtung festlegen verhält sich im Zusammenhang mit der Skripterstellung wie eine geometrische Randbedingung. Auch hier findet man auf der zugehörigen Referenzseite die möglichen Kombinationen von Argumenten, die für diese Randbedingung zulässig sind.

Bei maßlichen Randbedingungen ist das erste Argument eines der folgenden. Die möglichen Kombinationen von Argumenten, die für jede Randbedingung zulässig sind, findet man auf der Referenzseite der zugehörigen Funktion.

Die Randbedingung Lichtbrechung (nach Snellius-Gesetz) festlegen verhält sich im Zusammenhang mit der Skripterstellung wie eine maßliche Randbedingung. Auch hier findet man auf der zugehörigen Referenzseite die möglichen Kombinationen von Argumenten, die für diese Randbedingung zulässig sind.

Die Randbedingung Sperren ist ein GUI-Befehl, der die Randbedingungen  Horizontalen Abstand festlegen und  Vertikalen Abstand festlegen erstellt; sie ist keine eigenständige Randbedingung.

Identifizierung der Nummerierung einer Linie
Ich habe drei Linien gezeichnet, wie in der folgenden Abbildung dargestellt.



Durch bewegen des Mauszeigers über die Linie, lässt sich die Liniennummer unten links im FreeCAD Fenster anzeigen, siehe nächste Abbildung.



Leider beginnt die im FreeCAD-Fenster angezeigte Nummerierung bei 1, während die Nummerierung der Linien, die für das Skript verwendet wird, bei 0 beginnt: Das bedeutet, dass jedes Mal eins abgezogen werden muss, wenn man auf eine Linie verweisen möchte.

Positive Zahlen bezeichnen Skizzenkanten (Geraden, Kreise, Kegelschnitte, B-Splines usw.). Die folgenden Werte können verwendet werden, um Elemente zu kennzeichnen, die keine Skizzenkanten sind:


 * bezeichnet die horizontale x Achse
 * bezeichnet die vertikale y Achse
 * bezeichnet die externe Geometrieelementnummer (z. B. würde das externe Geometrieelement mit Index 0 in der reduzierten Liste  mit -3 bezeichnet, das folgende Element in der reduzierten Liste mit -4 usw.).

Identifizierung der Nummerierung der Abschnittsteile einer Linie
Um festzulegen, welcher Teil einer Linie von einer Beschränkung betroffen ist, kannst du die folgenden Werte verwendet werden:
 * , um anzugeben, dass die Beschränkung die gesamte Kante betrifft.
 * , um anzuzeigen, dass die Beschränkung den Anfangspunkt der Kante betrifft (ein Vollkreis hat keinen Anfangspunkt).
 * , um anzuzeigen, dass die Beschränkung den Endpunkt der Kante betrifft.
 * , um anzuzeigen, dass die Beschränkung den Mittelpunkt der Kante betrifft. Für Sketcher_CompCreateCircle.pnge und Sketcher_CompCreateConic.png (Ellipsen) ist dies der Mittelpunkt des Kreises bzw. das Zentrum (Schnittpunkt von Haupt- und Nebenachse) der Ellipse. Bei geraden Sketcher_CreateLine.svgn kann nicht zur Angabe des Mittelpunktes verwendet werden.
 * , um anzuzeigen, dass die Beschränkung den n-ten Pol eines Sketcher_CompCreateBSpline.png-Spline betrifft.

Die mit 1 und 2 gekennzeichneten Knoten sind in der Reihenfolge ihrer Erstellung nummeriert. Um die Reihenfolge ihrer Erstellung herauszufinden (wenn du viele Linien hast, kannst du dich nicht erinnern, welchen Knoten du zuerst erstellt hast), musst du nur den Mauszeiger über die beiden Knoten einer Linie bewegen, siehe folgende Abbildung.



Wenn du z. B. 4 und 5 liest, bedeutet dies, dass der Knoten mit der niedrigeren Nummer (4 in diesem Beispiel) mit der Nummer 1 (zuerst im Skriptbefehl) und der Knoten mit der höheren Nummer (5 in diesem Beispiel) mit der Nummer 2 im Skriptbefehl referenziert wird.

Beispiel
Nehmen wir das vorherige Beispiel der drei Linien. Die nachfolgende Abbildung zeigt die Nummerierung der einzelnen Linien und deren Knoten gemäß der Konvention für die Skripterstellung.



Der Befehl ergibt folgendes Ergebnis:



The full code to draw the three lines and add a Coincident constraint on two points from two lines is like this: