Click here to Skip to main content
Licence CPOL
First Posted 24 Jul 2006
Views 142,695
Bookmarked 50 times

Bindable CheckedListBox

By | 24 Jul 2006 | Article
In this article you will see how to bind a CheckedListBox to the data source and use features of multiple selection with data binding.

Sample Image - ExCheckedListBox1.jpg

Introduction

It seems that the .NET CheckedListBox even doesn't have primary binding facilities exists in the ListBox and ComboBox, because it must save multiple values in the database. Current article introducing an extended CheckedListBox that has a single property for setting and getting checked items, and also has binding facilities.

Problems

  • .NET CheckedListBox doesn't have binding facilities.
  • Because CheckedListBox works with an object collection it can't be bound to a data source.
  • CheckedListBox doesn't have a property representing whether item checked and it must be changed or getting data with Methods for one item or a collection of checked items hardly .

Needs

  • Creating a public bindable property that representing checked items and sets checked items based on it.
  • It must be one single property that when sets or gets it saves single primitive type value.
  • Items must be loaded from a data source (it could be lookup table) different from Value data source.
  • Because of list controls nature we must bind it to a column.

Using the code

A brief description of how to use the article or code. The class names, the methods and properties, any tricks or tips.

ExCheckedListBox

In the code samples major code belongs to ExCheckedListBox inherited from CheckedListBox of .NET framework.

It's extended CheckedListBox control and has three extra properties:

1. Value property:

This property is type of integer that brings ability to get and set checked item based on one single value. It works with bits in that integer, saves and retrieves values in single column.

get
{
    ///Gets checked items in decimal mode from binary mode
    
    try
    {
        //each item in list has a number that is binary number in decimal mode
        //this number represents that number
        int poweredNumber = 1;
        //loop in all items of list
        for (int i = 0; i < this.Items.Count; i++)
        {
            //if item checked and the value doesn't contains poweredNumber 
            //then add poweredNumber to the value
            if((this.GetItemChecked(i)))
                this.value |= poweredNumber;
            //else if poweredNumber exists in the value remove from it
            else if ((this.value & poweredNumber) != 0)
                this.value -= poweredNumber;

            //raise to the power
            poweredNumber *= 2;
        }
    }
    catch (ArgumentException ex)
    {
        throw ex;
    }
    catch (Exception ex)
    {
        throw ex;
    }


    return this.value;
}
set
{
    ///sets checked items from binary mode converted from decimal value

    this.value = value;
    try
    {
        //each item in list has a number that is binary number in decimal mode
        //this number represents that number
        int poweredNumber = 1;
        //loop in all items of list
        for (int i = 0; i < this.Items.Count; i++)
        {
            //if poweredNumber exists in the value set checked on item
            if ((this.value & poweredNumber) != 0)
                this.SetItemCheckState(i, CheckState.Checked);
            //else remove checked from item
            else
                this.SetItemCheckState(i, CheckState.Unchecked);

            //raise to the power
            poweredNumber *= 2;
        }
    }
    catch (ArgumentException ex)
    {
        throw ex;
    }
    catch (Exception ex)
    {
        throw ex;
    }


}

2. DataSource property:

This property is type of object that brings ability to get and set data source like other collection controls (ListBox and ComboBox). In reality it's base DataSource property used, but it hided in the .NET CheckedListBox because of CheckedListBox logic. So I hide it by new keyword and reused base DataSource protected property.

/// <summary>
/// Gets or sets the data source for this CustomControls.CheckedListBox.
/// Returns:
///    An object that implements the System.Collections.IList or 
//     System.ComponentModel.IListSource
///    interfaces, such as a System.Data.DataSet or an System.Array. The <BR>///    default is null.
///
///Exceptions:
///  System.ArgumentException:
///    The assigned value does not implement the System.Collections.IList or 
//     System.ComponentModel.IListSource
///    interfaces.
/// </summary>
[DefaultValue("")]
[AttributeProvider(typeof(IListSource))]
[RefreshProperties(RefreshProperties.All)]
[Browsable(true)]
public new object DataSource { 
    get 
    {
        return base.DataSource;
    }
    set 
    {
        base.DataSource = value;
        
    }
}

DataSource Property

3. DisplayMember property:

This property is type of string that brings ability to get and set data source specific column like other collection controls (ListBox and ComboBox).

In reality it's base DisplayMember property used, but it hided in the .NET CheckedListBox because of CheckedListBox logic.

So I hide it by new keyword and reused base DisplayMember protected property.

/// <summary>
///   Gets or sets the property to display for this <BR>///   CustomControls.CheckedListBox.
///
/// Returns:
///     A System.String specifying the name of an object property that is <BR>///     contained in the collection specified by the <BR>///     CustomControls.CheckedListBox.DataSource property. The default is <BR>///     an empty string ("").
/// </summary>
[DefaultValue("")]
[TypeConverter("System.Windows.Forms.Design.DataMemberFieldConverter, <BR>System.Design, 
Version=2.0.0.0, Culture=neutral, PublicKeyToken=b03f5f7f11d50a3a")]
[Editor("System.Windows.Forms.Design.DataMemberFieldEditor, System.Design, 
Version=2.0.0.0, Culture=neutral, PublicKeyToken=b03f5f7f11d50a3a", 
typeof(UITypeEditor))]
[Browsable(true)]
public new string DisplayMember
{
    get
    {
        return base.DisplayMember;
    }
    set
    {
        base.DisplayMember = value;
        
    }
}

Demo Project

Demo project contains a SQL Script that creates two tables:

Products and Cities that have the same scenario of (presented products in specified cities).

Points of Interest

I wanted to implement another scenario (Questions and Answers) In that scenario we must navigate questions and answer the tests with multiple answers but there is a problem with data binding and this scenario.

License

This article, along with any associated source code and files, is licensed under The Code Project Open License (CPOL)

About the Author

Hossein Ghahvei Araghi

Software Developer (Senior)
System Group
Iran (Islamic Republic Of) Iran (Islamic Republic Of)

Member

Hossein Ghahvei Araghi
Birth date: 1978
Birth place: Iran
Academic Credentials : BS(Tehran University)
Microsoft Credentials : MCP, MCAD, MCTS 2.0, MCTS 3.5, MCPD 2.0, MCPD 3.5

Sign Up to vote   Poor Excellent
Add a reason or comment to your vote: x
Votes of 3 or less require a comment

Comments and Discussions

 
You must Sign In to use this message board. (secure sign-in)
 
Search this forum  
 FAQ
    Noise  Layout  Per page   
  Refresh
Questionhttp://www.codeproject.com/Articles/14916/Bindable-CheckedListBox#_comments Pinmembermansoorttg5:01 28 May '12  
GeneralNew Simple Solution PinmemberAlejandro Diaz11:20 8 May '08  
QuestionRe: New Simple Solution PinmemberJosé Filipe Néis8:13 5 Jun '08  
GeneralGreat Work PinmemberUnRusoDeCaracas7:35 1 Apr '08  
GeneralAcceptChanges bug PinmemberRVW2:16 28 Feb '08  
QuestionCheckListBox PinmemberMember 234864116:21 26 Jan '08  
GeneralCheckedListBox does have Datasource, DisplayMember properties. PinmemberVB Prog9:57 18 Dec '07  
GeneralRe: CheckedListBox does have Datasource, DisplayMember properties. PinmemberAlejandro Rey11:43 7 Apr '08  
GeneralRe: CheckedListBox does have Datasource, DisplayMember properties. PinmemberSeema Gosain21:23 17 Jan '11  
GeneralVery nice, but... Pinmembershaybar6:44 25 Oct '07  
QuestionRe: Very nice, but... PinmemberRVW2:18 28 Feb '08  
AnswerRe: Very nice, but... Pinmembershaybar22:11 28 Feb '08  
GeneralRe: Very nice, but... Pinmembershaybar22:16 28 Feb '08  
GeneralBindable CheckedListbox Pinmemberedgardepuy6:09 7 Aug '07  
Generalvery good Pinmemberabdelrahman khaled farooq8:42 22 Apr '07  
QuestionGet stuck in control??? Pinmemberxtempore22:27 11 Mar '07  
QuestionHow can i get the VALUE and DISPLAY MEMBER for the checked items? Pinmemberkylai222:42 24 Feb '07  
QuestionWhy not use array or list as bound property? Pinmemberphilippe dykmans4:26 30 Nov '06  
AnswerRe: Why not use array or list as bound property? PinmemberHossein eraghi17:42 2 Dec '06  
GeneralRe: Why not use array or list as bound property? Pinmemberphilippe dykmans3:26 16 Dec '06  
GeneralVB.Net and additions PinmemberChris Kolkman6:10 10 Oct '06  
GeneralRe: VB.Net and additions PinmemberKarl Rhodes0:35 6 Mar '07  
GeneralRe: VB.Net and additions PinmemberGlimmerMan3:46 24 Sep '09  
Questionhow can i get the text of selected item PinmemberAmar Chaudhary13:29 30 Sep '06  
AnswerRe: how can i get the text of selected item [modified] Pinmemberkzimny8:01 29 Nov '06  
Hello, try this:
for (int i = 0; i < chkBoxListCategory.Items.Count; i++)
{
foreach (DataRow dtrCategory in ocomdrop.DTCategory.Rows)
{
string x = chkBoxListCategory.GetItemText(chkBoxListCategory.Items[i]);
bool y = chkBoxListCategory.GetItemChecked(i);
if (dtrCategory["CategoryName"].ToString() == x & y)
{
MessageBox.Show(y.ToString());
}
}
}
 
Bye, Christopher.
 
-- modified at 16:18 Wednesday 29th November, 2006

General General    News News    Suggestion Suggestion    Question Question    Bug Bug    Answer Answer    Joke Joke    Rant Rant    Admin Admin   

Use Ctrl+Left/Right to switch messages, Ctrl+Up/Down to switch threads, Ctrl+Shift+Left/Right to switch pages.

Permalink | Advertise | Privacy | Mobile
Web03 | 2.5.120529.1 | Last Updated 24 Jul 2006
Article Copyright 2006 by Hossein Ghahvei Araghi
Everything else Copyright © CodeProject, 1999-2012
Terms of Use
Layout: fixed | fluid