![]() |
Eindeutigen Name für Frame durch anhängen einer Nummer finden
Hallo,
ihr kennt sicherlich das Problem, wenn man mehre gleiche Frames auf eine Form oder anderem Frame setzt, meldet Delphi einen Fehler, dass dieser Frame bereits existiert. Es benötigt einen eindeutigen Namen, den man durch anhängen einer Nummer erreicht. Soweit so gut, wenn Delphi auf einer Form Nummern vergibt für Komponenten, wie TEDit oder TLabel, dann füllt Delphi auch wieder die Lücken, die durch Löschen entstanden sind. Ich wollte es so machen, wie Delphi es macht, konnte es nicht finden oder habe den Code nicht begriffen. Weiß jemand wie Delphi die Nummerierung lückenlos schafft? Mein Versuch:
Delphi-Quellcode:
Auch da habe ich lange dran herumexperimentiert.
function TFrameBuchenBank.findFreeNumber: integer;
var I,J,Zahlen: Integer; Frame: TFrameBuchenBankDetail; ZahlenArray: TArray<string>; Fund: boolean; begin for I := 1 to ScrollBoxKontierZeilen.ComponentCount do begin ScrollBoxKontierZeilen.EnumObjects( function (aObject: TFMXObject) : TEnumProcResult var Anhalten: boolean; begin Anhalten:= false; if aObject is TFrameBuchenBankDetail then begin Frame:= aObject as TFrameBuchenBankDetail; Fund:= Frame.NameNr = I; Anhalten := Fund; end; if Anhalten then Result:= TEnumControlsResult.Stop else Result:= TEnumControlsResult.Continue end ); if not Fund then exit(I) end; Result:= ScrollBoxKontierZeilen.ComponentCount + 1 end; Danke für eure Mühe. Gruß Peter |
AW: Eindeutigen Name für Frame durch anhängen einer Nummer finden
Brauchst du denn die Namen für irgendetwas? Andernfalls kannst du auch einfach den Namen des Frames auf einen Leerstring setzen. Mehrere Komponenten ohne Namen sind nämlich erlaubt.
|
AW: Eindeutigen Name für Frame durch anhängen einer Nummer finden
Hallo Uwe,
danke für Deine Antwort. Nein, die Namen brauche ich nicht. Das heißt, ich könnte
Delphi-Quellcode:
setzen?
Frame.Name := EmptyStr;
Mehrere sind erlaubt, schreibst Du, kannst Du ungefähr sagen wie viele? Die Frames nehmen in einem zusammengesetzten Buchungssatz jeweils ein Konto entgegen. Ich wollte zwar keine Begrenzung einbauen, aber bei einer genügenden Anzahl, wäre es vermutlich die einfachste Variante. Gruß Peter |
AW: Eindeutigen Name für Frame durch anhängen einer Nummer finden
Ja.
Warum nicht
Delphi-Quellcode:
:= '';
Irgendwie verstehe ich nicht, warum jemand auf die Idee kommt diese blöde "Variable" zu benutzen. (du willst nicht wissen wie viel Spaß es macht, wenn sie mal ausversehn verändert wurde) Egal wieviele. (bis der Speicher überläuft) Ein "Name" muß pro Owner "eindeutig" sein, wenn er gesetzt ist. |
AW: Eindeutigen Name für Frame durch anhängen einer Nummer finden
Danke Himitsu,
wenn ich den Namen auf Leerstring setzen kann und dann nur der Speicher die Grenze ist, hilft es nicht nur, sondern vereinfacht die Sache kolossal. Zitat:
Zitat:
Danke noch mal Himitsu und Uwe. Gruß Peter |
AW: Eindeutigen Name für Frame durch anhängen einer Nummer finden
Die Window-Handles (GDI) sind auch noch ein Limit, sind inzwischen wohl bei 65.536, also alle "Windows", was Forms, Frames, Panels, Edits, Buttons, aber auch Bitmap, Canvas, Font usw. sind.
![]() |
AW: Eindeutigen Name für Frame durch anhängen einer Nummer finden
Danke Himitsu,
diese Grenze werde ich wohl bestimmt nicht erreichen. Wie oben geschrieben dienen die Frames, um einen Teilbuchungssatz entgegenzunehmen. Ohnehin muss ich mir noch überlegen, ob ich die Teilbuchungssätze auf maximal 100 begrenze. Bei Lohn kann schon ein sehr umfangreicher Buchungssatz entstehen. Gerade bin ich dabei, den Code umzuschreiben, um die Frames ohne Namen zu nutzen. Soweit ich das sehe, erleichtert es einiges. Gruß Peter |
AW: Eindeutigen Name für Frame durch anhängen einer Nummer finden
Wie groß aufwändig ist denn der Frame?
Vielleicht wäre die TControlList eine Überlegung wert. ![]() ![]() @Uwe: Ja, die ListBox im FMX ist dagegen besser. |
AW: Eindeutigen Name für Frame durch anhängen einer Nummer finden
Zitat:
|
AW: Eindeutigen Name für Frame durch anhängen einer Nummer finden
Liste der Anhänge anzeigen (Anzahl: 1)
So richtig weiß ich nicht, was Du mit Größe meinst. Die *.pas hat 12 KB und die dazugehörige *.fmx noch mal 8 KB.
Das Frame enthält einige Komponenten und es können noch mehr werden. Vielleicht hilft Dir ein Bild weiter, die Größe einzuschätzen: Ich nutze fmx. Die Frames sammelt einer TScrollBox. TListBox habe ich auch ausprobiert, hatte Schwierigkeiten Code in jedes einzelne Item zu bekommen. Vielleicht meine Unerfahrenheit. Die Frames enthalten noch 360 Zeilen Code, wobei möglicherweise sich das noch um 50 bis 100 Zeilen kürzen läßt. Kann auch mehr werden, ich versuche so viel wie möglich die Frames selbst erledigen zu lassen. Trotzdem greift es auf ein Businesstool zu und anschließend ein Model . In Abhängigkeit des Kontos werden unterschiedliche Funktionen ausgeführt: u.a. Umsatzsteuer und Kategorie. Im Gegensatz zu anderen Buchhaltungsprogrammen habe ich bei den Konten die Sortierung nach Kategorien eingebaut. Grundsätzlich halte ich die ListBox von fmx für eine tolle Komponente und habe sie für andere Aufgaben vorgesehen. Das Schöne an der Listbox ist, dass sie auch längs funktioniert. In der Fibu habe ich für alles, was ich Listen brauche ListView genommen. |
AW: Eindeutigen Name für Frame durch anhängen einer Nummer finden
Groß = Was so alles drauf liegt, wie Uwe schon sagte ist TControlList (VCL) "etwas" eingeschränkt.
FMX weiß ich's grade nicht (bzw. beim Test grade zu doof angestellt), aber mir war so, als wenn man dort in der TList nahezu alle Komponenten reinbekommt. Also wenn alles die "selben" Frames sind, dann dort ein Vorlage-Item im Designer zusammenklimpern und das wird dann ItemCount-mal zur Laufzeit vervielfältigt. Im FMX dann noch via LiveBinding an eine TList<> oder Dataset hängen und von da automatisch mit Daten füllen lassen. |
Alle Zeitangaben in WEZ +1. Es ist jetzt 22:41 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