Solved

MDI question

Posted on 2002-05-14
7
210 Views
Last Modified: 2010-05-02
Hi,

I am trying out my first MDI app and I have a question. In my main MDIForm, I am able to create multiple instances of a child form. Is there a way for me to iterate thru all of the child forms, regardless of how many are up? I want to be able to do this without keeping a static counter. Also, if anyone could point me to a good site that could enlighten me on the ins and outs of VB MDI's I would appreciate it.

Thanks
0
Comment
Question by:jhamlett
7 Comments
 
LVL 70

Expert Comment

by:Éric Moreau
ID: 7009424
dim x as form

for each x in forms
   msgbox x.caption
next
0
 
LVL 2

Accepted Solution

by:
ventond earned 100 total points
ID: 7009430
   Dim I As Integer

    For I = 0 To Forms.Count - 1
       If TypeOf Forms(I) Is frmMyForm Then
           Forms(I).ZOrder 0
       End if    
    Next

Where frmMyform is the name of the from you are looking for. You might also do something like:

if Forms(I).caption = "ME" then
0
 
LVL 4

Expert Comment

by:trkcorp
ID: 7009435
<<Is there a way for me to iterate thru all of the child forms, regardless
of how many are up?>> The way I do this is by using the forms collection.  I set the Tag property of all child forms to "child". For example I add a menu option under a Windows menu "Close all child windows".  The code looks like this:

Private Sub mnuWinCloseChild_Click()
Dim n as integer
On Error Resume Next
n=0
Do While n < Forms.Count
   If Forms(n).Tag = "child" Then
      Unload Forms(n)
   else
      n = n + 1
   End If
Loop
End Sub

Hope this helps...

0
Gigs: Get Your Project Delivered by an Expert

Select from freelancers specializing in everything from database administration to programming, who have proven themselves as experts in their field. Hire the best, collaborate easily, pay securely and get projects done right.

 
LVL 4

Expert Comment

by:trkcorp
ID: 7009447
PS: The reason the loop is While < Forms.Count is that Forms(1) will always be the MDI parent...
0
 

Author Comment

by:jhamlett
ID: 7009486
cool, those all work great. thanks for all the input.
0
 
LVL 4

Expert Comment

by:trkcorp
ID: 7009561
jhamlett, you should accept or reject the "forced" answer by ventond.  If you leave this question sitting here "locked" few people will bother to look at it and give you further input...  
0
 

Author Comment

by:jhamlett
ID: 7009897
my bad, thought I had accepted the answer, hehe
0

Featured Post

Courses: Start Training Online With Pros, Today

Brush up on the basics or master the advanced techniques required to earn essential industry certifications, with Courses. Enroll in a course and start learning today. Training topics range from Android App Dev to the Xen Virtualization Platform.

Question has a verified solution.

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

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…
Since upgrading to Office 2013 or higher installing the Smart Indenter addin will fail. This article will explain how to install it so it will work regardless of the Office version installed.
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…
Get people started with the utilization of class modules. Class modules can be a powerful tool in Microsoft Access. They allow you to create self-contained objects that encapsulate functionality. They can easily hide the complexity of a process from…

776 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