PySide Beginner Examples/de

Einführung
Der Zweck dieser Seite ist es, Beispiele auf Anfängerniveau für die PySide GUI Verwalter (es gibt begleitende Seiten Zwischen PySide Beispiele und Fortgeschrittene PySide Beispiele).

Neulinge in der GUI Programmierung könnten über das Wort "Widget" stolpern. Seine Bedeutung außerhalb der Computerwelt wird gewöhnlich wie folgt angegeben

"'eine kleine Spielerei oder mechanisches Gerät, insbesondere eines, dessen Name unbekannt oder unspezifiziert ist'"

Für GUI Arbeiten wie PySide wird der Begriff "Widget" am häufigsten verwendet, um die sichtbaren Elemente der GUI zu bezeichnen - Fenster, Dialoge und Ein-/Ausgabefunktionen. Alle sichtbaren Elemente von PySide werden Widgets genannt, und für diejenigen, die daran interessiert sind, sie stammen alle von einer gemeinsamen Elternklasse ab, nämlich QWidget. Zusätzlich zu den sichtbaren Elementen bietet PySide auch Widgets für Netzwerk-, XML-, Multimedia- und Datenbankintegration.

Ein Widget, das nicht in ein übergeordnetes Widget eingebettet ist, wird als Fenster bezeichnet, und normalerweise haben Fenster einen Rahmen und eine Titelleiste. Die gebräuchlichsten Fenstertypen sind das "Hauptfenster" (aus der Klasse QMainWindow) und die verschiedenen Unterklassen des Dialogs (aus der Klasse QDialog). Ein großer Unterschied besteht darin, dass QDialog modal ist (d.h. der Benutzer kann nichts außerhalb des Dialogfensters tun, während es geöffnet ist) und das QMainWindow nicht-modal ist, was es dem Benutzer erlaubt, parallel mit anderen Fenstern zu interagieren.

Dieser Führer ist eine Abkürzungsliste, um ein PySide Programm schnell unter FreeCAD zum Laufen zu bringen. Es ist nicht dazu gedacht, Python oder PySide zu lehren. Einige Websites, die dies tun, sind es:
 * PySide Tutorium auf zetcode.com
 * PySide/PyQt Ttutorium auf PythonCentral.io
 * PySide 1.0.7 Referenz auf Srinikom.github.io (beachte, dass dies eine Referenz und kein Tutorium ist)



Import Anweisung
PySide wird standardmäßig nicht mit Python geladen, es muss vor der Verwendung angefordert werden. Der folgende Befehl:

bewirkt, dass die 2 Teile von PySide geladen werden - QtGui enthält Klassen zur Verwaltung der grafischen Benutzeroberfläche, während QtCore Klassen enthält, die sich nicht direkt auf die Verwaltung der GUI beziehen (z.B. Timer und Geometrie). Obwohl es möglich ist, nur das zu importieren, was benötigt wird, werden im Allgemeinen beide benötigt und beide importiert.

Die Importangaben werden in den folgenden Schnipseln nicht wiederholt; es wird davon ausgegangen, dass dies jeweils am Anfang geschieht.



Einfachstes Beispiel
Die einfachste Interaktion mit PySide besteht darin, dem Benutzer eine Nachricht zu präsentieren, die er nur akzeptieren kann:





Ja oder Nein Abfrage
Die nächst einfachste Interaktion ist die Frage nach einer Ja oder Nein Antwort:

QtGui.QMessageBox.No, QtGui.QMessageBox.No) if reply == QtGui.QMessageBox.Yes:       # this is where the code relevant to a 'Yes' answer goes         pass if reply == QtGui.QMessageBox.No:         # this is where the code relevant to a 'No' answer goes         pass





Textabfrage eingeben
Der nächste Codeschnipsel fragt den Benutzer nach einem Stück Text - beachte, dass dies wirklich jede Taste auf der Tastatur sein kann:



Denke daran, dass selbst wenn der Benutzer nur Ziffern eingibt, z.B. "1234", es sich um Zeichenketten handelt, die mit einem der folgenden Verfahren in eine Zahlendarstellung umgewandelt werden müssen:



Mehr als 2 Schaltflächen
Das letzte Beispiel für das Anfängerniveau zeigt, wie man einen Dialog mit einer beliebigen Anzahl von Schaltflächen aufbaut. Dieses Beispiel ist programmtechnisch zu komplex, um von einer einzigen Python-Anweisung aus aufgerufen zu werden, daher sollte es in gewisser Weise auf der nächsten Seite, die PySide weiterführende Beispiele enthält, aufgeführt werden. Andererseits ist dies oft alles, was benötigt wird, ohne sich in komplexe GUI-Definitionen zu vertiefen, so dass der Code am Ende der Seite und nicht am Anfang der folgenden weiterführenden PySide-Seite platziert wird.

Jedes zu testende Codestück würde sich in einer Funktion mit dem Namen 'routine1', 'routine2' usw. befinden. Es können so viele Schaltflächen verwendet werden, wie auf den Bildschirm passen. Folge den Mustern im Codebeispiel und füge bei Bedarf zusätzliche Knöpfe hinzu - das Dialogfeld wird seine Breite entsprechend der Bildschirmbreite einstellen.



Es gibt eine Codezeile:

was dazu führt, dass die Schaltflächen in einer horizontalen Linie liegen. Um sie in eine vertikale Linie zu setzen, ändere die zu lesende Zeile des Codes: