Delphi-PRAXiS
Seite 1 von 2  1 2      

Delphi-PRAXiS (https://www.delphipraxis.net/forum.php)
-   Win32/Win64 API (native code) (https://www.delphipraxis.net/17-win32-win64-api-native-code/)
-   -   Delphi Abgefangene Message auswerten und evtl. doch noch senden (https://www.delphipraxis.net/60746-abgefangene-message-auswerten-und-evtl-doch-noch-senden.html)

Matze 11. Jan 2006 23:42


Abgefangene Message auswerten und evtl. doch noch senden
 
Hallo,

Wenn ich eine Nachricht abfange, und zwar so:

Delphi-Quellcode:
procedure TFormMain.WMMENUCHAR(var Msg: TMessage);
begin
  inherited;

  if msg.WParamLo = ord('a') then // Catch Alt + a
  begin
    Msg.ResultHi := MNC_CLOSE;
  end else
  begin
    // Send Shortcut
    Msg.Result := SendMessage(MainMenu1.Handle, Msg.Msg, Msg.Wparam, Msg.LParam);
  end;
end;
dann soll, wenn nicht Alt + A gedrückt ist, der Shortcut wie gewohnt ans MainMenu weitergeleitet werden. Egal, ob ich das Handle der Form oder des MainMenus angebe, die Message wird nicht gesendet. Wo liegt mein Denkfehler?

marabu 12. Jan 2006 08:56

Re: Abgefangene Message auswerten und evtl. doch noch senden
 
Hallo Matthias,

die Nachricht WM_MENUCHAR wird an deine Form geschickt, wenn der menu loop aktiv ist und eine Taste gedrückt wurde, die keinem accelerator char entspricht. Nehmen wir an, das wäre ein 'b'. Schickst du die Nachricht an das auslösende menu, dann kannst du es genausogut vernichten - WM_MENUCHAR wird vom menu nicht verarbeitet. Schickst du es an die Form, dann würde dein message handler versuchen in eine Endlosschleife einzutreten - Windows verhindert das scheinbar ganz gut.

Grüße vom marabu

Matze 12. Jan 2006 20:04

Re: Abgefangene Message auswerten und evtl. doch noch senden
 
Hallo marabu,

und was heißt das nun genau?

marabu 12. Jan 2006 21:02

Re: Abgefangene Message auswerten und evtl. doch noch senden
 
Okay, das war eine sehr lange und ausführliche Erklärung.
Jetzt also die Folgerung für dein konkretes Beispiel.
In zwei Worten: So nicht.

marabu

Matze 12. Jan 2006 21:36

Re: Abgefangene Message auswerten und evtl. doch noch senden
 
Moin

Zitat:

Zitat von marabu
In zwei Worten: So nicht.

Äh, dass es genau so nicht geht, weiß ich schon. :zwinker:

Geht es in der Art dann komplett nicht? Wie löst man das Problem dann?



Nachtrag: Mit PostMessage würde es klappen:

Delphi-Quellcode:
PostMessage(MainMenu1.Handle, Msg.Msg, Msg.WParam, Msg.LParam);
Nur ob das die Lösung ist, weiß ich auch nicht.

marabu 13. Jan 2006 09:28

Re: Abgefangene Message auswerten und evtl. doch noch senden
 
Hallo Matthias,

eigentlich bin ich davon ausgegangen, dass die Wiederbelebung einer WM_MENUCHAR Nachricht unsinnig ist. Genau das habe ich versucht in meinem ersten Beitrag zu erklären. Ob PostMessage() oder SendMessage() - die Nachricht wird von MainMenu doch gar nicht verarbeitet - oder besser: sie hat keine Wirkung.

Ein Menü fragt mit WM_MENUCHAR beim assoziierten Fenster nach, wie es sich verhalten soll, wenn der Benutzer eine Zugriffstaste gedrückt hat, die im Menü gar nicht verwendet wird. Das ist regelmäßig dann der Fall, wenn rein graphische Menüs eingesetzt werden, aber auch eine Fehlbedienung kann so abgefangen werden.

Wenn du also die Nachricht duplizierst und mit PostMessage() in die message queue des Menüs stellst, nun - ich habe das jetzt nicht ausprobiert, aber ich erwarte, dass die Nachricht ignoriert wird und die Fehlbedienung mit einem Ton quittiert wird.

Was hast du denn da vor?

Freundliche Grüße vom marabu

Matze 13. Jan 2006 11:22

Re: Abgefangene Message auswerten und evtl. doch noch senden
 
Hallo marabu

Zitat:

Zitat von marabu
Was hast du denn da vor?

Ich habe in meinem Programm den Shortcut Alt + A verwendet. Da kein Menüitem mit A angesprochen werden kann, ertönt dieser nervende Piepton, den ich durch das Abfangen von MENUCHAR unterdrücken lasse. Doch fange ich dadurch ja alle Shortcuts ab, die an das MainMenu gesendet werden. Daher muss ich im Falle, dass ein Shortcut nicht Alt + A ist, diesen wieder an das Menü weiterleiten. Ich muss also eine abgefangene Message senden, sobald es sich nicht um Alt + A handelt. Mit SendMessage funktioniert dies nicht, mit PostMessage hingegen schon, doch frag mich nicht wieso.

marabu 13. Jan 2006 20:54

Re: Abgefangene Message auswerten und evtl. doch noch senden
 
Ich würde das von dir beschriebene Problem gerne in einem Testprojekt nachvollziehen. Kannst du mir eine kurze Beschreibung geben, wie ich dazu vorgehen muss? Welche Komponenten muss ich verwenden? Wo muss ich welchen shortcut zuordnen? Alles was relevant ist...

marabu

Matze 13. Jan 2006 21:55

Re: Abgefangene Message auswerten und evtl. doch noch senden
 
Liste der Anhänge anzeigen (Anzahl: 1)
Hallo marabu :hi:

Zitat:

Zitat von marabu
Ich würde das von dir beschriebene Problem gerne in einem Testprojekt nachvollziehen. Kannst du mir eine kurze Beschreibung geben, wie ich dazu vorgehen muss? Welche Komponenten muss ich verwenden? Wo muss ich welchen shortcut zuordnen? Alles was relevant ist...

Ich habe dir eine kleine Testanwendung erstellt. Labels beschreiben ungefähr, was ich meine. Ich hoffe, es ist einigermaßen verständlich.

Nachtrag: Huch, hier geht es sogar, ohne das PostMessage. Sehr komisch.

marabu 14. Jan 2006 11:48

Re: Abgefangene Message auswerten und evtl. doch noch senden
 
Liste der Anhänge anzeigen (Anzahl: 1)
Hallo Matthias,

wenn ich alles richtig verstanden habe, dann benötigst du von Menüeinträgen unabhängige shortcuts. Dein Ansatz war das Abfangen in FormKeyDown(). Da mit der Alt-Taste automatisch das Hauptmenü aktiviert wird, fängst du die wegen des dort unbekannten shortcuts erzeugte Nachricht WM_MENUCHAR in einem eigenen message handler ab und veranlasst das Hauptmenü sich ohne akustische Warnung zu deaktivieren. Noch immer ist mir nicht klar, was du mit der Reaktivierung der abgefangenen Nachricht erreichen willst. Nachvollziehbar wäre bei deinem Ansatz das hier:

Delphi-Quellcode:
procedure TForm1.WMMENUCHAR(var Msg: TMessage);
begin
  if Msg.WParamLo = Ord('w')
    then Msg.ResultHi := MNC_CLOSE
    else Msg.ResultHi := MNC_IGNORE;
end;
Aber diesen ganzen Aufwand musst du gar nicht treiben. Im Anhang findest du eine leicht modifizierte Fassung deines Testprojektes. Ich habe deinen message handler für WM_MENUCHAR und den event handler für FormKeyDown() entfernt und statt dessen eine ActionList aufgenommen. Nun kannst du zur Entwurfs- oder auch zur Laufzeit Actions hinzufügen, denen du einen shortcut zuordnest. Das scheint mir unter VCL Bedingungen die beste Methode zu sein um application shortcuts zu definieren.

Freundliche Grüße vom marabu


Alle Zeitangaben in WEZ +1. Es ist jetzt 12:17 Uhr.
Seite 1 von 2  1 2      

Powered by vBulletin® Copyright ©2000 - 2024, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024 by Thomas Breitkreuz