Solved

VBA AddHandler????

Posted on 2011-02-21
11
1,979 Views
Last Modified: 2012-08-14
If I add a checkbox via code at run-time, how can add code to fire when the user clicks on it?

In VB.net I would use addhandler, but I know this isnt what I need to do with VBA.

Reading up, I thought I could just use chkNew.onClick myMethod(), but that doesnt work either.

Does anyone have an exampe of how to add a handler to a CheckBox in VBA?

Thank you
0
Comment
Question by:tonelm54
  • 6
  • 5
11 Comments
 
LVL 85

Expert Comment

by:Rory Archibald
Comment Utility
What kind of checkbox (Forms or ActiveX), and where are you adding it?
0
 
LVL 85

Expert Comment

by:Rory Archibald
Comment Utility
If it's Forms, then you set its OnAction property to the name of the macro you want to run.
0
 

Author Comment

by:tonelm54
Comment Utility
I'm using MSForms.CheckBox, but looking at the intellisence there is no inaction property I can assign my macro to. I need to be able to add it by code.
0
 
LVL 85

Expert Comment

by:Rory Archibald
Comment Utility
Where are you adding it to? A Userform or a worksheet?
0
 
LVL 85

Expert Comment

by:Rory Archibald
Comment Utility
(that's not, oddly, the Forms control I was referring to)
0
What Security Threats Are You Missing?

Enhance your security with threat intelligence from the web. Get trending threat insights on hackers, exploits, and suspicious IP addresses delivered to your inbox with our free Cyber Daily.

 

Author Comment

by:tonelm54
Comment Utility
It's a userform

Thank you
0
 
LVL 85

Expert Comment

by:Rory Archibald
Comment Utility
In that case, your best bet is to use a class with a Checkbox variable declared WithEvents and put your Click code in that. Then as you add each checkbox, create an instance of the class, assign the checkbox to the class's variable and then add the class instance to a Collection (declared at module level in the userform).
Do you need sample code for that?
0
 

Author Comment

by:tonelm54
Comment Utility
Err, do you have any sample code for that? Sounds a very complex way of doing a simple task :-S
0
 

Author Comment

by:tonelm54
Comment Utility
My code I currently have is:-
0
 

Author Comment

by:tonelm54
Comment Utility
ok, this time I attach the code!!!

Private Sub UserForm_Activate()
      Dim newCheckBox  As MSForms.CheckBox
        
        Set newCheckBox = Frame1.Controls.Add("Forms.CheckBox.1")
        newCheckBox.Caption = "Hello " & x
        newCheckBox.Top = x * 30
        newCheckBox.Left = 10
        
        newCheckBox.OnAction = "Checkbox_Toggle"
                
        Frame1.Controls.Add newCheckBox
End Sub

Open in new window


Sorry!
0
 
LVL 85

Accepted Solution

by:
Rory Archibald earned 500 total points
Comment Utility
Class module called CheckboxHandler:
Option Explicit

Public WithEvents cb As MSForms.CheckBox

Private Sub cb_Click()
   MsgBox "You clicked checkbox: " & cb.Name
End Sub

Open in new window


Userform code:
Option Explicit

Dim colCBHandlers As Collection

Private Sub UserForm_Activate()
   Dim objHandler As CheckboxHandler
 Dim x As Integer
   Set colCBHandlers = New Collection
   
    For x = 1 To 100 Step 1
        Dim newCheckBox  As MSForms.CheckBox
        Set newCheckBox = Me.Frame1.Controls.Add("Forms.CheckBox.1")
        newCheckBox.Caption = "Hello " & x
        newCheckBox.Top = x * 30
        newCheckBox.Left = 10
        ' create new handler
        Set objHandler = New CheckboxHandler
        ' assign checkbox
        Set objHandler.cb = newCheckBox
        colCBHandlers.Add objHandler
    Next x

End Sub

Open in new window

0

Featured Post

How to run any project with ease

Manage projects of all sizes how you want. Great for personal to-do lists, project milestones, team priorities and launch plans.
- Combine task lists, docs, spreadsheets, and chat in one
- View and edit from mobile/offline
- Cut down on emails

Join & Write a Comment

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…
You can of course define an array to hold data that is of a particular type like an array of Strings to hold customer names or an array of Doubles to hold customer sales, but what do you do if you want to coordinate that data? This article describes…
This Micro Tutorial demonstrates how to create Excel charts: column, area, line, bar, and scatter charts. Formatting tips are provided as well.
This Micro Tutorial will demonstrate in Google Sheets how to use the HYPERLINK function to create live links inside your spreadsheet.

771 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

Need Help in Real-Time?

Connect with top rated Experts

10 Experts available now in Live!

Get 1:1 Help Now