Naja, Du hast den Fehler ja bereits lokalisieren und korrigieren können. Damit kommen doch gar nicht mehr so viele Stellen in Frage. GetWindowRect ist eine boolsche Funktion. Du könntest also den Rückgabewert prüfen. Vermutlich wird dieser „false“ sein, wenn Dein Rect falsch befüllt wird. Das wäre ein Indiz dafür, dass das Fenster-
Handle zu diesem Zeitpunkt ungültig ist.
Es ist nicht ungültig da es direkt davor erstellt wird.
Das WinHandle selbst ist dieses von der Anwendung die läuft ja im Hintergrund und das Fenster das ich öffne ist ein Dialog darüber.
Und das schlägt bei der Optimierung fehl.
Wäre das
Handle falsch würde es auch ohne Optimierung falsche Werte liefern tut es aber nicht.
Deshalb verstehe ich das auch nicht.
Delphi-Quellcode:
GetWindowRect(DialogHandle, rc);
ClientToScreen(DialogHandle, p);
TMDBInfoDlgCont := CTRL_SpriteContainerCreate;
TMDBInfoDlgCont.Left := p.x + 30;
TMDBInfoDlgCont.Top := p.Y + 60;
TMDBInfoDlgCont.Width := 900;
TMDBInfoDlgCont.Height := 506;
TMDBInfoDlgCont.AnchorMode := ANCHOR_HEIGHT_WIDTH;
TMDBInfoDlgCont.DwStyle := WS_POPUP
or WS_CLIPSIBLINGS
or WS_CLIPCHILDREN;
TMDBInfoDlgCont.DwExStyle := WS_EX_TOOLWINDOW;
TMDBInfoDlgContH := TMDBInfoDlgCont.CreateWindow(DialogHandle, hInstance);
if TMDBInfoDlgContH <> 0
then // Handle ist gültig
begin
bmW := 0;
bmH := 0;
GetWindowRect(TMDBInfoDlgContH, lpr);
// TRect liefert undefinierbare Werte bei eingeschalteter Optimierung, sonst nicht.
Zitat:
Es gibt also schon Dinge, die man tun könnte, wenn falsche Werte zurückkommen.
Ja. Sinnvoll wenn es bei beiden varianten ein Problem gäbe aber ohne Optimierung ist das
Handle sowie der Rect richtig.
Und es werden korrekte werte zurück gegeben.
Ich halte nochmal fest.
Es funktioniert ohne Optimierung mit leider nicht.
Also kann es am Code definitiv nicht liegen denn dann dürfte beides nicht gehn.