C#: Add Select All, Deselect All Checkbox In Column Header In DataGridView Control


Adding controls to your DataGridView like a checkbox as a column is possible with the use of the DataGridViewCheckboxColumn class. This post assumes that you are using the DataGridView control in a Windows.Form application and that your gridview object can already populate data into it. The purpose of this post is to add a column containing checkboxes including a header checkbox, used to select and deselect all in one click.

The name of our DataGridView control is list. To add a checkbox column into the gridview control, use the following code below inside your className_Load() method.

?View Code CSHARP
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
// customize dataviewgrid, add checkbox column
DataGridViewCheckBoxColumn checkboxColumn = new DataGridViewCheckBoxColumn();
checkboxColumn.Width = 30;
checkboxColumn.DefaultCellStyle.Alignment = DataGridViewContentAlignment.MiddleCenter;
list.Columns.Insert(0, checkboxColumn);
 
// add checkbox header
Rectangle rect = list.GetCellDisplayRectangle(0, -1, true);
// set checkbox header to center of header cell. +1 pixel to position correctly.
rect.X = rect.Location.X + (rect.Width / 4);
 
CheckBox checkboxHeader = new CheckBox();
checkboxHeader.Name = "checkboxHeader";
checkboxHeader.Size = new Size(18, 18);
checkboxHeader.Location = rect.Location;
checkboxHeader.CheckedChanged += new EventHandler(checkboxHeader_CheckedChanged);
 
list.Controls.Add(checkboxHeader);

The method that does the selecting and deselecting of all checkboxes within the checkbox column is made possible with the CheckedChanged event. We add an event handler for this to make it work.

?View Code CSHARP
1
2
3
4
5
6
private void checkboxHeader_CheckedChanged(object sender, EventArgs e) {
    for (int i = 0; i < list.RowCount; i++) {
	list[0, i].Value = ((CheckBox) list.Controls.Find("checkboxHeader", true)[0]).Checked;
    }
    list.EndEdit();
}

That’s all there is to it. If you may wonder how to make the checkbox header align to the center, the code that makes that happen is the part where there is a Rectangle object used.

?View Code CSHARP
1
2
3
4
// add checkbox header
Rectangle rect = list.GetCellDisplayRectangle(0, -1, true);
// set checkbox header to center of header cell. +1 pixel to position correctly.
rect.X = rect.Location.X + (rect.Width4);

I divided the cell area’s width by 4 instead of 2 because I had to take into account the checkbox header’s width value. By the way, you also need to set the DataGridView control’s AutoSizeColumnsMode property to Fill so that all any empty spaces within the DataGridView control will be occupied

Donations appreciated. Every little $ helps. Or click Google +1

Related Posts with Thumbnails

20 Responses to “C#: Add Select All, Deselect All Checkbox In Column Header In DataGridView Control”

Pages: « 1 2 [3] 4 » Show All

  1. 11
    tech Says:

    @merill: thanks for that tip

  2. 12
    mohammed Says:

    hi,
    nice articles i have a question. what should be code in c# .net when gridview1 column5 data is the same as the gridview2 column2 data, now when the gridview1 column edit index change edit button is clicked, the edit index should check all the column2 values in the gridview2 and if matches the corresponding column value should be checked……………….please help me how to do this……….i am punished for not doing this……………..plz

  3. 13
    james Says:

    This is great but what if I want to check only 1 or more checkbox?

  4. 14
    tech Says:

    just use the same code and modify it. since the code loops through all checkboxes, you can change it when the checkbox index number matches the one you want to select/deselect

  5. 15
    james Says:

    Perfect. Thank you.

Pages: « 1 2 [3] 4 » Show All

Leave a Reply

Spam protection by WP Captcha-Free