Button Array in Visual Basic 2008

Posted on 2008-10-27
Last Modified: 2013-11-26
How to I add buttons to an array.  I have 42 buttons on a form labeled btn1 through btn42.  I want to use a loop to add the buttons to an array.  I can add them one at a time
button(0) = me.btn1
button(1) = me.btn2
button(2) = me.btn3 and so on.

I can use a subscript for the button variable in a loop but how do I increment through the btn1 through btn42?
Once I get the buttons in an array, it will be much easier to write code to deal with the button presses.  Thank you for any information you can give me.
Question by:don_rowlett
Welcome to Experts Exchange

Add your voice to the tech community where 5M+ people just like you are talking about what matters.

  • Help others & share knowledge
  • Earn cash & points
  • Learn & ask questions
  • 2
  • 2
  • 2
  • +1

Expert Comment

ID: 22817988
Use Me.FindControl.
For i=0 To 41
   buttonArr(i) = CType(Me.FindControl("btn" & i), Button)

Open in new window

LVL 86

Expert Comment

by:Mike Tomlinson
ID: 22818009
Are you working with WebForms or WinForms?...

Generally it's easier to use multiple Handles clauses or use AddHandler() to wire up the buttons instead of creating an actual array.  Are you coming from VB6?...

Author Comment

ID: 22818037
I am using 2008 and winforms.
Industry Leaders: We Want Your Opinion!

We value your feedback.

Take our survey and automatically be enter to win anyone of the following:
Yeti Cooler, Amazon eGift Card, and Movie eGift Card!

LVL 48

Expert Comment

ID: 22818402
You can use a generics list to add all the buttons as an array.
Dim button As New List(Of Button)
' Then you can use
button(1).Enabled = False ' Disables the button 2

Open in new window

LVL 48

Assisted Solution

jpaulino earned 200 total points
ID: 22818416
To use an increment you can do (check snippet)
BUT I have to agree with Idle_Mind. This is VB6 way and .NET offers better handlings.

        For x As Byte = 1 To 42
            Dim ctrl() As Control = Controls.Find("Button" & x, True)
            If ctrl.Length = 1 Then
                Dim btn As Button = DirectCast(ctrl(0), Button)
                btn.Enabled = False
            End If

Open in new window

LVL 86

Accepted Solution

Mike Tomlinson earned 300 total points
ID: 22818433
Here is how I would do it with that many buttons:
Public Class Form1
    Private Sub Form1_Load(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles MyBase.Load
        Dim btn As Button
        Dim matches() As Control
        For i As Integer = 1 To 42
            matches = Me.Controls.Find("btn" & i, True)
            If matches.Length > 0 AndAlso TypeOf matches(0) Is Button Then
                btn = DirectCast(matches(0), Button)
                AddHandler btn.Click, AddressOf btn_Click
            End If
    End Sub
    Private Sub btn_Click(ByVal sender As System.Object, ByVal e As System.EventArgs)
        Dim btn As Button = DirectCast(sender, Button)
        Dim index As Integer = Integer.Parse(btn.Name.Substring(3))
        MessageBox.Show("Click: " & btn.Name & vbCrLf & "Index: " & index)
    End Sub
End Class

Open in new window


Author Closing Comment

ID: 31510576
Thank you very much for your help.  The final solution works great.  I really like the way you added every button to the button click event.

Featured Post

Free Tool: Path Explorer

An intuitive utility to help find the CSS path to UI elements on a webpage. These paths are used frequently in a variety of front-end development and QA automation tasks.

One of a set of tools we're offering as a way of saying thank you for being a part of the community.

Question has a verified solution.

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

Many of us here at EE write code. Many of us write exceptional code; just as many of us write exception-prone code. As we all should know, exceptions are a mechanism for handling errors which are typically out of our control. From database errors, t…
Today I had a very interesting conundrum that had to get solved quickly. Needless to say, it wasn't resolved quickly because when we needed it we were very rushed, but as soon as the conference call was over and I took a step back I saw the correct …
Attackers love to prey on accounts that have privileges. Reducing privileged accounts and protecting privileged accounts therefore is paramount. Users, groups, and service accounts need to be protected to help protect the entire Active Directory …

734 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