Delphi-PRAXiS
Seite 1 von 2  1 2      

Delphi-PRAXiS (https://www.delphipraxis.net/forum.php)
-   Object-Pascal / Delphi-Language (https://www.delphipraxis.net/32-object-pascal-delphi-language/)
-   -   Delphi Das geheimnissvolle Controll (https://www.delphipraxis.net/198555-das-geheimnissvolle-controll.html)

Delbor 13. Nov 2018 17:52

Delphi-Version: 10.2 Tokyo

Das geheimnissvolle Controll
 
Hi zusammen

In einer Scrollbox möchte ich mehrere Instanzen eines TCustumControl-Nachfahhren platzieren. Dieses versuchen ich in einer Testanwendung so:

Delphi-Quellcode:
procedure TRSPdfFrame.PdfViewCreate;
  var i: integer;
begin
  for i := 0 to 4 do
  begin
    FPDFView := TPdfView.Create(Self);
    FPdfView.Parent := Scrollbox1;
    FPdfView.Name := 'PdfView'+intToStr(i);
    FPdfView.Color := clyellow;
    FPdfView.Height := 120;
    FPdfView.Top := i * (FPdfView.Height + 8);
    FPdfView.Width := Scrollbox1.ClientWidth - 40;
    FPdfView.Left := (ScrollBox1.ClientWidth - FPdfView.Width) div 2;
    ScrollBox1.VertScrollBar.Range := ScrollBox1.VertScrollBar.Range + FPdfView.Height;
  end;
end;
Der Aufruf:
Delphi-Quellcode:
procedure TRSPdfFrame.ScrollBox1Resize(Sender: TObject);
begin
  PdfViewCreate;
  FReportlist.Add('ScrollBox1Resiz')
end;
Der Inhalt von FReportlist wird bei Programmende in eine Datei geschrieben. Deren Inhalt:
Delphi-Quellcode:
13.11.2018 17:32:28
----------------
ScrollBox1Resiz
Meine Fehlermeldung:

Zitat:

Benachrichtigung über Debugger-Exception
---------------------------
Im Projekt HomeOfficerMainProject.exe ist eine Exception der Klasse EComponentError mit der Meldung 'Komponente mit der Bezeichnung PdfView0 existiert bereits' aufgetreten.
---------------------------
Die DCUs und die EXE habe ich schon mehrmals gelöscht.
Was ist da falsch?

Gruss
Delbor

Schokohase 13. Nov 2018 17:56

AW: Das geheimnissvolle Controll
 
Führe doch bitte mal diese Änderungen aus
Delphi-Quellcode:
procedure TRSPdfFrame.ScrollBox1Resize(Sender: TObject);
begin
  FReportlist.Add('ScrollBox1Resiz ENTER');
  PdfViewCreate;
  FReportlist.Add('ScrollBox1Resiz EXIT');
end;
und zeige uns dann den Inhalt der Datei

Hobbycoder 13. Nov 2018 17:58

AW: Das geheimnissvolle Controll
 
Naja, du läßt bei jedem Resize TRSPdfFrame.PdfViewCreate durchlaufen. Und erzeugst nur. Demnach ist beim zweiten Resize ein Control mit dem Namen auch bereits vorhanden.

Wenn's anders nicht geht, sollte du die bereits erzeugten Controls vorher entfernen.
Besser wäre es natürlich im Resize auch die Controls in ihrer Größe zu ändern, als sie zu löschen und neu zu erzeugen.

DeddyH 13. Nov 2018 18:05

AW: Das geheimnissvolle Controll
 
Man muss übrigens beim dynamischen Erzeugen von Controls keinen Namen zuweisen.

Schokohase 13. Nov 2018 18:09

AW: Das geheimnissvolle Controll
 
Zitat:

Zitat von Hobbycoder (Beitrag 1417987)
Naja, du läßt bei jedem Resize TRSPdfFrame.PdfViewCreate durchlaufen. Und erzeugst nur. Demnach ist beim zweiten Resize ein Control mit dem Namen auch bereits vorhanden.

Ich wette das weiß er, aber diese "Log-Datei" hat ihn in die Irre geführt, weil er denkt, dass die Methode
Delphi-Quellcode:
TRSPdfFrame.ScrollBox1Resize
nur einmal ausgeführt wird.

Delbor 13. Nov 2018 18:21

AW: Das geheimnissvolle Controll
 
Hi Schokohase

Danke für deine schnelle Antwort!
Tja, das ist doch schon sehr speziell - wenigstens für mich im Moment:
Zitat:

13.11.2018 18:02:00
----------------
ScrollBox1Resiz ENTER
ScrollBox1Resiz ENTER
ScrollBox1Resiz EXIT
So der Dateiinhalt, und so der aktuelle Code:
Delphi-Quellcode:
procedure TRSPdfFrame.ScrollBox1Resize(Sender: TObject);
begin
//  FReportlist.Add('ScrollBox1Resiz')
  FReportlist.Add('ScrollBox1Resiz ENTER');
  PdfViewCreate;
  FReportlist.Add('ScrollBox1Resiz EXIT');
end;
Dass der Frame vor der Mainform erzeugt wird, ist mir schon klar, aber dass sich ein Ereignis widerholt, noch bevor es zu Ende ist...

Oder was verstehe ich jetzt falsch?

Okay, ich hab vor dem Anzeige der Vorschau die weiteren Beiträge gesehen und kann da nur mal bestätigen: Ja, ich weiss, der Anwender will die Form eventuell mehrmals resizen - ich muss das also kontrollieren.
Zur Zeit läüft der Test, wie ich die Dinger korrekt untereinander bringe. Das Stimmt insofern noch nicht, als dass die Form zu klein ist, um den gesammten Clientbereich der Scrollbox anzuzeigen. Mit dem Feler im Fokus hat mich die Sache mit dem Resize doch auf dem falschen Fuss erwischt.


Gruss
Delbor

Delphi.Narium 13. Nov 2018 18:31

AW: Das geheimnissvolle Controll
 
Das Erstellen der Controls gehört nicht ins Resize. Resize ist für Größenänderungen (wie der Name schon sagt).

Die Controls werden einmalig erstellt (z. B. im FormCreate oder einer daraus aufgerufenen Methode).

Hobbycoder 13. Nov 2018 18:33

AW: Das geheimnissvolle Controll
 
Zitat:

Zitat von Schokohase (Beitrag 1417989)
Ich wette das weiß er

Da war ich jetzt auch mal von ausgegangen. Aber manchmal......nach einem langen Arbeitstag...… :-D

Delbor 13. Nov 2018 18:47

AW: Das geheimnissvolle Controll
 
Hi zusammen

Zitat:

Zitat von DeddyH (Beitrag 1417988)
Man muss übrigens beim dynamischen Erzeugen von Controls keinen Namen zuweisen.

Ich werde später darauf zugreifen müssen - Okay, da täte es auch das Tag-Property.

Zitat:

Zitat von Schokohase (Beitrag 1417989)
Zitat:

Zitat von Hobbycoder (Beitrag 1417987)
Naja, du läßt bei jedem Resize TRSPdfFrame.PdfViewCreate durchlaufen. Und erzeugst nur. Demnach ist beim zweiten Resize ein Control mit dem Namen auch bereits vorhanden.

Ich wette das weiß er, aber diese "Log-Datei" hat ihn in die Irre geführt, weil er denkt, dass die Methode
Delphi-Quellcode:
TRSPdfFrame.ScrollBox1Resize
nur einmal ausgeführt wird.

Das heisst, dass es die Kontrolle auch dann braucht, wenn die Form nur in einer einzigen Gösse angezeigt wird.
Wie ist das denn mit dem Resize? Da ist mal der Basisframe - aber braucht der ein Resize? Der wird ja nie angezeigt.
Auf der Form habe ich gerade mal eine Frameinstanz - wäre nach meinem bisherigen Stand des Irrtums gerade mal ein Resize-Ereignis.

Anders sähe es wohl aus, wenn das Resize des Frames nach jedem Resize auf der Containerform aufgerufen würde - grundsätzlich könnte nach jedem Resize eines andern Elementes eine Anpssung nötig sein. Meine Frage hier wäre also: lösen Resize-Events anderer Elemente ein erneutes Resize aus?

Zitat:

Zitat von Hobbycoder (Beitrag 1418000)
Da war ich jetzt auch mal von ausgegangen. Aber manchmal......nach einem langen Arbeitstag...… :-D

Ich bin in Rente. Das heisst, zumindest jetzt nicht übermüdet.


Gruss
Delbor

Delbor 13. Nov 2018 19:39

AW: Das geheimnissvolle Controll
 
Hi Delphi.Narium

Zitat:

Zitat von Delphi.Narium (Beitrag 1417999)
Das Erstellen der Controls gehört nicht ins Resize. Resize ist für Größenänderungen (wie der Name schon sagt).

Die Controls werden einmalig erstellt (z. B. im FormCreate oder einer daraus aufgerufenen Methode).

Anfänglich rief ich die PdfCreate-Proedur aus dem Constructor des Frames auf - mit dem Resultat, das sämtlche Elemente übereinander erstellt wurden. Ist ja auch kein Wunder - zu dem Zeitpunkt gibts noch keine Form und eine Höhe eines Elements dieser Form schon gar nicht.
Ein Create oder sonst was(Activate, Show) kennt der Frame auch nicht. Wann also sollen diese Controls erzeugt werden?
Für den Produktiveinsatz stellt sich dieses Problem allerdings wohl nicht - hier ist dies Aufgabe zum Beispiel eines Eventhandlers, der auf das Öffnen einer Datei reagiert...

Gruss
Delbor


Alle Zeitangaben in WEZ +1. Es ist jetzt 10:47 Uhr.
Seite 1 von 2  1 2      

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