Solved

Keep window topmost in MDI application

Posted on 1999-01-14
5
391 Views
Last Modified: 2012-06-27
I am creating an application that will display one or more MDI Child forms. I want to be able to display a Search form that will:
1. Be a child of the MDI parent form
2. Stay on top of the child forms
3. Not stay on  top of other applications that may be      running.  

I have tried the SetParent API call to achieve item 1, but when the Search form is unloaded, it also hides the toolbar on the MDI Main form.

I have also used SetWindowPos to achieve item 2, but the Search form remains on top of other applications.

I have also tried using Zorder in the activate and deactivate events on all forms, but the blinking that occurs is unacceptable.
0
Comment
Question by:kponder
[X]
Welcome to Experts Exchange

Add your voice to the tech community where 5M+ people just like you are talking about what matters.

  • Help others & share knowledge
  • Earn cash & points
  • Learn & ask questions
  • 2
  • 2
5 Comments
 
LVL 7

Expert Comment

by:bouscal
ID: 1456431
Try setting the search form to VBModal.  That should keep it on top of the other forms in your app and still allow other apps to run on top of it.
0
 
LVL 1

Author Comment

by:kponder
ID: 1456432
I have tried this but it is not a child of the MDI form. The Search form can't be allowed to go outside of the MDI form's borders.




0
 
LVL 1

Author Comment

by:kponder
ID: 1456433
Another point:  When the search form is displayed the user will also need to be able to access the MDI child forms.
0
 
LVL 1

Accepted Solution

by:
Johnn earned 200 total points
ID: 1456434
I'm not really sure what seems to be wrong with what your doing.  As long as you reset the parent in the search form's unload event to 0, it shouldn't unload your toolbar.  Also, this window will always stay on top of the child windows without doing anything else.  My tests were in VB5.  I guess your try too hard?

Dim frmChild() As Child
Private Sub MDIForm_Load()
    Dim a%
    ReDim frmChild(1 To 5)
    For a = 1 To 5
        Set frmChild(a) = New Child
        Load frmChild(a)
        frmChild(a).Visible = True
    Next
    Load frmSearch
    SetParent frmSearch.hWnd, Me.hWnd
    frmSearch.Visible = True'set to false at design time to elminated any "flashing"
End Sub
'search form
Private Sub Form_Unload(Cancel As Integer)
    SetParent Me.hWnd, 0
End Sub

Hope that works for you
John
0
 
LVL 1

Expert Comment

by:Johnn
ID: 1456435
The reason my code works above is that we are setting the "find" windows parent to the actual MDI form, not the MDI form's client which is a totally different window.
0

Featured Post

Enroll in July's Course of the Month

July's Course of the Month is now available! Enroll to learn HTML5 and prepare for certification. It's free for Premium Members, Team Accounts, and Qualified Experts.

Question has a verified solution.

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

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…
Enums (shorthand for ‘enumerations’) are not often used by programmers but they can be quite valuable when they are.  What are they? An Enum is just a type of variable like a string or an Integer, but in this case one that you create that contains…
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…
This lesson covers basic error handling code in Microsoft Excel using VBA. This is the first lesson in a 3-part series that uses code to loop through an Excel spreadsheet in VBA and then fix errors, taking advantage of error handling code. This l…
Suggested Courses
Course of the Month6 days, 18 hours left to enroll

623 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