Solved

Making a Form Always on Top

Posted on 1998-11-13
12
265 Views
Last Modified: 2006-11-17
Hello I need a function that will make a passed in form always on top of the application, but not all windows.  Basically like a Find window.
0
Comment
Question by:cavacasp
12 Comments
 
LVL 9

Expert Comment

by:Dalin
ID: 1444815
cavacasp
Try:
In form 1,
Form2.Show, me

This will keep form2 always on top of form1
Regards
Dalin

0
 
LVL 1

Expert Comment

by:MAVERICK
ID: 1444816
Dont you use VBmodal ????

0
 

Author Comment

by:cavacasp
ID: 1444817
That does not work it is giving me an invalid procedure call on that line.  One thing that I did not mention was that these forms are MDI Child Forms.  On thing that also is that the person needs to be able to switch between the two forms, just like they can on a Find form.
0
Simplifying Server Workload Migrations

This use case outlines the migration challenges that organizations face and how the Acronis AnyData Engine supports physical-to-physical (P2P), physical-to-virtual (P2V), virtual to physical (V2P), and cross-virtual (V2V) migration scenarios to address these challenges.

 
LVL 14

Expert Comment

by:waty
ID: 1444818
Use this :

Private Declare Function SetWindowPos Lib "user32" (ByVal hWnd As Long, ByVal hWndInsertAfter As Long, ByVal x As Long, ByVal y As Long, ByVal cx As Long, ByVal cY As Long, ByVal wFlags As Long) As Long

Sub AlwaysOnTop(frmID As Form, OnTop As Integer)
   ' *** Pass any non-zero value to Place on top
   ' *** Pass zero to remove top-mostness

   Const SWP_NOMOVE = 2
   Const SWP_NOSIZE = 1
   Const flags = SWP_NOMOVE Or SWP_NOSIZE
   Const HWND_TOPMOST = -1
   Const HWND_NOTOPMOST = -2

   If OnTop Then
      OnTop = SetWindowPos(frmID.hWnd, HWND_TOPMOST, 0, 0, 0, 0, flags)
   Else
      OnTop = SetWindowPos(frmID.hWnd, HWND_NOTOPMOST, 0, 0, 0, 0, flags)
   End If

End Sub

0
 

Author Comment

by:cavacasp
ID: 1444819
Two things

1) Does not work with MDI Child forms.  I can get around this if necessary even though I would prefer to make the second form a MDI Child form.

2) I only want the Always on top attribute to be application wide.  If you pull up a find box it only stays on top of the application not every program that is currently running on the computer.

0
 

Expert Comment

by:SANTOSMI
ID: 1444820
use this function

Declare Function SetWindowPos Lib "user32" (ByVal hwnd As Long, ByVal hWndInsertAfter As Long, ByVal X As Long, ByVal Y As Long, ByVal cx As Long, ByVal cy As Long, ByVal wFlags As Long) As Long


when load a form use:

SetWindowPos hwnd, -1, 0, 0, 113, 290, conSwpNoActivate Or conSwpShowWindow

0
 

Author Comment

by:cavacasp
ID: 1444821
What is
conSwpNoActivate Or conSwpShowWindow
I'm getting variable not defined when it gets to this point.

Also how would I go about taking the always on top attribute off.
0
 

Author Comment

by:cavacasp
ID: 1444822
I need to get and answer to this question. So I have to reject it because you are not answering my comment.  If you can answer my comment then feel free to resubmit and I'll be happy to award you the points.
0
 
LVL 1

Expert Comment

by:MAVERICK
ID: 1444823
Now If I understand this correctly.....
1. You are using a MDI form
2. You want a specific MDI Child to remain on top

then there is a simple answer
Private Sub form_lost focus
form.Zorder=0
End sub

Is this what you want??


0
 

Author Comment

by:cavacasp
ID: 1444824
Which form would I put this code on the one that I want to stay on top or the one beneath it.
0
 
LVL 1

Expert Comment

by:MAVERICK
ID: 1444825
Oh sorry.... the one you want to keep on top.. :) I guess I should have mentioned that !


0
 
LVL 1

Accepted Solution

by:
movieguy earned 50 total points
ID: 1444826
' Declare the following API function in a module
Declare Function SetWindowWord Lib "User32" (ByVal hWnd As Long, ByVal nIndex As Long, ByVal nNewWord As Long) As Long

' Place the following code in the load event of the Mdi child
' form you want to keep on top of all the other child
' forms.
' Assuming the name of the Mdi main form is mdiMain.  You will
' have to change names as needed.
SetWindowWord Me.hWnd, -8, mdiMain.hWnd

0

Featured Post

Ransomware: The New Cyber Threat & How to Stop It

This infographic explains ransomware, type of malware that blocks access to your files or your systems and holds them hostage until a ransom is paid. It also examines the different types of ransomware and explains what you can do to thwart this sinister online threat.  

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

Suggested Solutions

Introduction In a recent article (http://www.experts-exchange.com/A_7811-A-Better-Concatenate-Function.html) for the Excel community, I showed an improved version of the Excel Concatenate() function.  While writing that article I realized that no o…
This article describes some techniques which will make your VBA or Visual Basic Classic code easier to understand and maintain, whether by you, your replacement, or another Experts-Exchange expert.
As developers, we are not limited to the functions provided by the VBA language. In addition, we can call the functions that are part of the Windows operating system. These functions are part of the Windows API (Application Programming Interface). U…
Show developers how to use a criteria form to limit the data that appears on an Access report. It is a common requirement that users can specify the criteria for a report at runtime. The easiest way to accomplish this is using a criteria form that a…

803 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question