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!

Pivy
Schnittstellen erstellen
Index

Einleitung

Die PySide-Bibliothek ist ein Python-Wrapper für den plattformübergreifenden GUI-Werkzeugsatz Qt. FreeCAD setzt Qt als seinen Hauptwerkzeugsatz für die Benutzerschnittstelle (GUI) ein. Qt selbst ist mehr als nur ein GUI-Werkzeugsatz, es ist eine Sammlung von C++ Bibliotheken für viele unterschiedliche Aufgaben; man kann beispielsweise mit Komponenten der Bibliothek netzwerken, und durch Pyside kann auf alles mit Python zugegriffen werden. Jede grafische Oberfläche, die in C++ erstellt werden kann, kann auch in Python erstellt und modifiziert werden. Ein Vorteil der Verwendung von Python ist, dass Qt-Oberflächen entwickelt und live getestet werden können, da wir die Quelldateien nicht kompilieren müssen.

Die empfohlene Methode zum Importieren von PySide (jeder Version) in FreeCAD ist:

from PySide import QtCore, QtGui, QtWidgets

Qt & PySide-Versionen

  • Version 1.0 von Qt wurde Mitte der 1990er Jahre veröffentlicht.
  • Version 4.0 von Qt wurde 2005 veröffentlicht und die 4.x-Serie wurde 2015 offiziell eingestellt.
    • Der Python-Wrapper für Qt4.x trägt den Namen PySide.
  • Version 5.0 von Qt wurde 2012 veröffentlicht, und die 5.x-Serie wurde 2020 offiziell eingestellt.
    • Der Python-Wrapper für Qt5.x trägt den Namen PySide2.
  • Version 6.0 von Qt wurde 2020 veröffentlicht und ist die aktuelle Versionsserie.
    • Der Python-Wrapper für Qt6.x trägt den Namen PySide6.

Mit PySide erstellte Beispiele. Links: ein einfacher Dialog. Rechts: ein komplexerer Dialog mit Diagrammen.

Anfang

FreeCAD und PySide

Die ursprüngliche Idee hinter FreeCAD war es, Cas.CADE (geometrischer Kernel), Qt (GUI-Toolkit) und Python zusammenzuführen, um ein freies parametrisches 3D-CAD-Programm mit integrierter Skript-Engine zu schaffen. Dies war in den frühen 2000er Jahren, also vor der Existenz von PySide, sodass in den ersten zehn Jahren des Bestehens von FreeCAD ein anderer Wrapper – PyQt – verwendet wurde. PySide wurde entwickelt, um Lizenzprobleme mit PyQt zu lösen, und 2013 erfolgte die Umstellung von FreeCAD auf PySide (commit 1dc122dc9a).

Wenn man wissen möchte, welche Qt-Version die Installation verwendet, findet man im Dialog Über FreeCAD eine Liste der Versionen, in denen Qt enthalten ist.

Für weitere Informationen siehe:

  • Wikipedia:PySide
  • Unterschiede zwischen PySide und PyQt (engl.)

Wird FreeCAD installiert, erhält man sowohl Qt als auch ein passendes PySide als Teil des Pakets. Wenn man selbst kompiliert, muss man überprüfen, ob passende Versionen diese beiden Bibliotheken installiert sind, damit FreeCAD korrekt läuft. Natürlich wird PySide nur funktionieren, wenn Qt vorhanden ist.

Anfang

Kompatibilität mit verschieden Versionen

Der Hauptunterschied zwischen den Bibliotheken PySide und den nachfolgenden PySide2 und PySide6 besteht im Namensraum. PySide (Qt4) hat die Hauptnamensräume QtGui und QtCore, während PySide2 (Qt5) und PySide6 (Qt6) den zusätzlichen Namensraum QtWidgets eingeführt haben, in dem sich nun alle Widgets befinden, die zuvor im QtGui-Namensraum lagen.

Der Ansatz von FreeCAD zur Handhabung der verschiedenen Versionen von Qt/PySide besteht darin, sie alle als PySide zu bezeichnen, was eigentlich als PySideX verstanden werden sollte. Es spielt keine Rolle, welche Qt/PySide-Version installiert ist, sie werden alle mit PySide importiert.

Ein Shim verwaltet die Unterschiede zwischen den Versionen. Dieser PySide Shim befindet sich im Verzeichnis Ext/ einer für Qt5/Qt6 kompilierten FreeCAD-Installation.

/usr/share/freecad/Ext/PySide

Dieses Modul importiert einfach die erforderlichen Klassen aus PySide2/6, bringt sie aber im Namensraum von PySide unter. Diese Herangehensweisen wurde ausgewählt, da sie, von Qt4 aus betrachtet, eine Rückwärtskompatibilität ermöglicht.

PySide2.QtCore -> PySide.QtCore
PySide2.QtGui -> PySide.QtGui
PySide2.QtWidgets -> PySide.QtWidgets
PySide2.QtSvg -> PySide.QtSvg
PySide2.QtUiTools -> PySide.QtUiTools

Aus diesem Grund sind die Klassen der PySide2.QtWidgets auch im Namensraum PySide.QtGui untergebracht.

PySide2.QtWidgets.QCheckBox -> PySide.QtGui.QCheckBox

Aber der derzeit empfohlene Weg ist die Verwendung der moderneren Namespacing-Variante.

from PySide import QtCore, QtGui, QtWidgets

my_check_box = QtWidgets.QCheckBox()

Anfang

Beispiele für die Verwendung von PySide

  • PySide Anfänger Beispiele, Hallo Welt, Ankündigungen, Text eingeben, Nummer eingeben.
  • PySide Beispiele für Fortgeschrittene, Fenstergröße, Widgets ausblenden, Aufklappmenüs, Mausposition, Mausereignisse.
  • PySide Zwischenbeispiele, viele Widgets.

Die Beispiele von PySide sind in 3 Teile unterteilt, die sich nach dem Grad der Exposition gegenüber PySide, Python und den FreeCAD Interna unterscheiden. Die erste Seite gibt einen Überblick über PySide; die zweite und dritte Seite sind meist Code Beispiele auf verschiedenen Niveaus.

Es wird erwartet, dass diese Beispiele für den Anfang nützlich sind, und danach kann der Benutzer andere Ressourcen online oder die offizielle Dokumentation hinzuziehen.

Anfang

Dokumentation

Es gibt einige Unterschiede in der Behandlung von Widgets zwischen den unterschiedlichen Versionen. Programmierer sollten sich dieser Inkompatibilitäten bewusst sein und die offizielle Dokumentation konsultieren, wenn etwas auf einer bestimmten Plattform nicht wie erwartet funktioniert. Wenn auch selten, kann es manchmal erforderlich sein, versionsabhängige Aufrufe über If-Abfragen zu erstellen.

Die PySide-Dokumentation bezieht sich auf die Klassen im Python-Stil; da Qt jedoch ursprünglich eine C++ Bibliothek ist, sollten dieselben Informationen auch in der entsprechenden C++ Referenz vorhanden sein.

  • Qt-Module bereitgestellt von PySide2/PySide6 (Qt5/Qt6).
  • Alle Qt-Klassen nach Modulen in Qt5 für C++.
  • Qt-Module bereitgestellt von PySide (Qt4).

Anfang

Pivy
Schnittstellen erstellen
Index

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

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