Behandeln WM_CHAR, WM_KEYDOWN auch das drücken der Enter Taste?
-
Hast du dir den Link angesehen?
-
WM_KEYDOWN und WM_CHAR funktionieren nicht und ich bin ziemlich sicher das das was mit dem IsDialogMessage für Tabstops zu tun hat.
@link was soll man sich da groß ansehen, du hast doch meinen Code gesehen oder? ich sehe zu dem auf www.winapi.net kaum einen unterschied (codemäßig).
Ich habe jetzt mal if(!IsDialogMessage) weggelassen und es funzt, das Problem ist wie kriege ich das hin das Tabstops und das Subclassing funktionieren
-
Srry link habe deinen link zu spät gesehen, mit dem Code funktioniert es zwar auch mit IsDialogMessage allerdings geht jetzt Tabstop net mehr

-
oh das stimmt. dann muss man den code in WM_GETDLGCODE ein bisschen verfeinern.

-
ähm link ich halte die deutsche übersetzung nicht wirklich für gelungen ... ich verstehe nämlich so gut wie gar nichts ... kannst du mir mal in richtigem Deutsch sagen was ich jetzt noch ändern muss?
-
ne, da geb ich dir doch lieber den link zum englischen text.
-
also ich verstehe das immer noch nicht richtig. Ich bräuchte jetzt wirklich mal ein Beispiel wie ich das genau machen soll. Ich wann muss ich was/wo/wieoft zurückgeben?

-
Peek at the lParam. If it is a press of the Return key, then return DLGC_WANTMESSAGE so the message will not be handled by the dialog manager.
-
Ich glaube ihr solltet meine Funktion einfach anpassen, denn ich verstehe immer noch nicht was ihr genau von mir wollt:
LRESULT CALLBACK WndEditProc (HWND hwnd, UINT message, WPARAM wParam, LPARAM lParam) { switch(message) { case WM_GETDLGCODE: return DLGC_WANTALLKEYS; case WM_KEYDOWN: if(wParam == VK_RETURN) { SendMessage((HWND) GetWindowLong(hwnd, GWL_HWNDPARENT), WM_COMMAND, MAKEWPARAM(BU_WEITER, 0),0); return DLGC_WANTALLKEYS; } //Kein break !!! default: return CallWindowProc((WNDPROC)oldeditproc, hwnd, message, wParam, lParam);; }
-
nice try
-
Sag mal ist BU_WEITER ein Button? Dann mach es doch wie "button" es vorgeschlagen hat.
-
was ist mit dem style ES_WANTRETURN ???
ES_WANTRETURN Specifies that a carriage return be inserted when the user presses the ENTER key while entering text into a multiple-line edit control in a dialog box. Without this style, pressing the ENTER key has the same effect as pressing the dialog box’s default pushbutton. This style has no effect on a single-line edit control.
-
This style has no effect on a single-line edit control
-
case ( WM_CHAR ): switch ( wParam ) { case ( '\r' ): // SendMessage ( ...... ); return ( 0 ) } break;
-
????
-
@!!!! hier gehts doch um
Behandeln WM_CHAR, WM_KEYDOWN auch das drücken der Enter Taste?
(oderrhabichschonzuvielbierimkopp
)na so gehts halt !
-
So (ähnlich) gehts nur wenn man nicht IsDialogMessage benutzt.
-
Also nochmal für alle zum mitschreiben, das Codeschnipsel das ich zuletzt gepostet habe funktioniert auch mit IsDialogMessage(). Allerdings funktioniert dann der Tabstop nicht mehr um zwischen den Feldern zu wechseln.
-
Jo, du hast ja auch die WM_GETDLGCODE Behandlung drin. Da darfst du eben nur DLGC_WANTMESSAGE zurückgeben wenn die Enter-Taste gedrückt wurde. Wenns nicht Enter war, rufst du mit CallWindowProc die original Edit-Proc auf.
-
Also mein Code sieht jetzt so aus:
LRESULT CALLBACK WndEditProc (HWND hwnd, UINT message, WPARAM wParam, LPARAM lParam) { switch(message) { case WM_GETDLGCODE: return DLGC_WANTMESSAGE; case WM_KEYDOWN: if(wParam == VK_RETURN) { SendMessage((HWND) GetWindowLong(hwnd, GWL_HWNDPARENT), WM_COMMAND, MAKEWPARAM(BU_WEITER, 0),0); return DLGC_WANTMESSAGE; } //Kein break !!! default: return CallWindowProc((WNDPROC)oldeditproc, hwnd, message, wParam, lParam);; } }Es funktioniert allerdings immer noch nicht!