AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Algorithmen, Datenstrukturen und Klassendesign Falsche Änderung in einem Frame rückgängig machen
Thema durchsuchen
Ansicht
Themen-Optionen

Falsche Änderung in einem Frame rückgängig machen

Ein Thema von idefix2 · begonnen am 17. Mai 2015 · letzter Beitrag vom 18. Mai 2015
Antwort Antwort
Benutzerbild von himitsu
himitsu

Registriert seit: 11. Okt 2003
Ort: Elbflorenz
44.313 Beiträge
 
Delphi 12 Athens
 
#1

AW: Falsche Änderung in einem Frame rückgängig machen

  Alt 17. Mai 2015, 23:09
Toolpalette "Frames" und dann geht ein Helper auf, der z.B. Frames im selben Projekt auflistet.
Ein Therapeut entspricht 1024 Gigapeut.
  Mit Zitat antworten Zitat
Perlsau
(Gast)

n/a Beiträge
 
#2

AW: Falsche Änderung in einem Frame rückgängig machen

  Alt 18. Mai 2015, 00:26
Ahh! Jetzt! Das hatte ich bisher nie verwendet ... Der Ursprungsframe enthält eine Checkbox mit zugewiesenem OnClick-Ereignis. Ich wechsle ins Mainform und platziere darauf den Frame via Toolpalette -> Standard -> Frames. Okay. Danach klicke ich die auf dem jetzt eingebetteten Frame befindliche Checkbox an und sehe im OI -> Ereignisse, daß in dieser Kopie des Original-Frames der Checkbox keine Ereignisbehandlung zugewiesen wurde. Wenn ich jetzt im OI via Doppelklick der Checkbox im Frame auf dem Formular ein Ereignis zuweisen will, erstellt mir Delphi folgende Procedure in der Mainform:
Delphi-Quellcode:
procedure TFormMain.Frame_Test1CheckBox1Click(Sender: TObject);
begin
  Frame_Test1.CheckBox1Click(Sender);
end;
Das ruft dann die bereits implementierte Ereignisbehandlung für die Checkbox auf und funktioniert tatsächlich wie erwartet. Wenn ich jetzt im OI das Ereignis lösche, steht tatsächlich in der DFM der Mainform:
Delphi-Quellcode:
inherited CheckBox1: TCheckBox
          OnClick = nil
Nachdem ich das Ereignis im OI wieder zugewiesen habe, steht dort:
Delphi-Quellcode:
inherited CheckBox1: TCheckBox
          OnClick = Frame_Test1CheckBox1Click
Damit dürfte das Problem gelöst sein

Geändert von Perlsau (18. Mai 2015 um 00:30 Uhr)
  Mit Zitat antworten Zitat
idefix2

Registriert seit: 17. Mär 2010
Ort: Wien
1.027 Beiträge
 
RAD-Studio 2009 Pro
 
#3

AW: Falsche Änderung in einem Frame rückgängig machen

  Alt 18. Mai 2015, 00:36
Oder du weißt das Event wieder zu (wenn man es kennt) ... findest du es denn im DropDown nicht?
Nein, im Dropdown kann man es nicht zuweisen, da scheinen nur die Ereignisbehandlungsroutinen der Form-Unit auf, aber die geerbte Routine ist ja in der Frame-Unit deklariert.
Wenn man sich im OI der Form die Ereignisse anschaut, die der Komponente eines Frame zugeordnet sind, ist das komplett leer, die geerbten Ereignisse sind da nicht sichtbar, die sieht man nur, wenn man das Original-Frame bearbeitet.

Ist auch nicht weiter schlimm, man kann es ja direkt in der DFM-Datei löschen - ich habe das nur gefragt, weil ich in dem File nicht besonders gerne herumfuhrwerke, weil man da sehr schnell irgendwas gröber ruiniert: beim Herauslöschen dieses inherited habe ich in der DFM Datei zuerst das zugehörige "end" nicht mitgelöscht, daraufhin waren beim ersten Versuch, die neue Version zu kompilieren, plötzlich die Hälfte der Formularkomponenten weg, da hab ich im ersten Moment recht dumm dreingeschaut

@Perlsau
Frame_Test1Checkbox1Click ist aber eine Ereignisbehandlungsroutine der Form, die ihrerseits die Routine der frame aufruft, was zumindest überflüssiger Overhead ist. Deshalb wollte ich das so nicht stehen lassen. Aber offenbar bringt man das nicht mehr via OI weg, sondern nur direkt in der DFM Datei.

Geändert von idefix2 (18. Mai 2015 um 00:39 Uhr)
  Mit Zitat antworten Zitat
Benutzerbild von himitsu
himitsu

Registriert seit: 11. Okt 2003
Ort: Elbflorenz
44.313 Beiträge
 
Delphi 12 Athens
 
#4

AW: Falsche Änderung in einem Frame rückgängig machen

  Alt 18. Mai 2015, 00:50
Wenn man sich im OI der Form die Ereignisse anschaut, die der Komponente eines Frame zugeordnet sind, ist das komplett leer, die geerbten Ereignisse sind da nicht sichtbar,
Auch nicht, wenn du den Fokus in das Property-Edit setzt?
Ich kenn z.B. Komponenten von einem globalen DataModul, deren "Link" man nur sieht, wenn der Fokus sich im Edit befindet und sonst ist der auch unsichtbar,
außer die Datenmodul-Unit ist ebenfalls gerade im Editor geladen,

bzw. sie war es in dieser Session mal geladen, wenn das Datenmodul sich zudem in einem Designpackage innerhalb der IDE befindet.

sondern nur direkt in der DFM Datei.
Im Kontextmenü des Formdesigners gibt es keine Funktion?
Ein Therapeut entspricht 1024 Gigapeut.
  Mit Zitat antworten Zitat
idefix2

Registriert seit: 17. Mär 2010
Ort: Wien
1.027 Beiträge
 
RAD-Studio 2009 Pro
 
#5

AW: Falsche Änderung in einem Frame rückgängig machen

  Alt 18. Mai 2015, 00:56
Auch nicht, wenn du den Fokus in das Property-Edit setzt?
Nein, auch dann nicht.

sondern nur direkt in der DFM Datei.
Im Kontextmenü des Formdesigners gibt es keine Funktion?
Ha! Gibt es doch!
"Geerbte Einstellungen wiederherstellen"
Danke für den Tipp.
  Mit Zitat antworten Zitat
Perlsau
(Gast)

n/a Beiträge
 
#6

AW: Falsche Änderung in einem Frame rückgängig machen

  Alt 18. Mai 2015, 01:17
Frame_Test1Checkbox1Click ist aber eine Ereignisbehandlungsroutine der Form, die ihrerseits die Routine der frame aufruft, was zumindest überflüssiger Overhead ist. Deshalb wollte ich das so nicht stehen lassen. Aber offenbar bringt man das nicht mehr via OI weg, sondern nur direkt in der DFM Datei.
Wenn du den Frame zur Designzeit in das Form einbettest, wird jedes Ereignis im Frame zu einem Ereignis im Form. Da die eigentliche Ereignisbehandlung jedoch im Frame steht, muß die Ereignisbehandlung im Form die im Frame aufrufen. Der Frame wird dabei zu einer Komponente des Forms. Wenn du nun deine Checkbox im Frame, das bereits in die Form eingebettet ist, markierst, siehst du im OI keine Zuweisung einer Ereignisbehandlung. Die Ereignisse des Frames sind im OI offenbar nicht verfügbar. Wenn du diese Zuweisung nicht machst, funktioniert dein Klick auf die Checkbox zur Laufzeit nicht (eben nochmal getestet). Ergo ist es kein überflüssiger Overhead, sondern Notwendigkeit. Etwas anders sieht es aus, wenn du den Frame erst zur Laufzeit in der Form unterbringst. Dabei reagiert der Frame vollkommen eigenständig. Ob das jetzt ein Bug ist oder so gewollt, kann ich dir mangels tiefergehender Kenntnisse über die Eingeweide der Delphi-IDE auch nicht sagen ...

Alles falsch, hab eben das Frame aus der Form gelöscht und den Frame nochmal "frisch" auf die Form verpflanzt und siehe da: Die Ereignisbehandlung der Checkbox funktioniert auch ohne diesen Overhead. Das heißt: Nach dem Einbetten des Frame in das Form steht im OI kein Ereignis für die Checkbox, und es funktioniert dennoch. Du mußt also vor dem Löschen selber was eingetragen haben, was dann natürlich nur über die Form funktioniert.

Sorry für die Irreführung, für mich stellt dieser Fall auch Neuland dar, weil ich zuvor noch niemals einen Frame zur Designzeit in eine Form eingebettet habe. Immerhin: Wieder was dazugelernt ...

Geändert von Perlsau (18. Mai 2015 um 01:27 Uhr) Grund: Richtigstellung
  Mit Zitat antworten Zitat
idefix2

Registriert seit: 17. Mär 2010
Ort: Wien
1.027 Beiträge
 
RAD-Studio 2009 Pro
 
#7

AW: Falsche Änderung in einem Frame rückgängig machen

  Alt 18. Mai 2015, 01:39
Du mußt also vor dem Löschen selber was eingetragen haben, was dann natürlich nur über die Form funktioniert.
Richtig, im Eingangspost habe ich geschrieben:
...
Nun habe ich im Formular via Objektinspektor irrtümlich ein Onclick Ereignis eingetragen und das dann wieder gelöscht. Daraufhin steht im Dfm-File:
...
Und richtig hätte ich das falsche onclick mit Hilfe des Kontextmenüeintrags weggebracht, auf den mich Himitsu aufmerksam gemacht hat, statt es zu löschen.

Geändert von idefix2 (18. Mai 2015 um 01:42 Uhr)
  Mit Zitat antworten Zitat
Dejan Vu
(Gast)

n/a Beiträge
 
#8

AW: Falsche Änderung in einem Frame rückgängig machen

  Alt 18. Mai 2015, 07:55
Wenn man 'Geerbte Einstellungen' wiederherstellen anwendet, werden natürlich alle Änderungen ggü. dem Original entfernt. Das will man aber manchmal nicht. Leider hilft hier 'nur' das direkte Editieren der DFM. Das finde ich allerdings nicht schlimm. Ich mache viele Refactorings über die DFM direkt. So eine IDE kann eben nicht alles. Schön wäre hier ein Syntaxhighlightning der DFM und ein paar Hilfen, so wie es bei WPF oder ASP.NET der Fall ist.
  Mit Zitat antworten Zitat
Antwort Antwort


Forumregeln

Es ist dir nicht erlaubt, neue Themen zu verfassen.
Es ist dir nicht erlaubt, auf Beiträge zu antworten.
Es ist dir nicht erlaubt, Anhänge hochzuladen.
Es ist dir nicht erlaubt, deine Beiträge zu bearbeiten.

BB-Code ist an.
Smileys sind an.
[IMG] Code ist an.
HTML-Code ist aus.
Trackbacks are an
Pingbacks are an
Refbacks are aus

Gehe zu:

Impressum · AGB · Datenschutz · Nach oben
Alle Zeitangaben in WEZ +1. Es ist jetzt 23:18 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