Como: Determinar itens verificados no controle CheckedListBox do Windows Forms
Ao apresentar dados num controlo CheckedListBox do Windows Forms, pode-se percorrer a coleção armazenada na propriedade CheckedItems ou percorrer a lista usando o método GetItemChecked para identificar quais são os itens marcados. O método GetItemChecked usa um número de índice de item como argumento e retorna true
ou false
. Ao contrário do que você poderia esperar, as propriedades SelectedItems e SelectedIndices não determinam quais itens serão verificados; eles determinam quais itens são destacados.
Para determinar os itens verificados em um controle CheckedListBox
Itere através da coleção CheckedItems, começando em 0, uma vez que a coleção é baseada em zero. Observe que esse método fornecerá o número do item na lista de itens verificados, não a lista geral. Portanto, se o primeiro item da lista não for verificado e o segundo item for verificado, o código abaixo exibirá texto como "Item verificado 1 = MyListItem2".
' Determine if there are any items checked. If CheckedListBox1.CheckedItems.Count <> 0 Then ' If so, loop through all checked items and print results. Dim x As Integer Dim s As String = "" For x = 0 To CheckedListBox1.CheckedItems.Count - 1 s = s & "Checked Item " & (x + 1).ToString & " = " & CheckedListBox1.CheckedItems(x).ToString & ControlChars.CrLf Next x MessageBox.Show(s) End If
// Determine if there are any items checked. if(checkedListBox1.CheckedItems.Count != 0) { // If so, loop through all checked items and print results. string s = ""; for(int x = 0; x < checkedListBox1.CheckedItems.Count ; x++) { s = s + "Checked Item " + (x+1).ToString() + " = " + checkedListBox1.CheckedItems[x].ToString() + "\n"; } MessageBox.Show(s); }
// Determine if there are any items checked. if(checkedListBox1->CheckedItems->Count != 0) { // If so, loop through all checked items and print results. String ^ s = ""; for(int x = 0; x < checkedListBox1->CheckedItems->Count; x++) { s = String::Concat(s, "Checked Item ", (x+1).ToString(), " = ", checkedListBox1->CheckedItems[x]->ToString(), "\n"); } MessageBox::Show(s); }
- ou -
Percorra a coleção Items, começando em 0, já que a coleção é baseada em zero, e chame o método GetItemChecked para cada item. Observe que esse método lhe dará o número do item na lista geral, portanto, se o primeiro item da lista não for verificado e o segundo item for verificado, ele exibirá algo como "Item 2 = MyListItem2".
Dim i As Integer Dim s As String s = "Checked Items:" & ControlChars.CrLf For i = 0 To (CheckedListBox1.Items.Count - 1) If CheckedListBox1.GetItemChecked(i) = True Then s = s & "Item " & (i + 1).ToString & " = " & CheckedListBox1.Items(i).ToString & ControlChars.CrLf End If Next MessageBox.Show(s)
int i; string s; s = "Checked items:\n" ; for (i = 0; i <= (checkedListBox1.Items.Count-1); i++) { if (checkedListBox1.GetItemChecked(i)) { s = s + "Item " + (i+1).ToString() + " = " + checkedListBox1.Items[i].ToString() + "\n"; } } MessageBox.Show (s);
int i; String ^ s; s = "Checked items:\n" ; for (i = 0; i <= (checkedListBox1->Items->Count-1); i++) { if (checkedListBox1->GetItemChecked(i)) { s = String::Concat(s, "Item ", (i+1).ToString(), " = ", checkedListBox1->Item[i]->ToString(), "\n"); } } MessageBox::Show(s);
Ver também
.NET Desktop feedback