Delphi-PRAXiS

Delphi-PRAXiS (https://www.delphipraxis.net/forum.php)
-   GUI-Design mit VCL / FireMonkey / Common Controls (https://www.delphipraxis.net/18-gui-design-mit-vcl-firemonkey-common-controls/)
-   -   Delphi Wie Dialogs.CreateMessageDialog abfangen (https://www.delphipraxis.net/211239-wie-dialogs-createmessagedialog-abfangen.html)

QuickAndDirty 19. Aug 2022 15:06

Wie Dialogs.CreateMessageDialog abfangen
 
Hallo
Ich habe versucht Showmessage mit einen Hook auf WM_INITDIALOG abzufangen...
leider wird diese Message dafür nie verwendet, Stattdessen wird (in D2007) in der Unit Dialogs eine
Function CreateMessageDialog aufgerufen, in der das Formular "komplett zufuß" aufgebaut wird .
Die Einzige Message die man da mit bekommt könnte WM_GETTEXT sein....

Ich möchte Dialogs nicht bearbeiten.

Kann ich die Adresse von CreateMessageDialog nach Programmstart auf eine eigene Function legen?
Würde sich das auch auf Dialoge auswirken die von anderen Komponentensammlungen benutzt werden?

Ich will verhindern, dass in einem Dienst Modale Fenster aufgehen, die auf Eingaben warten.

Maliko 19. Aug 2022 15:16

AW: Wie Dialogs.CreateMessageDialog abfangen
 
Uhh das würde mich auch brennend interessieren. Das selbe Problem haben wir nämlich auch. Wir haben das bisher immer so umgangen, dass der Dienst ein Silent-Flag setzt und dieses Flag sorgt dafür dass der MessageDialog gar nicht erst getriggert wird, sondern die Fehlermeldung stattdessen in ein Logfile geschrieben wird. Das ist natürlich nur möglich wenn man bei der Entwicklungs selbst an so etwas denkt.

Sollte es also tatsächlich ne Möglichkeit geben den tatsächlich abzufangen wäre ich daran ebenfalls sehr interessiert.

QuickAndDirty 19. Aug 2022 15:23

AW: Wie Dialogs.CreateMessageDialog abfangen
 
in Delphi XE wäre es soo einfach.
Man könnte eine angepasste Dialogs.pas in den Projekt Ordner kopieren...und dann würde Delphi die nehmen...
Aber für D2007 weiß ich keine Lösung.

QuickAndDirty 19. Aug 2022 15:46

AW: Wie Dialogs.CreateMessageDialog abfangen
 
OK Ich glaube ich habs. (Bzw. Ich habe noch einen Ansatz...)
Muss es nur noch testen.
https://stackoverflow.com/questions/...lared-function

das dürfte die Lösung sein

Uwe Raabe 19. Aug 2022 15:47

AW: Wie Dialogs.CreateMessageDialog abfangen
 
Zitat:

Zitat von QuickAndDirty (Beitrag 1510336)
in Delphi XE wäre es soo einfach.
Man könnte eine angepasste Dialogs.pas in den Projekt Ordner kopieren...und dann würde Delphi die nehmen...
Aber für D2007 weiß ich keine Lösung.

Wieso sollte das bei D2007 anders sein?

himitsu 19. Aug 2022 16:16

AW: Wie Dialogs.CreateMessageDialog abfangen
 
Zitat:

WM_INITDIALOG
Es kommt drauf an, Dialoge können im Delphi über die VCL (TForm) oder die Dialog-WinAPI ablaufen (TaskDialog usw.).

CreateMessageDialog ist natürlich direkt nur VCL.
Beim normalen ShowMessage und Co. kommt es grauf an, ob das Windows aktuell genug ist und ob die neue CommonControls-API (ab v6) vorhanden+aktiv ist.
Nicht dass jemand auf die saublöde Idee kam und denkt der alte Win9x/2K-Look sei zu cool.


Und Delphi-DialogeFenster (CreateWindow) mit ShowModal sind nunmal keine "Dialoge" (mit WM_INITDIALOG usw.).


Zitat:

Stattdessen wird (in D2007) in der Unit Dialogs eine
Function CreateMessageDialog aufgerufen, in der das Formular "komplett zufuß" aufgebaut wird .
Normal sollte das nicht passieren, in Delphis der letzten dutzend Jahre ... außer du baust irgendwo bissl Mist,
denn vor CreateMessageDialog kommt irgendwo eine entsprechende Prüfung, ob der "Fallback" für eine veraltete API nötig ist.

Aktuell in Delphi 11 (davor jeweils ein bissl anders)
Delphi-Quellcode:
  if TOSVersion.Check(6) and UseLatestCommonDialogs and
     IsNewCommonCtrl and not ((shDialogs in TStyleManager.SystemHooks) and not StyleServices(Screen.ActiveCustomForm).IsSystemStyle) then


@QuickAndDirty: schau mal in Form.ShowModal rein.
Ich bin mir fast sicher, dass dort irgendwo ein Event bezüglich "Modal" ausgelöst wird und in System oder SysUtils gäbe es etwas, wo du dich dafür registrieren kannst.

Und eventuell noch ein schmutziges
Delphi-Quellcode:
UseLatestCommonDialogs:=False;
.

[add]
Nee, in Forms war es (Delphi-Referenz durchsuchenTApplicationEvents)
Delphi-Quellcode:
procedure TApplication.ModalStarted;
begin
  Inc(FModalLevel);
  if (FModalLevel = 1) and Assigned(FOnModalBegin) then
    FOnModalBegin(Self);
end;
Achtung: TService hat ein anderes TApplication, aber das TApplication der VCL läuft dennoch "heimlich" im Hintergrund.
[/add]



Zitat:

Ich will verhindern, dass in einem Dienst Modale Fenster aufgehen, die auf Eingaben warten.
In einem Dienst darf es überhaupt keine Dialoge/Fenster geben, egal ob modal oder nicht,
seit die Alle standardmäßig nicht mehr "interactive" sind.

QuickAndDirty 19. Aug 2022 17:03

AW: Wie Dialogs.CreateMessageDialog abfangen
 
Ja die Entwicklungsumgebung ist WIN2000 und die IDE D2007 dann läuft alles über "CreateMessageDialog"
andernfalls wird alles über "TaskDialogIndirect" aus der CommCtrl unit gemacht.
So ein misst.

Also sind zwei Lösungen notwendig?
UseLatestCommonDialogs ist in D2007 standardmäßig auf true.
Wenn ich es auf FALSE setze dann würden immer die "zufuss"-Dialoge genutzt werden oder?

Im TApplicationEvents.OnModalBegin
bekomme ich leider auch nicht raus welcher Dialog da jetzt offen ist und schließen kann ich ja dann auch nicht. Soweit ich weiß.

Ich will die Dialoge verhindern, weil der Dienst halt in einem Dialog hängen kann.

himitsu 19. Aug 2022 19:27

AW: Wie Dialogs.CreateMessageDialog abfangen
 
Indirekt doch.
VCL-Dialoge stehen in Screen.Forms und dort sollte es der Neuste sein, bzw. soooo viel sollte dort auch nicht existieren.

Aber da das Zeug eh aus dem Service raus gehört, kannst dort schön eine Exception werfen und den Dialog abbrechen.
Der Code wo es dann knallt ... der gehört letztendlich repariert. :angle2:



Man könnte vielleicht auch noch in TApplicationEvents.OnMessage auf sowas wie WM_SHOWWINDOW und vielleicht WM_CREATE reagieren.
Delphi-Referenz durchsuchenFindControl Delphi-Referenz durchsuchenIsVCLControl


Zitat:

Wenn ich es auf FALSE setze dann würden immer die "zufuss"-Dialoge genutzt werden oder?
Jupp.

Die ganz neuen TaskDialog-APIs bieten nun auch eine Übersetzung,
aber das CreateMessageDialog und Co. haben einen Vorteil ... es sind da drauf z.B. VCL-Buttons, bei denen man schön die Captions ändern kann, ohne sich nicht komplett selbst um den Dialog kümmern zu müssen.
bzw. es lassen sich leicht weitere VCL-Controls draufpappen.



Bei uns hab ich nun die letzten 3 Windows 7 entsorgt. (das eine Windows 7 Embedded ... da ist das Display kaputt und es hat sich leider selbst disqualifiziert :cry: )
PS: Selbst die ersten Versionen von Windows 10 sind bereits "offiziell" tot.

QuickAndDirty 19. Aug 2022 22:39

AW: Wie Dialogs.CreateMessageDialog abfangen
 
Zitat:

Zitat von himitsu (Beitrag 1510358)
Indirekt doch.
VCL-Dialoge stehen in Screen.Forms und dort sollte es der Neuste sein, bzw. soooo viel sollte dort auch nicht existieren.

Aber da das Zeug eh aus dem Service raus gehört, kannst dort schön eine Exception werfen und den Dialog abbrechen.
Der Code wo es dann knallt ... der gehört letztendlich repariert. :angle2:



Man könnte vielleicht auch noch in TApplicationEvents.OnMessage auf sowas wie WM_SHOWWINDOW und vielleicht WM_CREATE reagieren.
Delphi-Referenz durchsuchenFindControl Delphi-Referenz durchsuchenIsVCLControl


Zitat:

Wenn ich es auf FALSE setze dann würden immer die "zufuss"-Dialoge genutzt werden oder?
Jupp.

Die ganz neuen TaskDialog-APIs bieten nun auch eine Übersetzung,
aber das CreateMessageDialog und Co. haben einen Vorteil ... es sind da drauf z.B. VCL-Buttons, bei denen man schön die Captions ändern kann, ohne sich nicht komplett selbst um den Dialog kümmern zu müssen.
bzw. es lassen sich leicht weitere VCL-Controls draufpappen.



Bei uns hab ich nun die letzten 3 Windows 7 entsorgt. (das eine Windows 7 Embedded ... da ist das Display kaputt und es hat sich leider selbst disqualifiziert :cry: )
PS: Selbst die ersten Versionen von Windows 10 sind bereits "offiziell" tot.

Wir beide wissen, dass technical debt sucked und man sich davon befreien sollte.
Dieser Befreiungschlag, konvertierug zu unicode und Delphi XE 10.3, ist auch geplant, sobald ich mit einem anderen Projekt an dem ich sitze und das immer größer wird , fertig bin.

Da es ja nur um das verhindern der Dialoge für den Dienst, der auch als Desktop tray Anwendung laufen kann, geht es ja erstmal wenn ich die Messageboxen verhindere.


Alle Zeitangaben in WEZ +1. Es ist jetzt 13:58 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