dcsimg
Login | Register   
RSS Feed
Download our iPhone app
TODAY'S HEADLINES  |   ARTICLE ARCHIVE  |   FORUMS  |   TIP BANK
Browse DevX
Sign up for e-mail newsletters from DevX

By submitting your information, you agree that devx.com may send you DevX offers via email, phone and text message, as well as email offers about other products and services that DevX believes may be of interest to you. DevX will process your information in accordance with the Quinstreet Privacy Policy.


Tip of the Day
Language: Visual Basic
Expertise: Intermediate
Mar 5, 2001

WEBINAR:

On-Demand

Application Security Testing: An Integral Part of DevOps


Finding the Form That Contains a Control From Any Point in the Code

You may find that you want to know something about the form that contains the control you wish to use. You could do this by passing a reference to the form, but that will get messy if you are nested 5 levels deep in procedures. A cleaner solution is to use the Container property to get the form. Of course, a control may be contained by other controls. The solution is to walk the chain of containers until you reach the form.
 
Public Function GetForm(ctr As Control) As Object
    Set GetForm = ctr.Container
    Do Until TypeOf GetForm Is Form
        Set GetForm = GetForm.Container
    Loop
End Function
Now, since this function returns an object, you should cast it back to a form for better performance. This is shown below using a control array of nested pictureboxes:
 
Private Sub picNested_Click(Index As Integer)
    Dim frm As Form

    Set frm = GetForm(picNested(Index))
    MsgBox frm.Name, vbOKOnly, "Name of form"
End Sub
Richard Morrison
 
Comment and Contribute

 

 

 

 

 


(Maximum characters: 1200). You have 1200 characters left.

 

 

Sitemap
×
We have made updates to our Privacy Policy to reflect the implementation of the General Data Protection Regulation.
Thanks for your registration, follow us on our social networks to keep up-to-date