Delphi-PRAXiS

Delphi-PRAXiS (https://www.delphipraxis.net/forum.php)
-   Programmieren allgemein (https://www.delphipraxis.net/40-programmieren-allgemein/)
-   -   Delphi WM_COMMAND wird nicht ausgelöst (https://www.delphipraxis.net/200936-wm_command-wird-nicht-ausgeloest.html)

EWeiss 9. Jun 2019 19:17

WM_COMMAND wird nicht ausgelöst
 
Seltsames verhalten..

1. Ich erstelle einen Container.
2. In diesen wird ein neuer Container als Parent erstellt (Menu)
3. In diesen Container (Menu) erstelle ich Button.

WM_SETCURSOR, WM_LBUTTONUP, WM_MOUSEMOVE usw.. werden ausgelöst aber WM_COMMAND nicht.
Wie man im Shot erkennen kann wird ein Rahmen gezeichnet beim drüberfahren. (WM_MOUSEMOVE)

Woran könnte das liegen bzw.. wo müsste ich schauen warum es nicht ausgelöst wird.

Lege ich Button auf das Main Fenster gibt es diesbezüglich keine Probleme
auch wenn ich diese auf einem Tab oder Panel lege funktioniert alles.

Vielleicht hat ja jemand eine Idee.

PS:
Vergessen.. Das ganze liegt in einem Tab!

gruss

EWeiss 10. Jun 2019 08:11

AW: WM_COMMAND wird nicht ausgelöst
 
Bekomme wieder die Krise..
Einfache Sache.

Delphi-Quellcode:
ID := GetDlgCtrlID(WinHandle);
SendMessage(GetParent(WinHandle), WM_LBUTTONDOWN, MakeLong(ID, 0), LPARAM(WinHandle));
So die ID sollte sich jetzt im LoWord Part befinden.. "-31"
Werte ich das jetzt in WM_Command mit

Delphi-Quellcode:
wID := LoWord(wP);
aus
wird mir der wert 65505 zurückgegeben.. sollte aber doch -31 sein.

tsss…

gruss

samso 10. Jun 2019 08:25

AW: WM_COMMAND wird nicht ausgelöst
 
Es gilt Word(-31)=$FFE1=65505. D.h SmallInt(wP) wird -31 ergeben.

EWeiss 10. Jun 2019 08:33

AW: WM_COMMAND wird nicht ausgelöst
 
Zitat:

Zitat von samso (Beitrag 1434260)
Es gilt Word(-31)=$FFE1=65505. D.h SmallInt(wP) wird -31 ergeben.

Wie soll ich das denn händeln?
Meine Lib weis ja nicht welche ID für ein bestimmtes Control definiert wird.

Delphi-Quellcode:
const
  IDC_ABOUT     = -31;
Kommt auch an in meiner SuperClass
Nur wenn ich sie übergebe wird 65505 draus

Versteh jetzt nicht genau was du mir sagen willst.

Delphi-Quellcode:
wID := SmallInt(wP);
ergibt -31.. Das ist korrekt.

Aber! Der normale weg die Message abzufragen ist doch eigentlich LoWord.. Oder? Der niedrigste part von MakeLong.

gruss

samso 10. Jun 2019 09:56

AW: WM_COMMAND wird nicht ausgelöst
 
Wir leben in verschiedenen Welten. Deshalb kann ich nur begrenzt begreifen, was Du vorhast. In meiner Welt (32-Bit-Windows) ist der WRARAM einer WM_LBUTTONDOWN-Message ein 32-Bit-Integer. Und in LPARAM befinden sich die Koordinaten und kein Handle.

IDC_ABOUT ist eine vorzeichenbehaftete Zahl. Wenn Du IDC_ABOUT an MakeLong übergibst, dann wird IDC_ABOUT als vorzeichenlose Zahl interpretiert(WORD). Logisch, dass dann bei dem Empfänger auch eine vorzeichenlose Zahl ankommt.Es bleibt dem Empfänger überlassen die Zahl zu interpretieren.

Der Empfänger muss nun aus der vorzeichenlosen Zahl wieder eine vorzeichenbehaftete Zahl machen. Übersetzt heißt SmallInt(wP): Nimm die unteren 16 Bit und interpretiere das als vorzeichenbehaftete Zahl. Die Übersetzung von LoWord(wP) heißt aber: Nimm die unteren 16 Bit und interpretiere das als vorzeichenlose Zahl. Je nachdem ob es als vorzeichenbehaftete Zahl oder als vorzeichenlose Zahl interpretiert wird, werden Dir halt auch andere Werte angezeigt.

EWeiss 10. Jun 2019 10:04

AW: WM_COMMAND wird nicht ausgelöst
 
Zitat:

Und in LPARAM befinden sich die Koordinaten und kein Handle.
Dann leite ich einfach lP weiter so wie sie ist. ;)

Delphi-Quellcode:
SendMessage(GetParent(WinHandle), WM_LBUTTONDOWN, GetDlgCtrlID(WinHandle), 0), lP);


Wie kann ich das am besten lösen das immer LoWord gültig ist?
Ich kann ja daraufhin prüfen ob der wert ins minus geht und dann?

Danke für die Hilfe..

PS:
Raten muss man da ja nichts..

Ich schicke die Daten aus der DLL auf altbewährter weise über MakeLong.
Wenn der User eine Vorzeichen behaftete CtrlID verwendet dann muss ihm auch klar sein das er zur Auflösung den Daten typ verwenden muss den er auch definiert hat.
In dem Fall bei 16 Bit halt SmallInt..

JO.. Ich habe es selber falsch interpretiert ;)
Das sind halt die Unterschiede wenn man studierter oder Privat Schreiber ist.
Studierten fallt sowas direkt auf.

gruss

peterbelow 10. Jun 2019 11:23

AW: WM_COMMAND wird nicht ausgelöst
 
Zitat:

Zitat von EWeiss (Beitrag 1434235)
Seltsames verhalten..

1. Ich erstelle einen Container.
2. In diesen wird ein neuer Container als Parent erstellt (Menu)
3. In diesen Container (Menu) erstelle ich Button.

WM_SETCURSOR, WM_LBUTTONUP, WM_MOUSEMOVE usw.. werden ausgelöst aber WM_COMMAND nicht.
Wie man im Shot erkennen kann wird ein Rahmen gezeichnet beim drüberfahren. (WM_MOUSEMOVE)

Woran könnte das liegen bzw.. wo müsste ich schauen warum es nicht ausgelöst wird.

Lege ich Button auf das Main Fenster gibt es diesbezüglich keine Probleme
auch wenn ich diese auf einem Tab oder Panel lege funktioniert alles.

Vielleicht hat ja jemand eine Idee.

PS:
Vergessen.. Das ganze liegt in einem Tab!

gruss

WM_COMMAND wird an den Parent des Buttons geschickt, nicht an den Button.

EWeiss 10. Jun 2019 11:31

AW: WM_COMMAND wird nicht ausgelöst
 
Zitat:

WM_COMMAND wird an den Parent des Buttons geschickt, nicht an den Button.
Sorry wo steht das ich die Message an den Button schicke?
Ist klar sie muss zum Container geschickt werden auf dem die Button sitzen. ;)

Habe das Problem mittlerweile gelöst und funktioniert wie es soll.
Danke.

WM_COMMAND muss ich nicht schicken wird automatisch ausgelöst wenn WM_LBUTTONDOWN oder UP erfolgreich waren.
Und beide Messagen oder einer davon behandelt werden.

gruss


Alle Zeitangaben in WEZ +1. Es ist jetzt 02:13 Uhr.

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