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 Element '' hat kein übergeordnetes Fenster (https://www.delphipraxis.net/139558-element-hat-kein-uebergeordnetes-fenster.html)

stahli 31. Aug 2009 18:10


Element '' hat kein übergeordnetes Fenster
 
Liste der Anhänge anzeigen (Anzahl: 1)
Hallo alle,

ich habe ein Problem an dem ich schon den ganzen Tag nicht weiter komme...
und das sich schlecht beschreiben lässt, daher ein größeres Bild anbei...

Ich nutze eine eigene Komponente, die Daten aus einer Datenbank holt und dynamisch abgeleitete Panels erzeugt, die die Records darstellen (links im Bild).
Die Einträge kann man z.B. verschieben und bearbeiten und so mit der DB arbeiten.

Aktuell werden links z.B. 3 Datensätze angezeigt (mögliche Zählweisen).
Wird die Abfrage aktualisiert und es gibt JETZT NUR NOCH 2 Datensätze, werden die Inhalte der ersten 2 Panels ersetzt und das dritte Panel gelöscht (Panel3.Free).
Hat das freizugebende Panel den Fokus wird der auf einen anderen Eintrag gesetzt und der ungültige Eintrag (das Panel3) gelöscht.

Alles wunderbar...

Hat jedoch ein Panel den Fokus, das Formular wird geschlossen und mit einer anderen Abfrage geöffnet, die weniger Resultate liefert, gibt das die genannte Fehlermeldung.
Diese tritt aber erst auf, nachdem meine Komponenten ihre Arbeit verrichtet haben.

Die "Listenkomponente" zeichnet sich nach dem Öffnen des Formulars und ruft dann automatisch neue Daten ab. Jetzt findet sie z.B. mal keine passenden Datensätze und löscht entsprechend alle enthaltetenen Panels.

das sieht etwas so aus:

Delphi-Quellcode:
I := 0
while not EOF do
begin
  if I > Items.Count - 1 then
  begin
    Item := Panel.Create(Self);
    Items.Add(Item);
  end
  else
    Item := Items[I];
  ItemBeschriftenUndPositionieren;
  Inc(I)
end;
while Items.Count > I do
begin
//  GetItem(Items.Count - 1).Visible := False;
  Items.Delete(Items.Count - 1);
end;
Die Items durchlaufen auch problemlos ihren destructor.

Erst wenn Windows wieder die Kontrolle übernimmt tritt der Fehler auf.
Und das auch nur, wenn beim letzen Schließen des Fensters ein jetzt gelöschter Eintrag den Fokus hatte (setze ich vorher den Fokus noch z.B. auf das Editfeld gibt es keinen Fehler).
Nach "wegdrücken" der Fehlermeldung geht alles ordentlich weiter.

Lösche ich die Items nicht sondern schalte sie nur unsichtbar, tritt der Fehler nicht auf.

Meine Überlegung:
Windows hat sich irgendwie gemerkt, dass der jeweilige Eintrag den Fokus hatte und will da nochmal etwas zeichnen.

Folgender Versuch bringt mich nicht weiter.
Delphi-Quellcode:
procedure TdcPanel.Paint;
begin
  if not HandleAllocated then
    Exit;
  ...
end;
"Application.ProcessMessages;" vor und nach den Löschaktionen bringen auch nichts.

ZuLoeschenderEintrag.Focused liefert nie True, vermutlich, da das Formular in dem Moment noch nicht aktiviert ist.

Die Fehlerbeschreibung --> Element '' <-- gibt keinen Komponentennamen an, vermutlich weil die Komponente bereits aufgelöst wurde.

Ich komme da nicht weiter...


Kann das Problem jemand nachvollziehen?

Danke
Stahli

Klaus01 31. Aug 2009 18:12

Re: Element '' hat kein übergeordnetes Fenster
 
.. Du solltest den erzeugten Panels noch ein Parent Control zuweisen.
Das Control auf dem sie dargestellt werden sollen.

Grüße
Klaus

stahli 31. Aug 2009 18:17

Re: Element '' hat kein übergeordnetes Fenster
 
Sorry, da habe ich zu sehr gekürzt:

Das ist natürlich in dem Bereich ItemBeschriftenUndPositionieren mit enthalten.
Die Anzeige funktioniert ja auch wunderbar.

Das Problem tritt nur auf, wenn das entsprechende Formuar geschlossen wird und beim erneuten Öffnen das zuletzt fokussierte Panel gelöscht wird.

Klaus01 31. Aug 2009 19:13

Re: Element '' hat kein übergeordnetes Fenster
 
Hallo Stahli,

könntest Du nicht hergehen und beim Öffnen des Formulars
den Fokus auf "Name der Sportart" setzen?

Das Öffnen und Schliessen des Formulars
ist das bei Dir mit einem Create und Free verbunden?
Oder wird das Formular einmalig erzeugt und beim Beenden des Programms
wieder freigegeben?

Grüße
Klaus

stahli 31. Aug 2009 19:22

Re: Element '' hat kein übergeordnetes Fenster
 
Ja, aber ich möchte eine Lösung des Problems in meiner Kompomente finden.
Sonst müsste man ja für alle Formulare entsprechendes regeln, die die Komponente verwenden.

Außerdem soll der Fokus nicht immer beim Öffnen auf eine bestimmte Komponente gesetzt werden...


Das Formular wird nur einmal erzeugt und am Programmende aufgelöst.

hoika 31. Aug 2009 21:05

Re: Element '' hat kein übergeordnetes Fenster
 
Hallo,

Delphi-Quellcode:
if Parent<>NIL then
begin
  SetFocus;
end;
so habe ich das bei mir hinbekommen.


Heiko

stahli 1. Sep 2009 11:29

Re: Element '' hat kein übergeordnetes Fenster
 
Der zu löschende Eintrag (Panel) erhält offenbar den Fokus gar nicht mehr.

Die Listenkomponente wird beim Öffnen des Formulars gezeichnet und die überflüssigen Panels werden gelöscht.
Dann will Windows offenbar noch einmal etwas mit dem gelöschten Panel anstellen (wenn es beib letzten Schließen des Formulars den Fokus hatte).

Ich kann dies aber in den Fokus- oder Paint-Funktionen scheinbar nicht mehr erkennen (die Komponente existiert ja nicht mehr)...

stahli 5. Okt 2009 15:54

Re: Element '' hat kein übergeordnetes Fenster
 
Gibt es eigentlich ein Ereignis, wennn ein Control "unaktuell" wird - also wenn

a) das übergeordnete Formular geschlossen

oder wenn

b) ein übergeordnetes Control unsichtbar

oder bestenfalls sogar wenn

c) das übergeordnete PageControl-Tabsheet gewechselt

wird?

In allen Fällen werden die enthaltenen Controls ja nicht mehr dargestellt...
(aus Anwendersicht quasi entfernt, obwohl sie natürlich noch existieren)

Kann man das in den Komponenten selbst irgendwie erkennen?

Stahli

stahli 7. Okt 2009 14:28

Re: Element '' hat kein übergeordnetes Fenster
 
*push*
(vielleicht hat ja doch jemand eine Idee)

stahli 8. Okt 2009 11:40

Re: Element '' hat kein übergeordnetes Fenster
 
Ich habe es jetzt mit einer Notlösung im Griff...

Delphi-Quellcode:
procedure ClearAllDcListBox(W: TWinControl);
var
  I: Integer;
begin
  if W is TdcListBox then
  begin
    (W as TdcListBox).Items.Clear;
  end;
  for I := 0 to W.ControlCount - 1 do
  begin
    if W.Controls[I] is TWinControl then
      ClearAllDcListBox(W.Controls[I] as TWinControl);
  end;
end;
Die proc rufe ich im OnClose-Ereignis der Formulare auf.

Eine allgemeine Lösung über ein Ereignis "ControlWirdNichtMehrAufDemBildschirmAngezeigt " wäre mir aber lieber...
Falls jemand einmal eine Lösung weiß, dann bitte her damit.

Stahli


Alle Zeitangaben in WEZ +1. Es ist jetzt 00:59 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