![]() |
Setfocus auf dbgrid
Hallo,
folgendes Problem. Habe ein Dbgrid, eigebettet in einem Frame. Ebenso in diesem Frame ist ein Panel mit einet Schliessen-Button. Würde gerne, wenn auf Button schliessen gedrückt, dann auf Dbgrid springen (1.-ter Datensatz) und anschliessend ohne die Maus in die Hand zu nehmen, weiter mit den Pfeil-Tasten im Grid rauf oder runter mich bewegen. Mit dbgrid.setfocus funktioniert es nicht. Wenn ich mit der Maus auf Dbgrid klicke, dann geht es wieder. Habe schon mit dbgridcellclick(nil) probiert, funktioniert auch nicht. Danke, Luckner |
AW: Setfocus auf dbgrid
Lass doch das DBGrid DBGrid sein und navigiere stattdessen durch die verbundene Datenmenge, oder habe ich das Problem missverstanden?
|
AW: Setfocus auf dbgrid
Zitat:
|
AW: Setfocus auf dbgrid
Danach wird nichts mehr aufgerunfen. Habe jetzt festgestellt, dass wenn ich mit der Maus auf die Buttons klicke, dan wird setfocus richtig ausgeführt. Mit meinem Hotkey F10, wo ich nur die Procedure Button.Click aufrufe, der Fücus auf dem Frame- oder Form1-Fenster landet. Mit den Pfeil-Tasten geht links, oben das Fenstermenue auf. Fenster minimieren, maximieren Schliessen usw.
|
AW: Setfocus auf dbgrid
Wo genau setzt du denn deinen Fokus für das DBGrid? Ich würde das in deinem Fall mal in der Button-Ereignisbehandlung versuchen ...
|
AW: Setfocus auf dbgrid
Aus einem Editfeld im Panel wird folgendes aufgerufen:
Delphi-Quellcode:
Dann im Button:
procedure TFrameAuftrag.JvEditKundennrsuchenKeyDown(Sender: TObject;
var Key: Word; Shift: TShiftState); begin if Key = VK_F10 then ButtonPanelSchliessen.Click; end;
Delphi-Quellcode:
procedure TFrameAuftrag.ButtonPanelSchliessenClick(Sender: TObject);
begin DBGridAuftrag.SetFocus; PanelFilter.Visible := False; JvHTButtonSuchenFiltern.Visible := True; end; |
AW: Setfocus auf dbgrid
Was passiert, wenn du das Setzen des DBGrid-Fokus ans Ende stellst, d.h. zuletzt ausführst? Welche Delphi-Version verwendest du eigentlich?
|
AW: Setfocus auf dbgrid
Wird denn ButtonPanelSchliessenClick auch ausgeführt?
Versuche dann mal folgendes:
Delphi-Quellcode:
Es ist denkbar, dass Dir hier ein Zeitverhalten der VCL in die Quere kommt. Es KÖNNTE SEIN, dass der Focus noch nicht wirklich umgesetzt wurde und Dein Edit durch Ausschalten des Panels "verschwindet". Dann würde der Parent den Focus erhalten.
procedure TFrameAuftrag.ButtonPanelSchliessenClick(Sender: TObject);
begin DBGridAuftrag.SetFocus; // PanelFilter.Visible := False; // JvHTButtonSuchenFiltern.Visible := True; end; Wenn das das Problem wäre, dann vielleicht einfach den Focus zuletzt zuweisen:
Delphi-Quellcode:
Da die VCL solche Anweisungen verzögert durch Nachrichtenverarbeitungen abarbeitet muss man mit solchen Effekten rechnen.
procedure TFrameAuftrag.ButtonPanelSchliessenClick(Sender: TObject);
begin PanelFilter.Visible := False; JvHTButtonSuchenFiltern.Visible := True; DBGridAuftrag.SetFocus; end; EDIT: Oups, kein roter Kasten, aber Perlsau ist wohl auf der gleichen Spur... |
AW: Setfocus auf dbgrid
JvEditKundennrsuchenKeyDown:
Wenn du Eingaben selber verarbeitest, dann solltest du besser auch die weitere Verarbeitung abschalten. (hier einfach
Delphi-Quellcode:
und in ganz besonderen Extremfällen ein
Key:=0;
![]() Und was passiert, wenn den Fokus als Letztes setzt? |
AW: Setfocus auf dbgrid
Die Lösung ist: Key:=0; Jetzt funktioniert es.
Danke himitsu und allen Anderen. |
AW: Setfocus auf dbgrid
Zitat:
Delphi-Quellcode:
PanelFilter.Visible := False;
JvHTButtonSuchenFiltern.Visible := True; Zitat:
![]() Zitat:
Zitat:
Ach ja, bevor ich's wieder vergesse: Welche Delphi-Version setzt du ein? |
AW: Setfocus auf dbgrid
Ok, Problem ist ja gelöst, dennoch ein Satz zu Perlsaus Frage:
Wenn DBGrid konkret den Fokus hat, dürfte es ja egal sein, ob ein anderes Panel ausgeblendet wird. In meinem Framework bin ich mit ähnlichen Abläufen aber einige Male auf die Nase gefallen - und bei verschiedenen Delphi- bzw- Windows-Versionen auch unterschiedlich. Man kann auf jeden Fall nicht davon ausgegen, dass alle VCL-Ereignisse immer und überall 1:1 chronologisch nacheinander abgearbeitet werden. Die Codezeilen werden natürlich nacheinander abgearbeitet, aber wenn nur Nachrichten verschickt werden kann man nie sicher sein, wann diese "beim Empfänger" verarbeitet werden. Bei schnellen Abläufen kann dann mal eine erwartete Reihenfolge durcheinander kommen. Ein konkretes (ähnlich gelagertes) Problem hatte ich, wenn ich ein focusiertes Control gelöscht habe und zuvor ein anderes focusiert habe. Windows wollte dann unbedingt das gelöschte nochmal neu zeichnen, aber das existierte dann ja nicht mehr. Gelöst habe ich das indem ich das zu löschende Control erst mal unsichtbar gemacht und erst später gelöscht habe. Dass die Lösung hier in der Key-Behandlung lag ist beruhigend. Aber Zusammenhänge wie von mir angesprochen sollte man mit als mögliche Problemursache beachten. |
AW: Setfocus auf dbgrid
Okay, das mit den verzögerten Messages kann ich zwar theoretisch nachvollziehen, hab's aber noch nicht erlebt bzw. hab keinen Schimmer, wie man das reproduzieren könnte. Dagegen erlebe ich des Öfteren, daß ein Umstellen der Befehlsreihenfolge ein Fehlverhalten beseitigen kann. Z.B. hatte ich kürzlich ein
![]() Zitat:
|
AW: Setfocus auf dbgrid
Wir schweifen etwas ab, aber noch kurz:
Die VCL hat gewissermaßen ein Eigenleben, das sich auch mal ändern kann. Eigene Logiken davon abhängig zu machen, kann unerwartete Schwierigkeiten bereiten. Hinzu kommt, dass die Controls in sich öfters nicht so arbeiten, wie man es erwarten sollte ( ![]() Das sollte man nur im Auge behalten. Das vorliegende Key-Problem ist wohl, dass F10 eine Menüfunktion aufruft. Wenn Key nicht "neutralisiert" wird, macht Windows das noch, nachdem die Anwendung schon mit der Bearbeitung fertig ist. |
AW: Setfocus auf dbgrid
Zitat:
Für dein DBRadioGroup hätte ich einfach TJvDBRadioPanel aus den Jedis genommen ... |
AW: Setfocus auf dbgrid
Zitat:
PS: Den schönsten Spaß hat man, wenn einige Ereignisse im OnKeyDown verarbeitet werden und Andere im OnKeyUp. Ein gutes Beispiel hatte ich da auch mal, so wurde im OnKeyDown per F2 das aktuelle ShowModal-Fenster geschlossen, während das übergeordnete Fenster im OnKeyUp per F2 eine neue Instanz des Fenster öffnete. - F2 rein und alles ist OK - per F2 wieder raus ging nicht, da es gleich wieder rein ging, weil das eine Fenster sich im Down ausblendete und das Up dann im anderen Fenster landete. > beides gleichermaßen im Up ODER im Down ausgeführt, hätte keine Probleme bereitet :stupid: Oder wie hier: Mehrere Stellen verarbeiten das selbe Tastenereignis und man wundert sich dann, wenn Mehreres passiert oder Einiges nicht richtig. |
AW: Setfocus auf dbgrid
Genau dafür gibt's den Spruch: Verarschen kann ich mich alleine :-D
Daß das wunderbar klappt, hat wohl schon jeder einmal erleben dürfen :lol: |
AW: Setfocus auf dbgrid
Hallo Perlsau, himitsu,
Meine Delphi-Version ist 7 Pro. Folgendes Problem noch, auf das, so glaube ich, gerade himitsu darauf hingewiesen hat. Habe versucht einige Funktionen ebenfalls in einem anderem Frame mit den F-Tasten zu steuern. Es funktioniert nicht, weil im Tastaturpuffer jetzt die Funktionen der F-Tasten aus dem vorherigen Frame noch hinterlegt sind und in einem weiterem Frame nicht funktionieren bzw. Mist machen. Kann ich, wenn ich ein Frame verlasse, den gesamten Tastaturpuffer zurücksetzen? Mit dem key := 0 funktioniert auch das Bewegen mit den Pfeiltasten im DB-Grid nicht mehr. Aber das werde ich noch gesondert überprüfen. |
AW: Setfocus auf dbgrid
Ich hoffe du setzt das nur dann auf 0, wenn du darin etwas gemacht hast (z.B. nur bei deinem VK_F10) und nicht immer auch für alle anderen Ereignisse.
PS: Man sollte am Besten auch unbedingt immer die kompletten ShiftStates prüfen. Also nicht mit
Delphi-Quellcode:
, sondern mit
... IN Shift
Delphi-Quellcode:
, auch und vorallem wenn man keine dieser Tasten verwendet.
Shift = [...]
F10 ist nunmal kein Strg+F10 usw.
Delphi-Quellcode:
if (Key = VK_F10) and (Shift = []) then begin
... Key := 0; end; |
AW: Setfocus auf dbgrid
Danke himitsu,
der Tipp mit key:=0 war richtig. Hatte Das an der falsche Stelle gesetzt. Jetzt habe ich das Problem, das z.B. die F2-Taste in einem weiterem Frame eine andere Funktion haben sollte. Leider wird die Funktion aus dem vorherigem Frame aufgerufen. Da holft das Setzen key := 0 nicht. Irgendwie müsste man den speicher löschen. Aber wie? |
AW: Setfocus auf dbgrid
Verstehe ich das so richtig?
Du hast in einem Formular mehrere Frames mit diversen Controls. Wenn Du F10 oder F2 drückst, soll etwas gemacht werden, egal, welches Control gerade den Focus hat? Ansonsten mach doch mal einen Screenshot oder so, dass das etwas nachvollziehbarer wird... |
AW: Setfocus auf dbgrid
Zitat:
|
AW: Setfocus auf dbgrid
Habe in einer Form 2 Frames. In der Form, wie auch in den einzelnen Frames gibt es z.B. Schliessen-Button. Schliessen-Button in Frame1 schliesst das Frame1, schliessen-Button in Frame2 schliesst Frame2. Schliessen-Button in Form1 schliesst die Form. Beide Frames sind allClient. Aus der Form kann man nur ein Frame aufrufen. So, wenn man in Frame1 ist, würde ich gerne mit der F10-Taste Frame1 schliessen, in Frame2 dann Frame2 schliesse und am Ende dann die Form. Die Buttons in den jeweiligen Frames machen das schon. Wenn ich jetzt in Frame1, oder 2 bin und F10 drücke wird sofort die ganze Form geschlossen. Das hin und her Springen von Frame zu Frame mache ich über die Eigenschaft "Visible". Möglicherweise müsste ich ein nichtsichtbares Frame auch deaktivieren?
|
AW: Setfocus auf dbgrid
Hallo Perlsau,
ja, dann sind es Hotkeys. kann man die irgendwie zurücksetzen oder Überschreiben? |
AW: Setfocus auf dbgrid
Die Ereignisbehandlungen für Keys im Hauptformular gelten auch für zusätzliche Fenster sowie Frames. Einzig beim Aufruf eines modalen Fensters gelten sie dort nicht. Im Übrigen ist die Wahl der F10-Taste eine schlechte, denn damit werden normalerweise Menüs aktiviert.
|
AW: Setfocus auf dbgrid
Jupp, viele Programme nehmen daher Strg+F4 für Frames/Tabs, da Alt+F4 ja auch schon als Fenster-Schließen bekannt ist.
Hier wird übrigens nirgendwo der Tastaturpuffer gelöscht. Das Tastenereignis wird von der VCL-Messageloop aus dem MessageQueue geholt und dann verarbeitet. Dabei wird das Key-Event durch mehrere Komponenten geschleift. Sobald nun Eine das Key auf 0 setzt, bekommen die Danach dann nur noch diese 0 oder deren Event wird ganricht erst aufgerufen. Du hast nicht zufällig KeyPreview der Form aktiviert? Wenn ja, dann bekommt sie zuerst das Event, ansonsten bekommt die Form das als Letztes und zuerst die Komponenten/Frames. Also entweder kein KeyPreview, oder du muß in der Form selber schauen ob es einen Frame gibt, dann schleißt du den Frame und wenn nicht, dann die Form. |
AW: Setfocus auf dbgrid
Hallo,
war gestern ganzen Tag unterwegs, deshalb erst heute weiter zu diesem Zhema. Himitsu danke für den Tipp mit "keypreview". Klar, die Taste F10 ist nicht glücklich gewählt, aber Chef möchte ganz einfach mit möglich nur einem Tansten-klick irgendwelche Funktionen in verschiedenen Masken aufrufen. Nach möglichkeit nur die F-Tasten. Also schalte ich, wenn ich in der Form ein Frame aufrufe "keypreview" aus, dann funktionieren die F-Tasten im Frame und wenn ich auf die Hauptform zurückspringe, wird "keypreview" auf True gesetzt, damit die F-Tasten da auch reagieren. Hatte gerade einige Tests gemacht und es scheint zu funktionieren. |
Alle Zeitangaben in WEZ +1. Es ist jetzt 16:01 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