FreeCAD Logo FreeCAD 1.0
  • Englisch Afrikaans Arabisch Weißrussisch Katalanisch Tschechisch Deutsch Griechisch Spanisch Spanisch Baskisch Finnisch Philippinisch Französisch Galicisch Kroatisch Ungarisch Indonesisch Italienisch Japanisch Kabylisch Koreanisch Litauisch Niederländisch Norwegisches Bokmål Polnisch Portugiesisch Portugiesisch Rumänisch Russisch Slowakisch Slowenisch Serbisch Schwedisch Türkisch Ukrainisch Valencianisch Vietnamesisch Chinesisch Chinesisch
  • Funktionen
  • Herunterladen
  • Blog
  • Dokumentation
    Inhaltsverzeichnis Erste Schritte Benutzerdokumentation Das FreeCAD-Handbuch Dokumentation der Arbeitsbereiche Python-Dokumentation Dokumentation der C++ Programmierung Anleitungen Häufig gestellte Fragen Datenschutzrichtlinie Über FreeCAD
  • Mitwirken
    Wie kann ich helfen Sponsor Einen Fehler melden Einen Pull Request durchführen Jobs und Finanzierung Richtlinien für Beiträge Entwicklerhandbuch Übersetzungen
  • Community
    Verhaltenskodex Forum The FPA GitHub GitLab Codeberg Mastodon Matrix IRC IRC via Webchat Gitter Discord Reddit Twitter Facebook LinkedIn Kalender
  • ♥ Donate

Donate

$
SEPA-Informationen
Bitte richten Sie Ihre SEPA-Überweisung an:
Beneficiary: The FreeCAD project association
IBAN: BE04 0019 2896 4531
BIC/SWIFT: GEBABEBBXXX
Kreditinstitut: BNP Paribas Fortis
Adresse: Rue de la Station 64, 1360 Perwez, Belgium

While Stripe doesn't support monthly donations, you can still become a sponsor! Simply make a one-time donation equivalent to 12 months of support, and you'll gain access to the corresponding sponsoring tier. It's an easy and flexible way to contribute.

If you are not sure or not able to commit to a regular donation, but still want to help the project, you can do a one-time donation, of any amount.

Choose freely the amount you wish to donate one time only.

You can support FreeCAD by sponsoring it as an individual or organization through various platforms. Sponsorship provides a steady income for developers, allowing the FPA to plan ahead and enabling greater investment in FreeCAD. To encourage sponsorship, we offer different tiers, and unless you choose to remain anonymous, your name or company logo will be featured on our website accordingly.

from 1 USD / 1 EUR per month. You will not have your name displayed here, but you will have helped the project a lot anyway. Together, normal sponsors maintain the project on its feet as much as the bigger sponsors.

from 25 USD / 25 EUR per month. Your name or company name is displayed on this page.

from 100 USD / 100 EUR per month. Your name or company name is displayed on this page, with a link to your website, and a one-line description text.

from 200 USD / 200 EUR per month. Your name or company name and logo displayed on this page, with a link to your website and a custom description text. Companies that have helped FreeCAD early on also appear under Gold sponsors.

Instead of donating each month, you might find it more comfortable to make a one-time donation that, when divided by twelve, would give you right to enter a sponsoring tier. Don't hesitate to do so!

Choose freely the amount you wish to donate each month.

Please inform your forum name or twitter handle as a notein your transfer, or reach to us, so we can give you proper credits!

GeomFüllfläche
Surface

Surface Füllfläche

Menüeintrag
Surface → Füllfläche
Arbeitsbereich
Surface
Standardtastenkürzel
Keiner
Eingeführt in Version
0.17
Siehe auch
Keiner

Beschreibung

Das Werkzeug Surface Füllfläche erstellt eine Oberfläche aus einer Reihe von verbundenen Randkurven. Die Krümmung der Oberfläche kann zusätzlich über Kanten und Knotenpunkte innerhalb der Fläche sowie einer Stützfläche gesteuert werden.

Die Basisgeometrie kann zu Kurven, die mit den Arbeitsbereichen Draft oder Sketcher erstellt wurden, gehören, aber auch zu Festkörperobjekten, die mit dem Arbeitsbereich Part erzeugt wurden.

Zwei gefüllte Oberflächen, umrandet von vier Kanten auf der XY-Ebene. Die Oberfläche auf der rechten Seite wird zusätzlich durch eine Kante beeinflusst, die nicht zur Umrandung gehört.

Anwendung

  1. Es gibt mehrere Möglichkeiten, das Werkzeug aufzurufen:
    • Die Taste Filling drücken.
    • Die Option Surface → Filling aus dem Menü wählen.
  2. Das Aufgaben-Fenster Boundaries wird geöffnet. Siehe Optionen.
  3. Zwei oder mehr Kanten in der 3D-Ansicht auswählen:
    • Es ist zu diesem Zeitpunkt nicht erforderlich, die Schaltfläche Kante hinzufügen im Abschnitt Grenzen zu drücken.
    • Die Kanten müssen in aufeinanderfolgender Reihenfolge ausgewählt werden.
    • Die Kanten müssen miteinander verbunden sein, aber die gesamte Begrenzung muss nicht geschlossen sein.
    • Die gesamte Begrenzung darf sich nicht selbst schneiden.
    • Für eine 360°-Kreisbegrenzung können zwei halbkreisförmige Kanten ausgewählt werden.
  4. Eine Vorschau der endgültigen Form wird angezeigt, sobald genügend gültige Geometrie ausgewählt wurde.
  5. Optional eine Stützfläche auswählen. Siehe Beispiel.
  6. Optional eine oder mehrere Kantenbeschränkungen auswählen.
  7. Optional eine oder mehrere Scheitelpunktbeschränkungen auswählen.
  8. Auf die Schaltfläche OK klicken.

Optionen

  • Im Abschnitt Grenzen können eine Auflagefläche und Begrenzungskanten festgelegt werden:
    • Die Schaltfläche Auflagefläche drücken und eine Fläche in der 3D-Ansicht auswählen, um eine Auflagefläche hinzuzufügen.
      • Auf das Symbol klicken, um die Auflagefläche zu entfernen.
    • Einmal auf die Schaltfläche Kante hinzufügen drücken, um mit der Auswahl von Begrenzungskanten in der 3D-Ansicht zu beginnen.
    • Es gibt mehrere Möglichkeiten, die Auswahl von Begrenzungskanten aufzuheben:
      • Einmal auf die Schaltfläche Kante entfernen drücken, um die Auswahl von Kanten in der 3D-Ansicht aufzuheben.
      • Eine Kante in der Liste auswählen und Entfernen drücken.
      • Mit der rechten Maustaste auf eine Kante in der Liste klicken und Entfernen aus dem Kontextmenü wählen.
  • Im Abschnitt Nicht-Begrenzungskanten können Kanten-Beschränkungen angegeben werden:
    • Die Auswahloptionen sind ähnlich wie bei Begrenzungskanten.
  • Im Abschnitt Knoten-Beschränkungen können nicht an Grenzen liegende Eckpunkte festgelegt werden:
    • Die Auswahloptionen entsprechen denen für an Grenzen liegende Kanten.
  • Esc-Taste oder die Schaltfläche Abbrechen drücken, um den Befehl abzubrechen.

Beispiel

Die Stützfläche stellt eine weitere Beschränkung für die Oberfläche dar. Das folgende einfache Beispiel gibt einen Eindruck davon, wie dies funktioniert:

  1. Im 16px Arbeitsbereich Part erstellt man einen Zylinder und setzt dessen Daten-EigenschaftAngle auf 180°.
  2. Zum Arbeitsbereich Surface wechseln und die Schaltfläche Füllen drücken.
  3. Die beiden halbkreisförmigen Kanten und die beiden geraden Kanten auswählen, die sie verbinden.
  4. Das Ergebnis entspricht den vier Begrenzungskanten, aber die innere Form unterscheidet sich deutlich von der zylindrischen Fläche.
  5. Das Oberflächenobjekt bearbeiten und für den Stützfläche die zylindrische Fläche auswählen.
  6. Die geänderte Form entspricht nun viel besser der zylindrischen Fläche.

Eigenschaften

Ein Oberflächenfüllungs-Objekt (Klasse Surface::Filling) leitet sich von der grundlegenden Part Formelement (Klasse Part::Feature, über die Unterklasse Part::Spline) ab und teilt daher alle Eigenschaften der letzteren.

Zusätzlich zu den in Part Formelement beschriebenen Eigenschaften, hat die Füllfläche in der Eigenschaften-Ansicht folgende Eigenschaften.

Daten

Füllung

  • Daten-EigenschaftBoundary Edges (LinkSubList): Grenzkanten; C0 ist für Kanten ohne entsprechende Fläche erforderlich.
  • Daten-EigenschaftBoundary Faces (StringList):
  • Daten-EigenschaftBoundary Order (IntegerList): Reihenfolge der Beschränkungen für Begrenzungsflächen; 0, 1 und 2 sind möglich.
  • Daten-EigenschaftUnbound Edges (LinkSubList): ungebundene Beschränkungsränder; C0 ist für Ränder ohne entsprechende Fläche erforderlich.
  • Daten-EigenschaftUnbound Faces (StringList):
  • Daten-EigenschaftUnbound Order (IntegerList): Reihenfolge der Einschränkungen für ungebundene Flächen; 0, 1 und 2 sind möglich.
  • Daten-EigenschaftFree Faces (LinkSubList): freie Beschränkung auf einer Fläche.
  • Daten-EigenschaftFree Order (IntegerList): Reihenfolge der Beschränkungen für freie Flächen.
  • Daten-EigenschaftPoints (LinkSubList): Einschränkungspunkte auf der Oberfläche.
  • Daten-EigenschaftInitial Face (LinkSub): Anfangsfläche, die verwendet werden soll.
  • Daten-EigenschaftDegree (Integer): Ausgangswert, standardmäßig 3.
  • Daten-EigenschaftPoints On Curve (Integer): Anzahl der Punkte auf einer Kante für die Beschränkung.
  • Daten-EigenschaftIterations (Integer): Anzahl der Iterationen, standardmäßig ist 2 eingestellt.
  • Daten-EigenschaftAnisotropy (Bool): Der Standardwert ist false.
  • Daten-EigenschaftTolerance2d (Float): 2D-Toleranz, der Standardwert ist 0.0.
  • Daten-EigenschaftTolerance3d (Float): 3D-Toleranz, der Standardwert ist 0.0.
  • Daten-EigenschaftTol Angular (Float): G1-Toleranz, der Standardwert ist 0.01.
  • Daten-EigenschaftTol Curvature (Float): G1-Toleranz, der Standardwert ist 0.10.
  • Daten-EigenschaftMaximum Degree (Integer): maximaler Kurvenwinkel, Standardwert ist 8.
  • Daten-EigenschaftMaximum Segments (Integer): maximale Anzahl von Segmenten, standardmäßig ist 9 eingestellt.

Ansicht

Base

  • Ansicht-EigenschaftControl Points (Bool): Der Standardwert ist false; wenn true eingestellt ist, wird eine Überlagerung mit den Kontrollpunkten der Oberfläche angezeigt.

Skripten

Siehe auch: Grundlagen der Skripterstellung in FreeCAD.

Das Werkzeug Surface Füllfläche kann in Makros und über die Python-Konsole verwendet werden, indem das Objekt Surface::Filling hinzugefügt wird.

  • Die Kanten, die zur Definition der Oberfläche verwendet werden sollen, müssen als LinkSubList der Eigenschaft BoundaryEdges des Objekts zugewiesen werden.
  • Hilfskanten und -scheitelpunkte müssen als LinkSubLists den Eigenschaften UnboundEdges und Points des Objekts zugewiesen werden.
  • Alle Objekte mit Kanten müssen berechnet werden, bevor sie als Eingabe für die Eigenschaften des Füllungsobjekts verwendet werden können.
import FreeCAD as App
import Draft

doc = App.newDocument()

a = App.Vector(-20, -20, 0)
b = App.Vector(-18, 25, 0)
c = App.Vector(60, 26, 0)
d = App.Vector(33, -20, 0)

points1 = [a, App.Vector(-20, -8, 0), App.Vector(-17, 7, 0), b]
obj1 = Draft.make_bspline(points1)

points2 = [b, App.Vector(0, 25, 0), c]
obj2 = Draft.make_bspline(points2)

points3 = [c, App.Vector(37, 4, 0), d]
obj3 = Draft.make_bspline(points3)

points4 = [d, App.Vector(-2, -18, 0), a]
obj4 = Draft.make_bspline(points4)
doc.recompute()

surf = doc.addObject("Surface::Filling", "Surface")
surf.BoundaryEdges = [(obj1, "Edge1"),
                      (obj2, "Edge1"),
                      (obj3, "Edge1"),
                      (obj4, "Edge1")]
doc.recompute()

# ---------------------------------------------------------
points_spl = [App.Vector(-10, 0, 2),
              App.Vector(4, 0, 7),
              App.Vector(18, 0, -5),
              App.Vector(25, 0, 0),
              App.Vector(30, 0, 0)]
aux_edge = Draft.make_bspline(points_spl)
doc.recompute()

surf.UnboundEdges = [(aux_edge, "Edge1")]
doc.recompute()

# ---------------------------------------------------------
aux_v1 = Draft.make_line(App.Vector(-13, -12, 5),
                         App.Vector(-13, -12, -5))
aux_v2 = Draft.make_line(App.Vector(-3, 18, 5),
                         App.Vector(-3, 18, -5))
doc.recompute()

surf.Points = [(aux_v1, "Vertex2"),
               (aux_v2, "Vertex1")]
doc.recompute()


GeomFüllfläche
Surface

Diese Seite wird abgerufen von https://wiki.freecad.org/Surface_Filling

Kontaktiere uns!
Forum GitHub Mastodon Matrix IRC Gitter.im Discord Reddit Twitter Facebook LinkedIn

© Das FreeCAD-Team. Bildnachweis (von oben nach unten): ppemawm, r-frank, epileftric, regis, rider_mortagnais, bejant.

Dieses Projekt wird unterstützt von: , KiCad Services Corp. und andere Sponsoren

GitHubDiese Seite auf GitHub verbessern