Im DelphiJedes Projekt hat mindestens ein Fenster - das Hauptfenster des Programms. Alle Fenster einer Delphi-Anwendung basieren auf TForm-Objekt.
Bilden
Objekte formen sind die Grundbausteine einer Delphi-Anwendung, die tatsächlichen Fenster, mit denen ein Benutzer interagiert, wenn er die Anwendung ausführt. Formulare verfügen über eigene Eigenschaften, Ereignisse und Methoden, mit denen Sie deren Erscheinungsbild und Verhalten steuern können. Ein Formular ist eigentlich eine Delphi-Komponente, aber im Gegensatz zu anderen Komponenten wird ein Formular nicht in der Komponentenpalette angezeigt.
Normalerweise erstellen wir ein Formularobjekt, indem wir eine neue Anwendung starten (Datei | Neue Anwendung). Dieses neu erstellte Formular ist standardmäßig das Hauptformular der Anwendung - das erste zur Laufzeit erstellte Formular.
Hinweis: Um dem Delphi-Projekt ein zusätzliches Formular hinzuzufügen, wählen Sie Datei | Neue Form.
Geburt
OnCreate
Das OnCreate-Ereignis wird ausgelöst, wenn eine TForm zum ersten Mal erstellt wird, dh nur einmal. Die für die Erstellung des Formulars verantwortliche Anweisung befindet sich in der Quelle des Projekts (wenn das Formular so eingestellt ist, dass es vom Projekt automatisch erstellt wird). Wenn ein Formular erstellt wird und seine Visible-Eigenschaft True ist, treten die folgenden Ereignisse in der angegebenen Reihenfolge auf: OnCreate, OnShow, OnActivate, OnPaint.
Sie sollten den OnCreate-Ereignishandler verwenden, um beispielsweise Initialisierungsaufgaben wie das Zuweisen von Zeichenfolgenlisten auszuführen.
Alle im OnCreate-Ereignis erstellten Objekte sollten vom OnDestroy-Ereignis freigegeben werden.
OnCreate -> OnShow -> OnActivate -> OnPaint -> OnResize -> OnPaint...
Auf Sendung
Dieses Ereignis zeigt an, dass das Formular angezeigt wird. OnShow wird aufgerufen, kurz bevor ein Formular sichtbar wird. Neben den Hauptformularen tritt dieses Ereignis auf, wenn wir die Visibles-Eigenschaft für Formulare auf True setzen oder die Methode Show oder ShowModal aufrufen.
OnActivate
Dieses Ereignis wird aufgerufen, wenn das Programm das Formular aktiviert, dh wenn das Formular den Eingabefokus erhält. Verwenden Sie dieses Ereignis, um zu ändern, welches Steuerelement tatsächlich den Fokus erhält, wenn es nicht das gewünschte ist.
OnPaint, OnResize
Ereignisse wie OnPaint und OnResize werden immer nach dem ersten Erstellen des Formulars aufgerufen, aber auch wiederholt aufgerufen. OnPaint wird ausgeführt, bevor Steuerelemente auf dem Formular gezeichnet werden (verwenden Sie es zum speziellen Malen auf dem Formular).
Leben
Die Geburt einer Form ist nicht so interessant wie Leben und Tod. Wenn Ihr Formular erstellt wurde und alle Steuerelemente auf die Verarbeitung von Ereignissen warten, wird das Programm ausgeführt, bis jemand versucht, das Formular zu schließen!
Tod
Eine ereignisgesteuerte Anwendung wird nicht mehr ausgeführt, wenn alle Formulare geschlossen sind und kein Code ausgeführt wird. Wenn beim Schließen des letzten sichtbaren Formulars noch ein verstecktes Formular vorhanden ist, wird Ihre Anwendung anscheinend angezeigt beendet (weil keine Formulare sichtbar sind), wird aber tatsächlich so lange ausgeführt, bis alle versteckten Formulare vorhanden sind geschlossen. Stellen Sie sich eine Situation vor, in der das Hauptformular frühzeitig ausgeblendet wird und alle anderen Formulare geschlossen werden.
... OnCloseQuery -> OnClose -> OnDeactivate -> OnHide -> OnDestroy
OnCloseQuery
Wenn wir versuchen, das Formular mit der Close-Methode oder auf andere Weise (Alt + F4) zu schließen, wird das Ereignis OnCloseQuery aufgerufen. Der Ereignishandler für dieses Ereignis ist daher der Ort, an dem das Schließen eines Formulars abgefangen und verhindert werden kann. Wir verwenden die OnCloseQuery, um die Benutzer zu fragen, ob sie sicher sind, dass das Formular wirklich geschlossen werden soll.
Verfahren TForm1.FormCloseQuery (Absender: TObject; var CanClose: Boolean);
Start
wennMessageDlg('Dieses Fenster wirklich schließen?', MtConfirmation, [mbOk, mbCancel], 0) = mrCancel dann CanClose: = False;
Ende;
Ein OnCloseQuery-Ereignishandler enthält eine CanClose-Variable, die bestimmt, ob ein Formular geschlossen werden darf. Der OnCloseQuery-Ereignishandler kann den Wert von CloseQuery auf False setzen (über den CanClose-Parameter), wodurch die Close-Methode abgebrochen wird.
OnClose
Wenn OnCloseQuery angibt, dass das Formular geschlossen werden soll, wird das OnClose-Ereignis aufgerufen.
Das OnClose-Ereignis gibt uns eine letzte Chance, das Schließen des Formulars zu verhindern. Der OnClose-Ereignishandler verfügt über einen Aktionsparameter mit den folgenden vier möglichen Werten:
- caNone. Das Formular darf nicht geschlossen werden. Als hätten wir CanClose in der OnCloseQuery auf False gesetzt.
- caHide. Anstatt das Formular zu schließen, verstecken Sie es.
- caFree. Das Formular wird geschlossen, sodass der zugewiesene Speicher von Delphi freigegeben wird.
- caMinimize. Das Formular wird minimiert und nicht geschlossen. Dies ist die Standardaktion für untergeordnete MDI-Formulare. Wenn ein Benutzer Windows herunterfährt, wird das Ereignis OnCloseQuery aktiviert, nicht das Ereignis OnClose. Wenn Sie verhindern möchten, dass Windows heruntergefahren wird, geben Sie Ihren Code in den OnCloseQuery-Ereignishandler ein. CanClose = False führt dies natürlich nicht aus.
OnDestroy
Nachdem die OnClose-Methode verarbeitet wurde und das Formular geschlossen werden soll, wird das OnDestroy-Ereignis aufgerufen. Verwenden Sie dieses Ereignis für Vorgänge, die denen des OnCreate-Ereignisses entgegengesetzt sind. OnDestroy wird verwendet, um die Zuordnung von Objekten zum Formular aufzuheben und den entsprechenden Speicher freizugeben.
Wenn das Hauptformular für ein Projekt geschlossen wird, wird die Anwendung beendet.