![]() |
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. |
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. |
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. |
AW: Wie Dialogs.CreateMessageDialog abfangen
OK Ich glaube ich habs. (Bzw. Ich habe noch einen Ansatz...)
Muss es nur noch testen. ![]() das dürfte die Lösung sein |
AW: Wie Dialogs.CreateMessageDialog abfangen
Zitat:
|
AW: Wie Dialogs.CreateMessageDialog abfangen
Zitat:
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:
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-Quellcode:
Achtung: TService hat ein anderes TApplication, aber das TApplication der VCL läuft dennoch "heimlich" im Hintergrund.
procedure TApplication.ModalStarted;
begin Inc(FModalLevel); if (FModalLevel = 1) and Assigned(FOnModalBegin) then FOnModalBegin(Self); end; [/add] Zitat:
seit die Alle standardmäßig nicht mehr "interactive" sind. |
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. |
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. ![]() ![]() Zitat:
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. |
AW: Wie Dialogs.CreateMessageDialog abfangen
Zitat:
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