![]() |
Eigene Komponente TCustomControl den Focus erhalten
Hi,
ich habe mir eine Komponente erstellt, die auf TCustomPanel basiert. Wie kann ich es anstellen, dass die Komponente per MouseDown auch den Focus erhält. Mit Tab komme ich hin und kann KeyPress auswerten. Aber wenn ein anderes Control aktiv ist und ich meines anklicke, erhält es nicht automaisch den Focus. |
AW: Eigene Komponente TCustomControl den Focus erhalten
Vielleicht klingt das naiv (kenne mich mit Komponentenentwicklung kaum aus), aber: was spricht dagegen, im MouseDown einfach SetFocus() aufzurufen?
|
AW: Eigene Komponente TCustomControl den Focus erhalten
Zitat:
|
AW: Eigene Komponente TCustomControl den Focus erhalten
Zitat:
|
AW: Eigene Komponente TCustomControl den Focus erhalten
Hmm..
Könnte es sein, das es deshalb nicht geht, da ein Panel (CustomPanel) ein Container ist und selber eigentlich keinen (sichtbaren) Focus erhält, sondern diesen immer an ein darauf platziertes Control weiter reicht? (Nur so eine Vermutung.. ;) ) |
AW: Eigene Komponente TCustomControl den Focus erhalten
Zitat:
Zitat:
Außerdem: Mit der Tab-Taste kann ich den Focus ja auf mein Control bringen. Ich möchte aber auch, dass es den Focus erhält, wenn ich es mit der Maus anklicke. |
AW: Eigene Komponente TCustomControl den Focus erhalten
Hmm..
Zitat:
Es erhält immer nur ein darauf platziertes Control (Edit/Button..) den Focus, aber nie das Panel selber. Wahrscheinlich wird im CustomPanel ein Flag gesetzt, welches ihm selber kein Focus gibt, sondern an ClientControls weiter reicht.. |
AW: Eigene Komponente TCustomControl den Focus erhalten
Man könnte ja nachschauen wie das bei anderen Controls funktioniert ... z.B. bei
Delphi-Quellcode:
TButton
Delphi-Quellcode:
procedure TButtonControl.WndProc(var Message: TMessage);
begin case Message.Msg of WM_LBUTTONDOWN, WM_LBUTTONDBLCLK: if not (csDesigning in ComponentState) and not Focused then begin FClicksDisabled := True; Winapi.Windows.SetFocus(Handle); // das setzt den Focus FClicksDisabled := False; if not Focused then Exit; end; CN_COMMAND: if FClicksDisabled then Exit; end; inherited WndProc(Message); end; |
AW: Eigene Komponente TCustomControl den Focus erhalten
Zitat:
Jetzt sollten alle KeyPress-Ereignisse auch an meine Komponente gehen (Form keyPreview = False). Tun sie auch ;-) bis auf Pfeiltasten VK_Left, VK_Right, VK_Top und VK_Down. Diese aktivieren sofort das nächste bzw. vohergehende Control. Aber genau diese Tasten benötige. Wie gesagt, wenn ich mit dem Tabulator zu meinem Control navigiere, kommen diese Tasten jedoch an. |
AW: Eigene Komponente TCustomControl den Focus erhalten
Zitat:
|
AW: Eigene Komponente TCustomControl den Focus erhalten
Zitat:
Werden Messagen im eigenen Control NICHT implementiert\Behandelt! Nun dann tun sie auch nichts. Baust du ein Auto ohne Bremsen dann kannst du es auch nicht anhalten. Ist doch ganz einfach zu verstehen. gruss |
AW: Eigene Komponente TCustomControl den Focus erhalten
Zitat:
Hierbei ist jedoch nicht ganz so einfach, da manches über Windows-Botschaften passiert. Und somit nicht direkt aus dem Code auslesbar ist. Da ich da nicht unbedingt so viel Erfahrung habe, frage ich hier halt mal. |
AW: Eigene Komponente TCustomControl den Focus erhalten
Zitat:
Behandle..
Delphi-Quellcode:
und gut ist.
WM_KEYFIRST = $0100;
{$EXTERNALSYM WM_KEYDOWN} WM_KEYDOWN = $0100; {$EXTERNALSYM WM_KEYUP} WM_KEYUP = $0101; {$EXTERNALSYM WM_CHAR} gruss |
AW: Eigene Komponente TCustomControl den Focus erhalten
Zitat:
Nur stellt sich mir die Frage, welche ich abfangen muss, damit ich die o.g. Tasten an meinem Control ankommen. WndProc, WMChar, WMKeyDown kommen nur an, wenn ich irgendwelche anderen Tasten drücke. Obwohl form.ActiveControl auf meinem Control steht. |
AW: Eigene Komponente TCustomControl den Focus erhalten
Zitat:
Ein Möglichkeit wäre dein Control bzw. das Panel zu Subclassen. Dein Control muss WM_KEYDOWN und WM_KEYUP an alle Child Windows weiterreichen. gruss |
AW: Eigene Komponente TCustomControl den Focus erhalten
Habe die Lösung gefunden.
Delphi-Quellcode:
Und schon kommen auch VK_LEFT, VK_RIGHT, VK_DOWN und VK_UP bei WMKeyDown an ;-)
procedure TTPPlan2.WMGetDlgCode(var Message: TWMGetDlgCode);
begin inherited; Message.Result:=Message.Result or DLGC_WANTARROWS; end; Da wäre ich so im Leben nicht drauf gekommen. Aber eure Anregungen haben mir bei der Suche schon wesentlich weiter geholfen. Danke euch dafür. |
Alle Zeitangaben in WEZ +1. Es ist jetzt 22:00 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 by Thomas Breitkreuz