tags:

views:

251

answers:

2

Here is the deal. Main form set to fsnormal. This main form is maximized full screen with a floating toolbar. Toolbar is normal form with style set to fsstayontop.

Most fo the time this works as expected. The mainform displays and the toolbar floats over on top of it.

Sometimes (this is a bugger to find a reproducible set of steps) when alt-tabbing to and from other apps (or when clicking the Delphi app icon on the taskbar) the following symptoms can happen...

  1. When alt-tabbing away from the Delphi app the floating topmost fsstayontop form stays on top of the other apps. So if I alt-tab to firefox then the floating menu stays on top of firefox too.

  2. When alt-tabbing from another app to the Delphi app the floating menu is not visible (as it is behind the fsnormal mainform).

Is there a known bug or any hacks to force it to work? This also seems to happen most when multiple copies of the app are running (they have no interaction between them and should be running in their own windows "sandbox").

It is as if delphi gets confused which window is meant to be on top and swaps them or changes the floating form to stayontopofeverything mode.

Or have I misunderstood fsstayontop? I am assuming setting a form style to fsstayontop makes it stay on top of all other forms within the current app and not all windows across other running apps.

Thanks for any tips or workarounds.

A: 

A bit more info and possible solution.

Set the floatingform to fsnormal.

When the mainform.activate event fires call floatingform.bringtofront.

But I also use stayontop for all of the other app dialogs. When multiple copies of the app are running then the dialogs show the same problem (ie if app1 has a dialog open and is alt-tabbed away from the the dialog may stay on top of all other programs).

TallGuy
One more question. How can I set a form style to stay on top of ONLY another form (in this case the mainform)? Then I can change dialogs to not fsstayontop and when they activate I can tell them to only stay on top of the mainform?PS, sorry for answering my own question. I didn't realise I should have commented rather than answer.
TallGuy
yes, you should move this entire information editing your question.
PA
A: 

I don't know of a bug in this area.

Let me first explain how the process works:

Delphi first uses fsStayOnTop style during the creation of the window that holds the form, by invoking win32 function SetWindowPos with HWND_TOPMOST parameter.

See http://msdn.microsoft.com/en-us/library/ms633545(VS.85).aspx for a detailed explanation of SetWindowPos.

Everytime the application is deactivated or minimized, Delphi enumerates all the topmost forms to normalize the forms (normalize is the term that vcl uses to mean that the windows that are topmost are turned to not being topmost) and it keeps an internal list of all of the windows that were topmost at that moment.

Everytime the application is activated or restored, Delphi uses the information stored in the list of topmost windows, to restore all the topmost forms (using setWindowPos with HWND_TOPMOST parameter)

So to me the problems seems to be in the way that Delphi stores the information while enumerating the windows when the application is minimized.

I would hack into the minimize or deactivate function and check if the topmost windows list (it is on Application.FTopMostList) are correctly listed.

PA
Some more info. There is known bugs identical with the ones I intially showed with fsstayontop from google searches.My fix is now to set all dialogs to fsnormal. Then under mainform.onactivate I add this code if (floatingmenu<>nil) and (floatingmenu.visible=true) then SetWindowPos(floatingmenu.handle, HWND_TOP, 0, 0, 0, 0, SWP_NOACTIVATE or SWP_NOMOVE or SWP_NOSIZE);This works as expected now and gets away from any delphi oddities with how it handles fsstayontop forms.
TallGuy