![]() |
Delphi-Version: 10 Berlin
MessageDLg beantwortet sich selbst?
Hallo,
ich habe ein seltsames Verhalten, weiß nicht, warum das so ist und wie ich es beheben kann... :pale:
Delphi-Quellcode:
Ich habe den Dialog jetzt zunächst mit Cancel beantwortet, weil ich noch was nachgucken wollte.
procedure TForm1.FormCloseQuery(Sender: TObject; var CanClose: Boolean);
begin CanClose:=false; if Editor.Modified then case MessageDlg('Text im Editor wurde bearbeitet. Soll vor dem Beenden dieser Text gespeichert werden?',mtConfirmation,[mbYes,mbNo,mbCancel],0) of idYes: begin btn_saveClick(btn_save); CanClose:=true; end; idNo: CanClose:=true; idCancel: CanClose:=false; end else CanClose:=true; Wenn ich jetzt die Anwendung wieder schließen will, poppt das Dialogfenster kurz auf und wieder weg. Im Debugger sehe ich, daß die Antwort einfach ohne Zutun auf idCancel springt. Kann mir das Verhalten nicht erklären :cry: |
AW: MessageDLg beantwortet sich selbst?
Das Problem muss woanders liegen. Ich habe deinen Code eben in ein leeres Projekt kopiert und kann den Fehler so nicht nachstellen.
Nutzt du noch andere Events die dazwischenfunken könnten? |
AW: MessageDLg beantwortet sich selbst?
Muss das nicht mrYes statt idYes heißen? Natürlich die anderen beiden Resultate respektive.
Grüße Mikhal |
AW: MessageDLg beantwortet sich selbst?
Wie wird denn das Schließen der Form initiiert? Über einen anderen Button oder über das Schließen X?
Wenn über einen anderen Button, dann wird der Fehler sicherlich dort irgendwo liegen. Weil ein MessageDlg wird nicht 2x angezeigt. Hast du evtl. bei dem zweiten Button (oder irgendwo anders) schon einen ModalResult Wert vergeben der das Schließen der Form auslöst? Zudem halte ich es für keine gute Idee, einen Event-Handler eines Buttons manuell aufzurufen. Lagere deine Speichern Funktion in eine gesonderte Procedure aus und rufe diese auf. Siehe Beispiel:
Delphi-Quellcode:
procedure TForm1.FormCloseQuery(Sender: TObject; var CanClose: Boolean);
begin CanClose := False; if Editor.Modified then case MessageDlg('Text im Editor wurde bearbeitet. Soll vor dem Beenden dieser Text gespeichert werden?', mtConfirmation, [mbYes, mbNo, mbCancel], 0) of idYes: begin SaveChanges(); CanClose := True; end; idNo: CanClose := True; idCancel: CanClose := False; end else CanClose := True; end; procedure TForm1.btn_saveClick(Sender: TObject); begin SaveChanges(); end; procedure TForm1.SaveChanges(); begin Memo1.Lines.SaveToFile(); // Oder welche Komponente auch immer bzw. wie auch immer der Speichervorgang ablaufen soll end; |
AW: MessageDLg beantwortet sich selbst?
Zitat:
|
AW: MessageDLg beantwortet sich selbst?
Zitat:
|
AW: MessageDLg beantwortet sich selbst?
An btn_saveClick wird es meiner Meinung nach nicht liegen.
Irgendetwas passiert vorher schon. Daher ja die Frage, welche anderen Events du noch benutzt. |
AW: MessageDLg beantwortet sich selbst?
Zitat:
Aber nichts desto trotz. An dem Event-Handler liegt es sicherlich nicht. Das habe ich auch so nie gesagt. Ich habe eher das Stichwort ModalResult im Kopf. Aber auch hier bringt es nichts, dadrüber zu philosophieren. Der TE sollte sich da mal konkret du den Vorschlägen äußern und ggf. mehr SourceCode posten. |
AW: MessageDLg beantwortet sich selbst?
Zitat:
![]() |
AW: MessageDLg beantwortet sich selbst?
Es ist schon nicht so einfach, mit Delphi-Mitteln einen modalen Dialog zu schließen. Als ich das mal machen musste, um einen Öffnen-Dialog beim Auswählen eines bestimmten Dateityps in den Ordner zu schicken, in dem sich diese Dateien ausschließlich befinden konnten, habe ich ein Alt+F4 oder Esc per Tastendruck an den Dialog geschickt.
Ich würde auf ein anderes Programm tippen oder einen kurzzeitigen Bug im Tastaturtreiber tippen. Letztendlich enthält dieser Thread ab mikhals Post nur Offtopic. Man könnte z.B. auch noch die völlig sinnlose erste Zeile im Quelltext diskutieren. |
Alle Zeitangaben in WEZ +1. Es ist jetzt 08:40 Uhr. |
Powered by vBulletin® Copyright ©2000 - 2025, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024-2025 by Thomas Breitkreuz