Как изменить положение строки виртуального режима DataGridView?

StackOverflow https://stackoverflow.com/questions/419980

Вопрос

Как изменить положение строки в виртуальном режиме DataGridView?

Я использую Windows Forms .

Это было полезно?

Решение

Ответ Маркуса верен, но вам также может потребоваться установить текущее свойство ячейки DataGridView ...

dgv.CurrentCell = dgv.Rows[0].Cells[0];

Я верю, что это прокрутит сетку. Кроме того, чтобы быть абсолютно безопасным, вы можете добавить это перед другой строкой кода ...

dgv.CurrentCell = null;

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

Другие советы

Вы должны очистить старую позицию и установить новую

Коллекция dataGridView1.SelectedRows содержит текущие выбранные строки. В зависимости от свойства MultiSelect сетки, вам может потребоваться перебрать все строки в SelectedRows и пометить их как невыбранные. Если вы используете режим одиночного выбора, просто установка новой строки в качестве выбранной должна очистить старый выбор.

Чтобы выбрать конкретную строку (в данном случае ту, которая имеет индекс 0), просто добавьте строку    dataGridView1.Rows [0] .Selected = true;

Похоже, вам требуется не только установка выбранной строки, но и отображаемой строки. Вы можете получить доступ к последнему с помощью свойства FirstDisplayedScrollingRowIndex в DataGridView. Одна из полезных настроек:

int lastShown = FirstDisplayedScrollingRowIndex + DisplayedRowCount(false) - 2;

if (lastShown < yourIndex)
  FirstDisplayedScrollingRowIndex += yourIndex - lastShown;
else if (FirstDisplayedScrollingRowIndex > yourIndex)
  FirstDisplayedScrollingRowIndex = yourIndex;

будет гарантировать, что выбранная вами строка не исчезнет с экрана при программной прокрутке вверх / вниз.

Else
        If i = rowcount Then
            Me.GridSaleItem.CurrentCell = Me.GridSaleItem.Rows(i - 1).Cells(0)
            Me.GridSaleItem.Rows(i - 1).Selected = True
        End If
    End If
Next
Private Sub GridSaleItem_SelectionChanged(ByVal sender As Object, ByVal e As System.EventArgs) Handles GridSaleItem.SelectionChanged
    Dim rowcount As Integer
    rowcount = GridSaleItem.Rows.Count
    For i As Integer = 1 To rowcount
        If i = 1 Then
            '
        Else
            If i = rowcount Then
                Me.GridSaleItem.CurrentCell = Me.GridSaleItem.Rows(i - 1).Cells(0)
                Me.GridSaleItem.Rows(i - 1).Selected = True
            End If
        End If
    Next

End Sub
Лицензировано под: CC-BY-SA с атрибуция
Не связан с StackOverflow
scroll top