Go Premium for a chance to win a PS4. Enter to Win

x
?
Solved

Excel VBA - programatically design a user form

Posted on 2016-11-03
9
Medium Priority
?
90 Views
Last Modified: 2016-11-04
Is it possible to place controls on a User Form at design time programatically?

Reason: to avoid having to manually name and align controls when there's a lot of them.
0
Comment
Question by:hindersaliva
  • 5
  • 2
  • 2
9 Comments
 
LVL 49

Assisted Solution

by:Martin Liss
Martin Liss earned 1000 total points
ID: 41872827
Yes it is, but the easiest thing to do is to put all the controls on the form that you'll ever need making all except the ones that you want to see at the start hidden.
0
 
LVL 49

Assisted Solution

by:Martin Liss
Martin Liss earned 1000 total points
ID: 41872848
To do it dynamically you do something like this which assumes you have a userform with a textbox named txtOriginal and a command button named CommandButton1.

Private Sub CommandButton1_Click()
Controls.Add "Forms.Textbox.1", "txtNew", True
With Controls("txtNew")
    .Top = txtOriginal.Top + txtOriginal.Height + 20
    .Height = txtOriginal.Height
    .Width = txtOriginal.Width
    .Left = txtOriginal.Left
End With

End Sub

Open in new window

0
 
LVL 49

Assisted Solution

by:Martin Liss
Martin Liss earned 1000 total points
ID: 41872856
If you want to add events to the created controls it's a little more complicated, so let me know.
0
Concerto's Cloud Advisory Services

Want to avoid the missteps to gaining all the benefits of the cloud? Learn more about the different assessment options from our Cloud Advisory team.

 
LVL 22

Accepted Solution

by:
Roy Cox earned 1000 total points
ID: 41873463
This example adds a userform with TextBoxes and 4 buttons with their code. You can add other controls as you want.
Dynamic-UserForm.xlsm
0
 

Author Comment

by:hindersaliva
ID: 41873765
Roy, that's perfect :)
Thanks Martin. It helped too.
0
 
LVL 22

Expert Comment

by:Roy Cox
ID: 41874312
Pleased to help
0
 
LVL 49

Expert Comment

by:Martin Liss
ID: 41874370
You're welcome and I'm glad I was able to help.

If you expand the “Full Biography” section of my profile you'll find links to some articles I've written that may interest you.

Marty - Microsoft MVP 2009 to 2016
              Experts Exchange MVE 2015
              Experts Exchange Top Expert Visual Basic Classic 2012 to 2015
0
 

Author Comment

by:hindersaliva
ID: 41874408
Some really good stuff there Martin. Thanks.
0
 
LVL 49

Expert Comment

by:Martin Liss
ID: 41874428
Thanks.
0

Featured Post

What does it mean to be "Always On"?

Is your cloud always on? With an Always On cloud you won't have to worry about downtime for maintenance or software application code updates, ensuring that your bottom line isn't affected.

Question has a verified solution.

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

You need to know the location of the Office templates folder, so that when you create new templates, they are saved to that location, and thus are available for selection when creating new documents.  The steps to find the Templates folder path are …
This article describes how you can use Custom Document Properties to store settings and other information in your workbook so that they will be available the next time you open the workbook.
This Micro Tutorial demonstrates using Microsoft Excel pivot tables, how to reverse engineer competitors' marketing strategies through backlinks.
Although Jacob Bernoulli (1654-1705) has been credited as the creator of "Binomial Distribution Table", Gottfried Leibniz (1646-1716) did his dissertation on the subject in 1666; Leibniz you may recall is the co-inventor of "Calculus" and beat Isaac…

916 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