![]() |
Korreekte Verwendung TActionList.OnUpdate / TAction.OnUpdate
Hallo zusammen,
ich hoffe ich bin mit dem Thema hier richtig. Die Actions betreffen ja im Wesentlich die Controls GUI (Controls). Ich habe eine grundsätzlich Frage zu den Actions bzw. wie implementiert ihr üblicherweise das OnUpdate. Bisher habe ich die Verwaltung der Zustände der Aktionen immer in die zentrale TActionList.OnUpdate verfrachtet. Also:
Delphi-Quellcode:
Das müsste aber kontraproduktiv zu sein, da das OnUpdate wohl für jede Aktion einmal aufgerufen wird. Eine Alternative wäre:
procedure TfrmSomething.ActionListUpdate(Action: TBasicAction; var Handled: Boolean);
begin aAction1.Enabled := ...; aAction2.Enabled := ...; usw. Handled := True; end;
Delphi-Quellcode:
Das ist aber auch irgendwie umständlich bzw. macht den Code unübersichtlich. Die dritte Alternative wäre das TActionList.OnUpdate nicht zu verwenden und stattdessen die Zustandsverwaltung mit TAction.OnUpdate jeder Aktion selbst zu überlassen. Macht das ganze aber noch unübersichtlicher.
procedure TfrmSomething.ActionListUpdate(Action: TBasicAction; var Handled: Boolean);
begin if Action = aAction1 then aAction1.Enabled := ... else if Action = aAction2 then aAction2.Enabled := ... usw. Handled := True; end; Ich mache das seit jeher wie ganz am Anfang gezeigt. Performance-Probleme hatte ich da noch nie, da die Boolschen Zustände die ich zum Aktivieren bzw. Deaktivieren der Aktionen verwende alle bereits vorliegen und nicht im OnUpdate erst ermittelt bzw. berechnet werden. Um zum Anfang zurück zu kommen: Wie macht ihr das normalerweise? Ich suche da nach einer "Best Practice". Man will ja keine Rechenzeit / Energie verschwenden :-D. Alex |
AW: Korreekte Verwendung TActionList.OnUpdate / TAction.OnUpdate
Hallo,
ich verwende dafür immer TForm.UpdateActions. Dazu überschreibe ich es und setze dort die Actions entsprechend.
Delphi-Quellcode:
TMyForm = class(TForm) public procedure UpdateActions; override; end;
Delphi-Quellcode:
procedure TMyForm.UpdateActions;
begin inherited; aAction1.Enabled := ...; aAction2.Enabled := ...; usw. end; |
AW: Korreekte Verwendung TActionList.OnUpdate / TAction.OnUpdate
Zitat:
|
AW: Korreekte Verwendung TActionList.OnUpdate / TAction.OnUpdate
Zitat:
Als weiteres wird der Update-Aufruf innerhalb von TCustomAction.Execute damit funktionslos. Zitat:
|
AW: Korreekte Verwendung TActionList.OnUpdate / TAction.OnUpdate
Wo die Actions liegen sollte doch keine Rolle spielen. Es ist ja trotzdem möglich auf das Datenmodul zuzugreifen. Aber man sollte im Form nur die Actions ansprechen, die hier auch eingebunden bzw. verknüpft sind.
|
AW: Korreekte Verwendung TActionList.OnUpdate / TAction.OnUpdate
[QUOTE=Uwe Raabe;1510617]
Zitat:
|
AW: Korreekte Verwendung TActionList.OnUpdate / TAction.OnUpdate
Zitat:
Das Problem mit den verschwindenden Links in den DFMs ist leider ärgerlich, taucht aber nach meinem Gefühl nur noch gelegentlich bei tiefen Form-Vererbungs-Hierarchien auf. Ich löse das dann durch gezielte Zuweisungen im Source-Code. Das erlaubt weiterhin die zentrale Verwaltung der Actions in Datenmodulen. |
AW: Korreekte Verwendung TActionList.OnUpdate / TAction.OnUpdate
Zitat:
ja, das mit der Vererbung von Forms ist in meinen Applikationen leider an der Tagesordnung. Sämtliche forms (Formulare, Dialoge und Frames) basieren bei mir auf einer zentralen Basis, da diese immer eine Grundfunktionalität mitbringen müssen (dynamisch Sprachumschaltung etc.). Ich gebe Dir aber recht, dass die IDE und vor allem der LSP mittlerweile damit besser zurecht kommen. Wobei der LSP immer noch das Problem hat, dass neue Units (egal ob normale Unit oder VCL Form etc.) erst nach einem Neustart der IDE vom LSP berücksichtigt werden (dafür muss ich mal einen eigenen Thread aufmachen, da ich nicht weiß ob das Problem nur bei mir besteht). Das mit dem gezielten Zuweisen im Source-Code ist auf jeden Fall eine gute Idee... |
AW: Korreekte Verwendung TActionList.OnUpdate / TAction.OnUpdate
Zitat:
Aber vielleicht spaltet ein Moderator das hier mal in einen neuen Thread ab... |
AW: Korreekte Verwendung TActionList.OnUpdate / TAction.OnUpdate
Zitat:
Was mir aufgefallen ist, das Actions, denen kein OnExecute zugewiesen ist, automatisch auf Enabled := False gesetzt wird. Setzt man es trotzdem im UpdateActions auf True, wird das nach wieder auf False gesetzt im UpdateActions wieder auf True. Es entsteht dann zwar keine Endlosschleife, aber ist z.B. ein Button mit der Action verklüpft, flackert der dann entsprechen. Ich habe eigendlich angenommen, dass UpdateActions der beste Zeitpunkt ist, die Actions zu setzen. Der Name der Prozedur sagt doch alles. Man könnte sicher noch ein Property (z.B. DoUpdateActions) im Form hinzufügen, dass UpdateActions mitteilt, dass die Actions gesetzt werden sollen. |
Alle Zeitangaben in WEZ +1. Es ist jetzt 21:58 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