Input Parameters


Calling the Same Macro

You might want to include a button that can be used as a toggle.
For example the following button can be used to toggle between sorting ascending and descending.

objbutton = objcommandbar.controls.Add (Type:=msoControlType.msoControlButton, _ 
                                        Parameter="Asc")
objbutton.OnAction = "SortList"
objbutton.Caption = "Sort Ascending"

objbutton = objcommandbar.controls.Add (Type:=msoControlType.msoControlButton, _
                                        Parameter="Dsc")
objbutton.OnAction = "SortList"
objbutton.Caption = "Sort Descending"

Public Sub SortList 
Dim iascdsc As Integer
   Select Case CommandBars.ActionControl.Parameter
      Case "Asc" : iascdsc = xlAscending
      Case "Dsc" : iascdsc = xlDescending
   End Select
   Range("A1:B20").Sort Key1:=Range("A1"), Order:=iascdsc, Header:=xlNo
End Sub

Passing Parameter Values

For simple VBA macros you can use the Parameter and Tag properties to store information to be passed to the OnAction macro.
If you have more than two items of information to pass it is more convenient to use a macro procedure that has input parameters.
For example if you wanted to pass a product name, cost and selling price to the following macro.

Public Sub ShowProductName(ByVal sProductName As String, _ 
                           ByVal dCost As Double, _
                           ByVal dPrice As Double)

End Sub

To execute this macro from a commandbar you need to assign the following code to the OnAction property of the control.

'ShowProduct "Product", 10, 20'

The entire expression is enclosed in single quotes.
Any string parameter values within the expression are enclosed in double quotes

objbutton.OnAction = "'ShowProduct ""Product"", 10, 20'" 

© 2025 Better Solutions Limited. All Rights Reserved. © 2025 Better Solutions Limited TopPrevNext