Radio Button in VB.NET

A RadioButton control provides a round interface to select one option from a number of options. Radio buttons are usually placed in a group on a container control such as a Panel or a GroupBox and one of them is selected.
  • 20137

A RadioButton control provides a round interface to select one option from a number of options. Radio buttons are usually placed in a group on a container control such as a Panel or a GroupBox and one of them is selected.

Creating a RadioButton

We can create a RadioButton control using a Forms designer at design-time or using the RadioButton class in code at run-time (also known as dynamically).

To create a RadioButton control at design-time, you simply drag and drop a RadioButton control from Toolbox to a Form in Visual Studio. After you drag and drop a RadioButton on a Form, the RadioButton looks like Figure 1. Once a RadioButton is on the Form, you can move it around and resize it using mouse and set its properties and events.



Figure 1

Creating a RadioButton control at run-time is merely work of creating an instance of RadioButton class, set its properties and add RadioButton class to the Form controls.

First step to create a dynamic RadioButton is to create an instance of RadioButton class. The following code snippet creates a RadioButton control object.

Dim dynamicRadioButton As New RadioButton()

In the next step, you may set properties of a RadioButton control. The following code snippet sets location, width, height, background color, foreground color, Text, Name, and Font properties of a RadioButton.

dynamicRadioButton.Left = 20

dynamicRadioButton.Top = 100

dynamicRadioButton.Width = 300

dynamicRadioButton.Height = 30

dynamicRadioButton.BackColor = Color.Orange

dynamicRadioButton.ForeColor = Color.Black

dynamicRadioButton.Text = "I am a Dynamic RadioButton"

dynamicRadioButton.Name = "DynamicRadioButton"

dynamicRadioButton.Font = New Font("Georgia", 12)

Once a RadioButton control is ready with its properties, next step is to add the RadioButton control to the Form. To do so, we use Form.Controls.Add method. The following code snippet adds a RadioButton control to the current Form.


New RadioButton created by the above code looks like Figure 2.



Figure 2

Setting RadioButton Properties

After you place a RadioButton control on a Form, the next step is to set properties.

The easiest way to set properties is from the Properties Window. You can open Properties window by pressing F4 or right click on a control and select Properties menu item. The Properties window looks like Figure 3.


Figure 3

Location, Height, Width, and Size

The Location property takes a Point that specifies the starting position of the RadioButton on a Form. You may also use Left and Top properties to specify the location of a control from the left top corner of the Form.  The Size property specifies the size of the control. We can also use Width and Height property instead of Size property. The following code snippet sets Location, Width, and Height properties of a RadioButton control.

dynamicRadioButton.Location = New Point(20, 150)

dynamicRadioButton.Height = 40

dynamicRadioButton.Width = 300

Background, Foreground, BorderStyle

BackColor and ForeColor properties are used to set background and foreground color of a RadioButton respectively. If you click on these properties in Properties window, the Color Dialog pops up.

Alternatively, you can set background and foreground colors at run-time. The following code snippet sets BackColor and ForeColor properties.

dynamicRadioButton.BackColor = Color.Red

dynamicRadioButton.ForeColor = Color.Blue


Name property represents a unique name of a RadioButton control. It is used to access the control in the code. The following code snippet sets and gets the name and text of a RadioButton control.

dynamicRadioButton.Name = "DynamicRadioButton"

Text and TextAlign

Text property of a RadioButton represents the current text of a RadioButton control. The TextAlign property represents text alignment that can be Left, Center, or Right. The following code snippet sets the Text and TextAlign properties and gets the size of a RadioButton control.

dynamicRadioButton.Text = "I am a Dynamic RadioButton"

dynamicRadioButton.TextAlign = ContentAlignment.MiddleCenter 


Font property represents the font of text of a RadioButton control. If you click on the Font property in Properties window, you will see Font name, size and other font options. The following code snippet sets Font property at run-time.

dynamicRadioButton.Font = nNw Font("Georgia", 16)

Read RadioButton Contents

The simplest way of reading a RadioButton control contents is using the Text property. The following code snippet reads contents of a RadioButton in a string.

Dim RadioButtonContents As String = dynamicRadioButton.Text


Appearance property of RadioButton can be used to set the appearance of a RadioButton to a Button or a RadioButton. The Button look does not have a round select option. The following property makes a RadioButton look like a Button control.

dynamicRadioButton.Appearance = Appearance.Button

Check Mark Alignment

CheckAlign property is used to align the check mark in a RadioButton. By using CheckAlign and TextAlign properties, we can place text and check mark to any position on a RadioButton we want. The following code snippet aligns radio button round circle and text to middle-right and creates a RadioButton that looks like Figure 4.

dynamicRadioButton.CheckAlign = ContentAlignment.MiddleRight

dynamicRadioButton.TextAlign = ContentAlignment.MiddleRight



Figure 4      


An ellipsis character (...) is used to give an impression that a control has more characters but it could not fit in the current width of the control. If AutoEllipsis property is true, it adds ellipsis character to a control if text in control does not fit. You may have to set AutoSize to false to see the ellipses character. The following code snippet sets the AutoEllipsis property of a RadioButton to true.

dynamicRadioButton.AutoEllipsis = True

Figure 5 shows a RadioButton when AutoEllipsis is true and contents does not fit in the given width of the control.



Figure 5

Image in RadioButton

The Image property of a RadioButton control is used to set the background as an image. The Image property needs an Image object. The Image class has a static method called FromFile that takes an image file name with full path and creates an Image object.

You can also align image and text. The ImageAlign and TextAlign properties of RadioButton are used for this purpose.

The following code snippet sets an image as a RadioButton background.

dynamicRadioButton.Image = Image.FromFile("C:\Images\Dock.jpg")

dynamicRadioButton.ImageAlign = ContentAlignment.MiddleRight

dynamicRadioButton.FlatStyle = FlatStyle.Flat

RadioButton States

A typical RadioButton control has two possible states â€" Checked and Unchecked. Checked state is when the RadioButton has check mark on and Unchecked is when the RadioButton is not checked. Typically, we use a mouse to check or uncheck a RadioButton.

Checked property is true when a RadioButton is in checked state.

dynamicRadioButton.Checked = True

Usually, we check if a RadioButton is checked or not and decide to take an action on that state something like following code snippet.

If (dynamicRadioButton.Checked) Then


End If

AutoCheck property represents whether the Checked or CheckState values and the RadioButton's appearance are automatically changed when the RadioButton is clicked. By default this property is true but if set to false.

dynamicRadioButton.AutoCheck = False

RadioButton Checked Event Hander

CheckedChanged event occurs when the value of the Checked property changes. To add this event handler, you go to Events window and double click on CheckedChanged events as you can see in Figure 6.



Figure 6


The following code snippet defines and implements these events and their respective event handlers. You can write this code to implement CheckedChanged event dynamically.

Friend WithEvents RadioButton1 As System.Windows.Forms.RadioButton         

Private Sub RadioButton1_CheckedChanged(ByVal sender As System.Object, ByVal e As System.EventArgs) _

        Handles RadioButton1.CheckedChanged

End Sub


In this article, we discussed discuss how to create a RadioButton control in Windows Forms at design-time as well as run-time. After that, we saw how to use various properties and methods.


More Articles

© 2020 DotNetHeaven. All rights reserved.