WPF CheckListBox


WPF CheckListBox

As a part of Visual Studio 2010, Windows Presentation Foundation (WPF) does not have a CheckListBox control. A CheckListBox is a combination of ListBox with each item being a CheckBox.  You may want to read WPF ListBox and WPF CheckBox articles to understand these controls better. 

This article demonstrates how to use the CheckListBox control in a WPF application using C# and XAML. 

Adding Reference to WPF Toolkit Extended Assembly

The CheckListBox control is a part of the WPF Toolkit Extended and does not come with Visual Studio 2010. To use the ButtonSpinner control in your application, you must add reference to the WPFToolkit.Extended.dll assembly. You can download Extended WPF Tookit from the CodePlex or you can use the WPFToolkit.Extended.dll available with this download. All you need is the DLL. See Downloads section of this article. You can find more details in my blog Adding Reference to WPF Toolkit Extended.

 

Sample code

See the attached file in the Downloads area.

Introduction

The CheckListBox tag represents a CheckListBox control in XAML.

 

<CheckListBox></CheckListBox>

 

The Width and Height properties represent the width and the height of the CheckListBox.  The Name property represents the name of the control, which is a unique identifier of a control. The Margin property tells the location of the CheckListBox on the parent control. The HorizontalAlignment and VerticalAlignment properties are used to set horizontal and vertical alignments.

 

The following code snippet sets the name, height, and width of a CheckListBox control.  The code also sets horizontal alignment to left and vertical alignment to top.

 

<wpfx:CheckListBox Name="CheckListBox1" Margin="12,12,0,0"

                    HorizontalAlignment="Left"

            VerticalAlignment="Top" Height="134" Width="156" />

 

Adding CheckListBox Items

A CheckListBox control hosts a collection of CheckListBoxItem. The following code snippet adds items to a CheckListBox control.

<wpfx:CheckListBox Name="CheckListBox1" Margin="12,12,0,0"

            HorizontalAlignment="Left"

    VerticalAlignment="Top" Height="134" Width="156">

    <wpfx:CheckListBoxItem>C# Corner</wpfx:CheckListBoxItem>

    <wpfx:CheckListBoxItem>VB.NET Heaven</wpfx:CheckListBoxItem>

    <wpfx:CheckListBoxItem>DB Talks</wpfx:CheckListBoxItem>

    <wpfx:CheckListBoxItem>SharePoint Talks</wpfx:CheckListBoxItem>

    <wpfx:CheckListBoxItem>Longhorn Corner</wpfx:CheckListBoxItem>           

</wpfx:CheckListBox>

 

The above code generates Figure 1.

WPFCheckBoxList1.jpg
Figure 1

Adding CheckListBox Items Dynamically

Let's change our UI and add a TextBox and a Button control to the window. The following code snippet adds a TextBox and a Button control to the window. I also add a click button event handler.

<TextBox Height="33" HorizontalAlignment="Left" Margin="18,6,0,0"

            Name="AddTextBox" VerticalAlignment="Top" Width="129" />

<Button Content="Add Item" Height="33" HorizontalAlignment="Left" Margin="162,9,0,0"

        Name="AddButton" VerticalAlignment="Top" Width="83" Click="AddButton_Click" />

 

The final UI looks like Figure 2.

WPFCheckBoxList2.jpg
Figure 2

On the button click event handler, we add the content of the TextBox to the CheckListBox by calling CheckListBox.Items.Add method. The following code adds the TextBox contents to the CheckListBox items.

private void AddButton_Click(object sender, RoutedEventArgs e)

{

    CheckListBox1.Items.Add(AddTextBox.Text);

}

 

You can enter any text in the TextBox and use Add Item to add it to the CheckBoxList items.

WPFCheckBoxList3.jpg
Figure 3

Getting Checked Items

The CheckedItem property returns the recently checked item.

CheckListBoxItem item = (CheckListBoxItem)CheckListBox1.CheckedItem;

 

The CheckedItems property returns all checked items.

foreach (CheckListBoxItem item in CheckListBox1.CheckedItems)

   

Deleting CheckListBox Items

We can use Remove method of Items collection to remove an item from the list. The following code snippet deletes the recently checked item.

CheckListBoxItem item = (CheckListBoxItem)CheckListBox1.CheckedItem;

string str = (string)item.Content;

if (item != null)

    CheckListBox1.Items.Remove(item);

 

The following code snippet loops through all the checked items and removes them.

 

foreach (CheckListBoxItem item in CheckListBox1.CheckedItems)

    CheckListBox1.Items.Remove(item);       

 

Summary

In this article, I discussed how to use a CheckListBox control available in WPF. Most of the functionality of CheckListBox works almost same way as WPF ListBox.  I recommend you read WPF ListBox to learn more.

 
 


Mindcracker
Founded in 2003, Mindcracker is the authority in custom software development and innovation. We put best practices into action. We deliver solutions based on consumer and industry analysis.