How to Add Conditional Formatting to Rows in Windows Forms GridControl
15 Jun 20213 minutes to read
Introduction
Say you want to color a row if the value in column 2 is larger than 10 (or any logical condition that you can evaluate). You can do something like this by using PrepareViewStyleInfo event. This event is raised immediately prior to the cell being drawn and gives you a chance to modify GridStyleInfo object that determines the appearance of the cell. Since you want to affect a visual change on the whole row when a single cell value is modified, you will need to tell the grid to redraw the whole row when the current cell moves instead of just redrawing affected cells. You can use the same technique to conditionally format columns or cells.
//Tells the grid to redraw the whole row as current cell moves (say in Form.Load).
this.grid.Model.Options.RefreshCurrentCellBehavior = GridRefreshCurrentCellBehavior.RefreshRow;
//The event handler.
private void grid_PrepareViewStyleInfo(object sender, GridPrepareViewStyleInfoEventArgs e)
{
if(e.RowIndex > 0 && e.ColIndex > 0)
{
double d;
string val = (e.ColIndex == 2) ? e.Style.Text : this.gridDataBoundGrid1[e.RowIndex, 2].Text;
if(double.TryParse(val, System.Globalization.NumberStyles.Any, null, out d)
&& d > 10)
{
e.Style.BackColor = Color.LightGoldenrodYellow;
}
}
}
'Tells the grid to redraw the whole row as current cell moves (say in Form.Load).
Me.grid.Model.Options.RefreshCurrentCellBehavior = GridRefreshCurrentCellBehavior.RefreshRow
'The event handler.
Private Sub grid_PrepareViewStyleInfo(ByVal sender As Object, ByVal e As GridPrepareViewStyleInfoEventArgs)
If e.RowIndex > 0 And e.ColIndex > 0 Then
Dim d As Double
Dim val As String
If e.ColIndex = 2 Then
val = e.Style.Text
Else
val = Me.gridDataBoundGrid1(e.RowIndex, 2).Text)
End If
If Double.TryParse(val, System.Globalization.NumberStyles.Any, Nothing, d) And d > 10 Then
e.Style.BackColor = Color.LightGoldenrodYellow
End If
End If
'Grid_PrepareViewStyleInfo.
End Sub