Delphi-PRAXiS
Seite 1 von 2  1 2      

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/)
-   -   Delphi Kompo dyn. erstellen -> Klappt. Dyn. Kompo benutzen -> Nicht (https://www.delphipraxis.net/13423-kompo-dyn-erstellen-klappt-dyn-kompo-benutzen-nicht.html)

Nalincah 18. Dez 2003 10:02


Kompo dyn. erstellen -> Klappt. Dyn. Kompo benutzen ->
 
Mit diesem Code erstelle ich ein paar Komponenten:

Globale Variablen:

Delphi-Quellcode:
var anzSQL:Integer = 0;
    Sheet : array of TTabSheet;
    SQLMemo : array of TSynMemo;
    SQLSyn : array of TSynSQLSyn;
Komponenten erstellen:
Delphi-Quellcode:
procedure TFrameDB.ButtonSQLNeuClick(Sender: TObject);
begin
  SetLength(Sheet, anzSQL + 1);
  SetLength(SQLMemo, anzSQL + 1);
  SetLength(SQLSyn, anzSQL + 1);
  // TabSheet erstellen
  Sheet[anzSQL] := TTabSheet.Create(PageControlSQL);
  Sheet[anzSQL].Parent := PageControlSQL;
  Sheet[anzSQL].PageControl := PageControlSQL;
  Sheet[anzSQL].Caption := '(Unbenannt)';
  // SQLMemo erstellen
  SQLMemo[anzSQL] := TSynMemo.Create(Sheet[anzSQL]);
  SQLMemo[anzSQL].Parent := Sheet[anzSQL];
  SQLMemo[anzSQL].Align := alClient;
  SQLMemo[anzSQL].RightEdge := 80;
  // SQLSyn erstellen
  SQLSyn[anzSQL] := TSynSQLSyn.Create(nil);
  SQLMemo[anzSQL].Highlighter := SQLSyn[anzSQL];
  // PageControl auf erstellen TabSheet stellen
  Inc(anzSQL);
  PageControlSQL.ActivePageIndex := PageControlSQL.PageCount - 1;
end;
Das klappt auch alles. Kompos werden erzeugt ohne Fehler

Wenn ich aber das ausführe, wird nichts geladen:

Delphi-Quellcode:
procedure TFrameDB.ButtonSQLLoadClick(Sender: TObject);
begin
  if OpenDialogSQL.Execute then
  begin
    TSynMemo(SQLMemo[PageControlSQL.ActivePageIndex]).Lines.LoadFromFile(OpenDialogSQL.FileName);
    TTabSheet(Sheet[PageControlSQL.ActivePageIndex]).Caption := OpenDialogSQL.FileName;
    TTabSheet(Sheet[PageControlSQL.ActivePageIndex]).Font.Style := [];
  end; // if OpenDialogSQL.Execute then
end;
Woran kann das liegen?????

Christian Seehase 18. Dez 2003 10:34

Re: Kompo dyn. erstellen -> Klappt. Dyn. Kompo benutzen -
 
Moin Sebastian,

ich kann Dir jetzt zwar keine Lösung sagen, aber Du kannst die Typecasts (TSynMemo(...), TTabSheet(...)) weglassen, da die entsprechenden Angaben ja schon vom entsprechenden Typ sind.

Nalincah 18. Dez 2003 10:54

Re: Kompo dyn. erstellen -> Klappt. Dyn. Kompo benutzen -
 
Achso. Aber wo liegt der unterschied? Bzw. wofür benutzt man
Delphi-Quellcode:
TTabSheet[Sheet.....

Christian Seehase 18. Dez 2003 11:02

Re: Kompo dyn. erstellen -> Klappt. Dyn. Kompo benutzen -
 
Moin Sebastian,

das brauchst Du, wenn der übergebene Typ oberhalb des gewünschten angesiedelt ist.
Ein, auch hier, häufig anzuwendender Fall ist die Verwendung von FindComponent. Hier ist der Rückgabetyp TComponent, und i.d.R. benötigt man Eigenschaften / Methoden eines von TComponent abgeleiteten Typs. Um diese nun ansprechen zu können, muss man einen Typecast durchführen.
Besser als
Delphi-Quellcode:
TDatentyp(ObjektBezeichner)
ist übrigens
Delphi-Quellcode:
(Objektbezeichner as TDatenTyp)
da in letzterem Falle der Compiler schon eine Typprüfung vornimmt, so dass ungültige Typcasts schon zur Compilierzeit erkannt werden können. In ersterem Falle (TDatenTyp(...)), übernimmt der Entwickler die Verantwortung dafür, dass das angegebene Objekt auch wirklich so angesprochen werden kann.

Nalincah 18. Dez 2003 11:46

Re: Kompo dyn. erstellen -> Klappt. Dyn. Kompo benutzen -
 
Verstanden...Aber wirklich weitergebracht hat mich das jetzt nicht

Christian Seehase 18. Dez 2003 16:40

Re: Kompo dyn. erstellen -> Klappt. Dyn. Kompo benutzen -
 
Moin Sebastian,

also einen Fehler kann ich nicht entdecken.
Hast Du mal einen Breakpoint auf diese Zeile

Delphi-Quellcode:
TSynMemo(SQLMemo[PageControlSQL.ActivePageIndex]).Lines.LoadFromFile(OpenDialogSQL.FileName);
gesetzt und überprüft, ob das Programm dort ankommt?

Andere Möglichkeit:
Hast Du mal die TabSheets durchgeklickt, ob die Datei eventuell in einem anderen Memo angezeigt wird?

noch eine:
Stehen in der Datei eventuell Binäre Nullen (z.B. wenn es sich um Unicode Dateien handelt)? Dann wird das Laden bei der ersten davon beendet.

Nalincah 18. Dez 2003 22:11

Re: Kompo dyn. erstellen -> Klappt. Dyn. Kompo benutzen -
 
Zitat:

Zitat von Christian Seehase
Moin Sebastian,

also einen Fehler kann ich nicht entdecken.
Hast Du mal einen Breakpoint auf diese Zeile

Delphi-Quellcode:
TSynMemo(SQLMemo[PageControlSQL.ActivePageIndex]).Lines.LoadFromFile(OpenDialogSQL.FileName);
gesetzt und überprüft, ob das Programm dort ankommt?

Andere Möglichkeit:
Hast Du mal die TabSheets durchgeklickt, ob die Datei eventuell in einem anderen Memo angezeigt wird?

noch eine:
Stehen in der Datei eventuell Binäre Nullen (z.B. wenn es sich um Unicode Dateien handelt)? Dann wird das Laden bei der ersten davon beendet.

Das Programm kommt zu der Zeile, der FileName ist auf gesetzt. Aber im Memo steht nichts. Auch in den anderen nicht. Bei der Datei handelt es zum um ne normale txt-Datei mit nem SQL-Statement drin. Auch andersrum hab ich das problem. Wenn ich den Inhalt aus dem Memo auslesen will, dann ist es immer leer. Komisch

Christian Seehase 19. Dez 2003 02:32

Re: Kompo dyn. erstellen -> Klappt. Dyn. Kompo benutzen -
 
Moin Sebastian,

kannst Du mal die Datei hier als Attachement anhängen, mit der das nicht funktioniert?

Nalincah 19. Dez 2003 07:29

Re: Kompo dyn. erstellen -> Klappt. Dyn. Kompo benutzen -
 
Liste der Anhänge anzeigen (Anzahl: 1)
Die Unit des Frame, in der ich die Kompos erstelle und benutze

Christian Seehase 19. Dez 2003 11:35

Re: Kompo dyn. erstellen -> Klappt. Dyn. Kompo benutzen -
 
Moin Sebastian,

ich hatte es geahnt...

Die Textdatei, die nicht so will wie sie soll hatte ich gemeint ;-)


Alle Zeitangaben in WEZ +1. Es ist jetzt 15:19 Uhr.
Seite 1 von 2  1 2      

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