Delphi-PRAXiS

Delphi-PRAXiS (https://www.delphipraxis.net/forum.php)
-   GUI-Design mit VCL / FireMonkey / Common Controls (https://www.delphipraxis.net/18-gui-design-mit-vcl-firemonkey-common-controls/)
-   -   Frame To Frame Zugriff? (https://www.delphipraxis.net/184807-frame-frame-zugriff.html)

Popov 22. Apr 2015 14:38

Frame To Frame Zugriff?
 
Liste der Anhänge anzeigen (Anzahl: 1)
Ich hab bisher so gut wie nie mit Frames gearbeitet, und wenn, dann ergab sich das Problem nicht. Eigentlich denke ich, dass ich die Antwort auf meine Frage schon kenne, ich möchte aber trotzdem fragen. Vielleicht irre ich mich.

Kann man irgendwie von eine Frame-Fenster auf ein anderes Frame-Fenster zugreifen, ohne es über das Formular zu tun, das beide Frames beinhaltet?

Beispiel, ich habe Form1, dann Frame2 und Frame3. Auf Frame3 liegt ein Panel, auf Frame2 habe ich einen Button. Nun möchte ich mit dem Button eine Aktion auf Frame3 ausführen, z. B. Panel rot färben. Das geht wohl nicht direkt.

Füge ich beider Frames in Form1, kann ich es über Form1 machen. Ich hätte die Aktion aber lieber aus dem Frame gemacht.

Es gab schon vorher solche Fragen hier im Forum, aber da wurde so viel und nebensächliches besprochen, das die eigentliche Frage nicht richtig beantwortet wurde.

Was mir natürlich aufgefallen ist, das ist, dass Frames im Gegensatz zu Formularen keine Variable anbieten, womit sie ja nicht angesprochen werden können. Nicht direkt, von Frame zu Frame.

Trotzdem, ich hab ein Projekt bei dem es sich anbieten würde von einem Frame auf dem anderen etwas zu steuern. Gibt es Lösungen?

Phoenix 22. Apr 2015 14:49

AW: Frame To Frame Zugriff?
 
Du könntest mal folgendes probieren:

Code:
 for i := 0 to Parent.ControlCount - 1 do
    if Parent.Controls[i] is TFrame3 then
    begin
      TFrame3(Parent.Controls[i]).Panel1.Color := clRed;
    end;
Ohne Gewähr. Ich hab Delphi das letzte mal vor über 10 Jahren angefasst, aber so in etwa könnte es gehen.

Uwe Raabe 22. Apr 2015 15:01

AW: Frame To Frame Zugriff?
 
Im Endeffekt musst du es über das Form machen, denn nur dort gibt es die Frame-Instanz. Es ist ja durchaus möglich, ein Frame in mehreren Forms oder auch mehrmals in einem Form zu verwenden. Selbst wenn das in deinem Fall nicht vorkommt, solltest du das zumindest im Hinterkopf behalten.

CarlAshnikov 22. Apr 2015 15:06

AW: Frame To Frame Zugriff?
 
Du kannst dem Frame mit dem Button ein Event spendieren, das ausgelöst wird, wenn jemand den Button drückt. Dem kannst du dann die Methode des Frames mit dem Panel zuweisen, die das Rotfärben übernimmt.

Popov 22. Apr 2015 15:27

AW: Frame To Frame Zugriff?
 
@Phoenix

Fast, sowas in der Art hatte ich mir auch überlegt (ähnlich, nicht das Gleiche), klappt aber nicht. Er findet Panel1 nicht.

@Uwe Raabe

Ich glaube ich kehre in Zukunft zu normalen Formularen zurück, die ich dann in andere Objekte einfüge. Ist mehr Arbeit, dafür richtige Formulare.

@CarlAshnikov

Wenn es klappt. Wäre eine Möglichkeit. Ich teste es.

Kralle 22. Apr 2015 15:48

AW: Frame To Frame Zugriff?
 
Moin,

Du könntest Auch ein Datenmodul einsetzen und dort den Inhalt von einer Variablen setzen bzw. lesen.

Du kannst Dir auch mal das hier anschauen : http://misc.delphi.lang.comp.de.grou...ular_zugreifen

Gruß Heiko

Phoenix 22. Apr 2015 16:11

AW: Frame To Frame Zugriff?
 
Zitat:

Zitat von Popov (Beitrag 1298816)
@Phoenix

Fast, sowas in der Art hatte ich mir auch überlegt (ähnlich, nicht das Gleiche), klappt aber nicht. Er findet Panel1 nicht.

Hast Du die Visibility von Panel 1 auf public gesetzt?
Du musst auf Deinem TForm3 vielleicht das Panel als Property exposen damit das geht.

ThomasBab 22. Apr 2015 16:51

AW: Frame To Frame Zugriff?
 
Liste der Anhänge anzeigen (Anzahl: 1)
Hallo!

Da ich nicht mehr soviel Zeit habe, ein neues Beispiel zu erstellen, als Anhang mal ein Lazarus-Projekt, bei dem Frames dynamisch erstellt werden. Vielleicht ist es hilfreich.

Uwe Raabe 22. Apr 2015 17:16

AW: Frame To Frame Zugriff?
 
Zitat:

Zitat von Popov (Beitrag 1298816)
Ich glaube ich kehre in Zukunft zu normalen Formularen zurück, die ich dann in andere Objekte einfüge. Ist mehr Arbeit, dafür richtige Formulare.

Das löst das Problem aber nicht, da auch Forms mehrfach instanziert werden können. Insofern mehr Arbeit aber kein Vorteil in diesem Punkt.

Popov 22. Apr 2015 17:19

AW: Frame To Frame Zugriff?
 
@Phoenix

Klappt auch nicht.

@ThomasBab

Werde es testen. Bisher habe ich Probleme es zu öffnen.

ThomasBab 22. Apr 2015 17:26

AW: Frame To Frame Zugriff?
 
Zitat:

Zitat von Popov (Beitrag 1298826)
@ThomasBab

Werde es testen. Bisher habe ich Probleme es zu öffnen.

Ist die zip kaputt?

Ansonsten: es ist ein Lazarus-Projekt. Aber ein Blick in die pas-Dateien sollte die Idee zeigen.

Sir Rufo 22. Apr 2015 17:35

AW: Frame To Frame Zugriff?
 
@Popov

Stell dir so ein Frame wie eine normale Komponente vor (TEdit, TButton, etc.) die du dir eben aus vielen einzelnen Komponenten zusammenbauen kannst. Das trifft die Art und Weise von einem Frame am Besten.

Nimm z.B. ein DBGrid, ein DBNavigator und eine DataSource und verstöpsel diese auf dem Frame. Dann dieses Frame auf eine Form und nur noch der Frame-DataSource ein DataSet geben und fertig.

Popov 22. Apr 2015 18:29

AW: Frame To Frame Zugriff?
 
@Sir Rufo

Ich hab die Hilfe auch gelesen, das steht auch in etwa: Frame ist weniger wie Formular, mehr wie eine Komponente. Ich verstehe was du meinst. Trotzdem fragte ich ich ob es eine Möglichkeit gibt. Schließlich lagerte ich alles in die Frames, damit die Haupt-Unit nicht so voll ist. Nun muss ich trotzdem darüber steuern.

@ThomasBab

Nein, er konnte einige Komponenten nicht finden. Habe v. 1.2.

ThomasBab 22. Apr 2015 18:32

AW: Frame To Frame Zugriff?
 
Zitat:

Zitat von Popov (Beitrag 1298832)
@ThomasBab

Nein, er konnte einige Komponenten nicht finden. Habe v. 1.2.

Achso, deshalb sagte ich ja, dass ich nicht extra ein eigenes Projekt anlegen wollte, sondern einfach eins "aus meinem Fundus" hochgeladen habe.

Aber die fehlenden Komponenten kannst Du einfach ignorieren. Die Idee für die dynamischen Frames kommt auch mit den Standardkomponenten zu Tage (hoffe/denke ich).

bcvs 22. Apr 2015 19:07

AW: Frame To Frame Zugriff?
 
Gib dem Button von Frame2 eine Ereignisbehandlngsroutine auf Formularebene:

Auf dem Form1 Doppelklick auf den Button in Frame2. Wenn der Button im Frame schon ein OnClick hat, steht dann da schon automatisch
Delphi-Quellcode:
Frame2.ButtonOnClick(Sender);
Danach schreibst du den Code zum Färben von Frame3.Panel rein.

Wenn man so eine Aktion nicht an ein Click- oder ähnlichen Ereignis hängen kann, arbeite ich gerne mit selbstdefinierten Events, über die das Form benachrichtigt wird, wenn etwas zu tun ist.

WoGe 23. Apr 2015 12:21

AW: Frame To Frame Zugriff?
 
Hi,

Zitat:

Zitat von Popov (Beitrag 1298807)
Was mir natürlich aufgefallen ist, das ist, dass Frames im Gegensatz zu Formularen keine Variable anbieten, womit sie ja nicht angesprochen werden können. Nicht direkt, von Frame zu Frame.

Also ich meine diese Aussage ist falsch. Ein Frame ist nichts anderes als ein Object , das nur etwas anders konstruiert wird als eine Klasse. Ein Frame kann sehr wohl eigene Variable und Properties haben.
spendiert man dem Frame ein Property vom Typ TFrame und weist an passender Stelle diesem property einen anderen instanziierten Frame zu, kann man auch auf diesen anderen Frame direkt zugreifen.
Gruß
wo

DeddyH 23. Apr 2015 12:29

AW: Frame To Frame Zugriff?
 
Ich habe eher das Gefühl, dass die globale Variable innerhalb der Formularunit gemeint ist. Die ist ja nur dem Konzept der automatischen Formularerzeugung geschuldet (Application.CreateForm in der dpr), ansonsten bräuchte man sie nicht.

Headbucket 23. Apr 2015 13:24

AW: Frame To Frame Zugriff?
 
Ist das bereits zu viel für die Hauptunit?

Delphi-Quellcode:
procedure TForm1.FormCreate(Sender: TObject);
begin
  Frame2.Button1.OnClick := Frame3.DoColorPanel;
end;
Delphi-Quellcode:
procedure TFrame3.DoColorPanel(Sender: TObject);
begin
  //if Sender is TButton then
  Panel1.Color := clRed;
end;
Oder ist das schlechter Programmierstil?

So funktioniert es auf jeden Fall.

Grüße
Headbucket

himitsu 23. Apr 2015 13:46

AW: Frame To Frame Zugriff?
 
Zitat:

Oder ist das schlechter Programmierstil?
Ja.

Bau das Event in den Frame ein und da kann sich Form1 dann dranhängen.
* entweder ein Event in den Frame, im Frame einen Eventhandler an den Button und da drin das Event aufrufen
* oder ein EventProperty in den Frame und im Getter/Setter den Eventhandler an das Property des Buttons weiterreichen

Delbor 1. Mai 2015 14:51

AW: Frame To Frame Zugriff?
 
Hi zusammen

Ich verzichte hier darauf, irggendeinen Thread direkt zu beantworten; anstelle dessen hier meine Umsetzung (die letztlich die Frage beantwortet):

Ich habe zwei (Basis-)Frames - ich weiss, dass der Ausdruck Basisframe offiziell nicht existiert, benutze ihn aber trotzdem, um den Unterschied zu den Frameinstanzen zu verdeutlichen.
  • Einen ToolBoxFrme, der eine Werkzeugleiste mit Buttons zum Ausschneiden, Kopieren, Einfügen etc. enthält, und
  • Einen SyneditFrame, der eine entsprechende Komponente birgt.
Das OnClickEvent eines Buttons im ToolBoxFrame feuert ein Event - testweise hab ich einen eigenen Typ für dieses Event definiert, damit ich einen Parameter mit abfeuern kann. Ein Event TNotifyEvent würde allerdings genügen.
Der SynEditFrame definiert den Eventhandler, der die entsprechende Aufgabe im Synedit ausführt, beispielsweise selektierten Text in die Zwischenabage kopiert oder ausschneidet.
Umgekehrt wird bei MouseUp eine Event gefeuert, wenn SelText Text enthält ist - der Eventhandler im ToolbuttonFrame stellt Enabled der entsprechenden Buttons.Im Hauptformular habe ich lediglich die Zuordnung der Events an ihre Eventhandler:
Delphi-Quellcode:
procedure TDelborWebServerMain.FormCreate(Sender: TObject);
  var Event: String;
begin
  SideBarWebFrame1.FileTreeFrame1.OnFileFound := DoOnFileFound;
  ToolBoxWebFrame1.OnPCtrlActivePage := DoOnPCtrlActivePage;
  SideBarWebFrame1.FileTreeFrame1.OnPathlist := DoOnPathList;

  ManageEvents;
end;

procedure TDelborWebServerMain.ManageEvents;
begin
  ToolBoxWebFrame1.OnCutOnClipBoard := SynEditFrame1.DoCutOnClipBoard;
  ToolBoxWebFrame1.OnCopyOnClipBoard := SynEditFrame1.DoCopyOnClipBoard;
  ToolBoxWebFrame1.OnPasteFromClipBoard := SynEditFrame1.DoPasteFromClipBoard;
  ToolBoxWebFrame1.OnOnSafe := SynEditFrame1.DoOnSafeSynedit;
  ToolBoxWebFrame1.OnOnOpen := SynEditFrame1.DoOnOpenSynedit;
  ToolBoxWebFrame1.OnOnNew := SynEditFrame1.DoOnNewSynedit;
  SynEditFrame1.OnSelectText := ToolBoxWebFrame1.DoOnSelectText;
end;
Damit tauschen die beiden Basisframes direkt untereinander Events aus. Um einen Basisframe per Code zu erreichen, muss dessen Instanz im Formular angesprochen werden.
Der Sinn des ganzen? Mir ging es nicht darum, den 'Umweg über das Formular' nicht gehen zu müssen, sondern darum, die Frames möglichst ohne Anpassung des Codes wiederverwenden zu können.

Gruss
Delbor


Alle Zeitangaben in WEZ +1. Es ist jetzt 09:19 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