我有一个在运行时用来自SQLite数据库的数据填充的DataGrid。当用户在datagrid中编辑单元格时,我希望该单元格更改其背景颜色。这是我所做的事情背后的MCVE代码:
public MainWindow()
{
InitializeComponent();
DataTable dt = new DataTable();
dt.Columns.Add("Column1");
dt.Columns.Add("Column2");
for (int i = 0; i < 100; i++)
{
var r = dt.NewRow();
r[0] = i ;
r[1] = i * i;
dt.Rows.Add(r);
}
myDataGrid.ItemsSource = dt.DefaultView;
}
private void myDataGrid_CellEditEnding(object sender, DataGridCellEditEndingEventArgs e)
{
if (e.EditAction.ToString() == "Commit")
{
FrameworkElement element = e.Column.GetCellContent(e.Row);
(element.Parent as DataGridCell).Background = new SolidColorBrush(Colors.Yellow);
}
}
xaml:
<Grid>
<DataGrid x:Name="myDataGrid" CellEditEnding="myDataGrid_CellEditEnding"/>
</Grid>
问题是,每当我滚动时,我都会看到其他单元格也被涂成黄色。此外,根据我的滚动方式,黄色背景会从我想要的单元格跳转到另一个单元格。只有当EnableRowVirtualization
设置为true
时,才会发生这种情况。有没有一种方法可以在不禁用它的情况下完成它,或者这是正确的方法?
发布于 2018-06-05 23:53:47
因此,根据他的回复评论中的守日沙链接,我想出了一个解决方案。禁用行虚拟化的问题是性能和内存,特别是对于大型网格。为了继续使用虚拟化并保持正确的背景,如果任何行单元格都有背景色,我必须取消CleanUpVirtualizedItem
事件。
xaml:
<Grid>
<DataGrid x:Name="myDataGrid" CellEditEnding="myDataGrid_CellEditEnding" VirtualizingStackPanel.CleanUpVirtualizedItem="myDataGrid_CleanUpVirtualizedItem"/>
</Grid>
代码隐藏:
private void myDataGrid_CleanUpVirtualizedItem(object sender, CleanUpVirtualizedItemEventArgs e)
{
var row = e.UIElement as DataGridRow;
for(int i = 0; i<(sender as DataGrid).Columns.Count; i++)
{
var cell = (DataGridCell)(sender as DataGrid).Columns[i].GetCellContent(row).Parent;
if (cell.Background != Brushes.White)
{
e.Cancel = true;
break;
}
}
}
发布于 2018-06-05 06:27:09
我在网上找到了这个解决方案。但我不知道这是不是正确的方法。我想这取决于你。
我刚刚将VirtualizingStackPanel.VirtualizationMode="Standard“添加到xaml中:
<DataGrid x:Name="myDataGrid" CellEditEnding="myDataGrid_CellEditEnding" VirtualizingStackPanel.VirtualizationMode="Standard" />
我执行后发现,着色现在不会跳到其他单元格。
https://stackoverflow.com/questions/50687285
复制相似问题