Как обновить привязанный DataGridView при щелчке флажка


Цель

Мне нужен способ задать элементы как завершенные , нажав на CheckBox в моей привязке DataGridView. Как только это будет сделано, элемент больше не будет виден из DataGridView из-за фильтра строк DataView.


Объяснение

У меня есть DataGridView, который связан с DataView.

Private Sub LoadLispImprovements()
    Private ViewLispImprovements As New DataView
    ViewLispImprovements.Table = Programs.Tables("dtLispImprovements")
    ViewLispImprovements.RowFilter = "Completed=0"
    Lisp_dgvImprovements.DataSource = ViewLispImprovements
End Sub

Эта таблица DataView была установлена на следующий DataTable:

DataTable, показывающий первичный ключ и логическое значение (красным цветом)

Этот DataTable имеет свой первичный ключ, установленный в правильное поле. Поле Completed имеет красный квадрат просто чтобы показать вам, ребята, что я установил его как логическое значение.

Взгляните на мой DataGridView:

DataGridView, отображающий результат привязки элементов

Вот где я бы нажал на флажок, и элемент должен быть отфильтрован (потому что флажок ShowAll не установлен)


Задача

Когда я нажимаю на CheckBox, Элемент остается в DataGridView. Чтобы отфильтровать его, я должен выбрать другую строку. Взгляните:

Улучшение проверяется, но остается в ДГВ

И когда я меняю строки, это наконец уходит:

Улучшение было отфильтровано, но только когда я попытался выбрать другую строку

Как заставить его удалиться сразу же после того, как я установил флажок завершено?

P. S: Да, у меня есть обработчик событий CurrentCellDirtyStateChanged.

Private Sub Lisp_dgvImprovements_CurrentCellDirtyStateChanged(sender As Object, e As System.EventArgs) Handles Lisp_dgvImprovements.CurrentCellDirtyStateChanged
    If Lisp_dgvImprovements.IsCurrentCellDirty Then
        Lisp_dgvImprovements.CommitEdit(DataGridViewDataErrorContexts.Commit)
    End If
End Sub
1 5

1 ответ:

Этого можно добиться, закончив редактирование DataRow при изменении значения ячейки.

Private Sub Lisp_dgvImprovements_CurrentCellDirtyStateChanged(sender As Object, e As System.EventArgs) Handles Lisp_dgvImprovements.CurrentCellDirtyStateChanged
    If (Me.Lisp_dgvImprovements.IsCurrentCellDirty) Then
        Me.Lisp_dgvImprovements.CommitEdit(DataGridViewDataErrorContexts.Commit)
    End If
End Sub

Private Sub Lisp_dgvImprovements_CellValueChanged(sender As System.Object, e As System.Windows.Forms.DataGridViewCellEventArgs) Handles Lisp_dgvImprovements.CellValueChanged
    '                    |-- The index of boolean DataGridViewColumn
    If ((e.ColumnIndex = 0) AndAlso (e.RowIndex > -1)) Then
        With Me.Lisp_dgvImprovements.Rows(e.RowIndex)
            If (Not .IsNewRow) Then
                With DirectCast(.DataBoundItem, DataRowView).Row
                    '     |-- The index of boolean DataColumn
                    .Item(0) = True
                    .EndEdit()
                End With
            End If
        End With
    End If
End Sub