![]() |
Controls wärend der Laufzeit ENTFERNEN.
Hallo Gemeinde,
ich hab da mal wieder ein kleines Problem ^^ und zwar möchte ich wärend der Laufzeit Controls entfernen. In der Code Libery habe ich schon was zum entfernen der Codes wärend der Laufzeit gefunden, allerdings entfernt da sich der Control selber. Ich bräuchte allerdings eine Procedure mit der Ich andere Button killen kann, d.h. Klickt einer auf Button1 soll in der ScrollBox1 die Button 2 und 3 entfernt werden. Leider habe ich den Code aus der Code Libery nicht umschreiben können das es funktioniert.... bin denk ich ma zu doof :D Hoffe es kann mir einer helfen Link zur CodeLibery: ![]() MFG Andre |
Re: Controls wärend der Laufzeit ENTFERNEN.
Wie hast du es versucht?
|
Re: Controls wärend der Laufzeit ENTFERNEN.
Hallo Andre,
es ist so einfach:
Delphi-Quellcode:
Grüße vom marabu
procedure TDemoForm.Button1Click(Sender: TObject);
begin Button2.Free; Button3.Free; end; |
Re: Controls wärend der Laufzeit ENTFERNEN.
Zitat:
|
Re: Controls wärend der Laufzeit ENTFERNEN.
Zitat:
Aber die Lösung von marabu funktioniert ^^ so einfach ist es also... danke euch :D |
Re: Controls wärend der Laufzeit ENTFERNEN.
Zitat:
|
Re: Controls wärend der Laufzeit ENTFERNEN.
Also die müssen meiner Meinung nach neu erzeugt werden da die Situation so aussieht:
Alle Felder und Labels werden dynamisch aus einer CSV erzeugt. Diese CSV wird durch ein anderes Programm wärend der Laufzeit geändert. d.h. der Inhalt aus der ersten Zelle der CSV wird in Edit1 geschrieben und die überschrift dazu in Label1. dies kann aber sich alles wärend der Laufzeit ändern, sodass ich wenn der User auf Aktuallisieren klickt nicht weiß ob die Caption von Label 1 immernoch die Überschrift der Spalte 1 ist und ich weiß auch nicht ob der Inhalt von Edit1 immernoch der gleiche Inhalt ist wie Zelle 1 der CSV. Desweiteren weiß ich vorher nicht ob die CSV nicht vllt nach dem Aktuallisieren Leer ist, oder ob da noch Spalten zugekommen ist. Da ich soviele Sachen nicht weiß, dachte ich mir das ein destroy und nachher wieder erzeugen besser wäre als tausende von Prüfungen und anschließend die dazugekommenden zu erzeugen. Bin natürlich offen für alle Ideen, also wenn einer was besseres weiß als .free und dann wieder erzeugen immer her damit. Dazu kommt noch das .free sehr sehr langsam ist. Also das .free mach ich gerade so:
Delphi-Quellcode:
dabei ist pruefung eine variable des typ boolean welche auf true gesetzt wird wenn 1mal felder erzeugt wurden.
if pruefung = true then begin
for i:= 1 to AnzahlSpalten-1 do begin TEdit(Scrollbox1.FindComponent('Edit'+ IntToStr(i))).Free; TLabel(Scrollbox1.FindComponent('Label'+ IntToStr(i))).Free; end; end; AnzahlSpalten ist die Anzahl der Spalten der CSV wovon ich vorher (bevor die CSV durch ein anderes Programm verändert worden ist) die Objects erzeugt habe. Mit AnzahlSpalten weiß ich also wieviele Objects ich zu löschen habe. mit FindComponents suche ich mir die dann raus da ich ja die Objects nicht mit Edit[i] oder Label[i] ansprechen kann oder?? nun klappt alles, aber ich habe bei der .free Methode eine CPU-Auslastung von 100 % also geht alles zu langsam. Gibt es eine bessere Möglichkeit??? So .... nun seit ihr wieder gefragt ^^ Danke schonmal :D MFG Andre |
Re: Controls wärend der Laufzeit ENTFERNEN.
Richtig rechenintensiv ist eigentlich nur FindComponent() - eine Methode, die du hier wirklich missbrauchst. Sie ist in erster Linie zur Unterstützung von Interaktionen gedacht, wo ihr Laufzeitverhalten von der Arbeitsgeschwindigkeit des Benutzers überdeckt wird.
Warum verwendest du kein Grid oder eine ListView für deine CSV-Daten? |
Re: Controls wärend der Laufzeit ENTFERNEN.
Na dann ergibt es schon mehr Sinn ;)
Was ein besserer und/oder schnellerer Weg wäre, kommt darauf an, wie genau die Edits und Labels dargestellt werden. Vlt. wäre ein Liste ya besser?! :wink: PS: Das casten bei FindComponent kannst du dir sparen, jedes TObject kennt .Free ^^ |
Re: Controls wärend der Laufzeit ENTFERNEN.
Zitat:
Nur da die CSV aktuallisiert wird wärend der Laufzeit muss ich dann wenn der User auf den Button aktuallisieren klickt die CSV einlesen in das StringGrid und dann halt wieder die Objects neu erzeugen. Zitat:
OK, das casten hab ich wieder weggenommen. Aber ist natürlich immernoch alles langsam. Und FindComponent() brauch ich ja weil ich muss doch irgendwie alle Labels und Edits "löschen"... wie soll ich es sonst machen wenn nicht mit FindComponent? Ich will keinen Missbrauchen aber ich sehe keine andere Möglichkeit.... aber diese hier ist zu langsam. Da brauch ich mal gute Ideen :D Eine Liste ist nicht zu machen, der Kunde MÖCHTE vorne nen Label mit der Spaltenüberschrift und dahinter dann ein Edit. Und was der Kunde möchte... das bekommt er ^^ MFG Andre PS: HELFT MIR BITTE :D :D |
Alle Zeitangaben in WEZ +1. Es ist jetzt 20:37 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