How to keep cell style unchanged when selecting row in .NET MAUI DataGrid (SfDataGrid) ?
In this article, we will demonstrate how to maintain the cell style unchanged when a row is selected in the .NET MAUI DataGrid.
xaml
<ContentPage.BindingContext>
<local:EmployeeViewModel x:Name="viewModel"/>
</ContentPage.BindingContext>
<syncfusion:SfDataGrid x:Name="dataGrid"
GridLinesVisibility="Both"
SelectionMode="Single"
NavigationMode="Row"
HeaderGridLinesVisibility="Both"
AutoGenerateColumnsMode="None"
ColumnWidthMode="Auto"
ItemsSource="{Binding Employees}">
<syncfusion:SfDataGrid.DefaultStyle>
<syncfusion:DataGridStyle RowBackground="LightBlue" HeaderRowBackground="LightBlue" HeaderRowTextColor="Black"
RowTextColor="Black"
SelectionBackground="Gray"
SelectedRowTextColor="White" />
</syncfusion:SfDataGrid.DefaultStyle>
<syncfusion:SfDataGrid.Columns>
<syncfusion:DataGridNumericColumn MappingName="EmployeeID" HeaderText="Employee ID" Format="#" />
<syncfusion:DataGridTextColumn MappingName="Name" HeaderText="Employee Name" />
<syncfusion:DataGridTextColumn MappingName="Title" HeaderText="Designation" />
<syncfusion:DataGridDateColumn MappingName="HireDate" HeaderText="Hire Date" />
</syncfusion:SfDataGrid.Columns>
</syncfusion:SfDataGrid>
C#
The code below illustrates how to maintain the cell style unchanged when a row is selected in the DataGrid.
public MainPage()
{
InitializeComponent();
dataGrid.CellRenderers.Remove("Text");
dataGrid.CellRenderers.Add("Text", new CustomRenderer());
}
public class CustomRenderer : DataGridCellRenderer<View, View>
{
protected override void OnSetCellStyle(DataColumnBase dataColumn)
{
base.OnSetCellStyle(dataColumn);
if (dataColumn != null)
{
var gridStyle = this.DataGrid?.DefaultStyle;
DataGridCell gridCell = dataColumn.ColumnElement;
var mappingName = dataColumn.DataGridColumn.MappingName;
if ((mappingName == "Name"))
{
var label = gridCell.Children[0] as Label;
if (label != null && gridCell != null)
{
label.TextColor = Colors.White;
gridCell.BackgroundColor = Colors.Orange;
}
}
gridStyle = null;
mappingName = null;
gridCell = null;
}
}
}
Output
Download the complete sample from GitHub
Conclusion
I hope you enjoyed learning how to keep cell style unchanged when selecting a row in .NET MAUI DataGrid (SfDataGrid).
You can refer to our .NET MAUI DataGrid feature tour page to learn about its other groundbreaking feature representations. Explore our .NET MAUI DataGrid Documentation to understand how to present and manipulate data.
For current customers, check out our components from the License and Downloads page. If you are new to Syncfusion®, try our 30-day free trial to check out our other controls.
Please let us know in the comments section if you have any queries or require clarification. You can also contact us through our support forums, Direct-Trac or feedback portal, or the feedback portal. We are always happy to assist you!