复制数据网格行并将其粘贴到WPF数据网格中的新行
本文关键字:网格 数据网 数据 WPF 新行 复制 | 更新日期: 2023-09-27 18:25:20
我有一个wpf数据网格,它允许用户添加行。我需要添加一个功能,用户可以在其中复制数据行,并在粘贴时将其添加为新行。我可以复制(Ctrl+C)一行,但在粘贴(Ctrl+V)时,所有项目都会粘贴到该行的第一个单元格。如何将其粘贴到行的每个单元格中。
<DataGrid Name="grdTest" HorizontalAlignment="Left" Grid.Row="0" Margin="5,5,0,0" VerticalAlignment="Top" Height="426" Width="1034"
AlternationCount="2" ItemsSource="{Binding TestsList,Mode=TwoWay,UpdateSourceTrigger=PropertyChanged}" >
<DataGrid.Columns>
<DataGridCheckBoxColumn Header="Is Active" Binding="{Binding Path=IsActive,Mode=TwoWay}">
<DataGridTextColumn Width="90">
<DataGridTextColumn.Binding>
<Binding Path="TestName" Mode="TwoWay">
<Binding.ValidationRules>
<localVal:ValidationRules/>
</Binding.ValidationRules>
</Binding>
</DataGridTextColumn.Binding>
<DataGridTextColumn.Header>
<TextBlock Width="80" Text="Test Name" ToolTip=""/>
</DataGridTextColumn.Header>
</DataGridTextColumn>
<DataGridTextColumn.Binding>
<Binding Path="TestType" Mode="TwoWay">
<Binding.ValidationRules>
<localVal:ValidationRules/>
</Binding.ValidationRules>
</Binding>
</DataGridTextColumn.Binding>
<DataGridTextColumn.Header>
<TextBlock Width="80" Text="Test Type" ToolTip=""/>
</DataGridTextColumn.Header>
</DataGridTextColumn>
</DataGrid.Columns>
</DataGrid>
这就是我到目前为止得到的:
private void grdTest_CopyingRowClipboardContent(object sender, DataGridRowClipboardEventArgs e)
{
copiedItem = (Test)e.Item;
}
private void grdTest_PreviewKeyDown(object sender, KeyEventArgs e)
{
if (e.Key == Key.V && (Keyboard.Modifiers & ModifierKeys.Control) == ModifierKeys.Control)
{
if (App.ViewModel.UpdatedListCommand.CanExecute(null))
{
App.ViewModel.UpdatedListRowCommand.Execute(copiedItem);
}
}}}
我更新了视图模型中的列表,并调用NotifyProperty changed。该列表已更新,但它不会反映在UI中。行(我将值复制/粘贴到的行)看起来是空的,但当我选择一个单元格时,值就会出现。因此,基本上它是正确设置的,但有些方式没有显示在数据网格中。
我认为使用Ctrl+C只需复制行的内容,尝试覆盖粘贴时使用的函数/事件,然后创建一个新的数据网格行并将每个数据插入到正确的单元格中。我希望这能有所帮助。
我不知道这是否是最好的方法,但我通过将复制的项目插入绑定到DataGrid:的ObservableCollection中来做到这一点
private void grdTest_PreviewKeyDown(object sender, KeyEventArgs e)
{
if (e.Key == Key.V && (Keyboard.Modifiers & ModifierKeys.Control) == ModifierKeys.Control)
{
TestList.Insert(TestList.IndexOf((Test)grdTest.SelectedItem), copiedItem);
}
}
请注意,这会粘贴一个全新的行,而不是填充现有的空白行。
我能够使用以下代码从一行复制到另一行。
ObservableCollection<Item> allItems;
private Item copiedItem;
private void tableInput_CopyingRowClipboardContent(object sender, DataGridRowClipboardEventArgs e)
{
//if row itself is copied as opposed to a number
if(e.Item is Item)
copiedItem=(Item)e.Item;
}
private void tableInput_PreviewKeyDown(object sender, KeyEventArgs e)
{
if (e.Key == Key.V && (Keyboard.Modifiers & ModifierKeys.Control) == ModifierKeys.Control)
{
//if row itself is copied
if(copiedItem!=null) {
if(dataGrid.CurrentItem != null)
{
for(int i=0;i<allItems.Count;i++)
{
if(allItems[i].Equals(dataGrid.CurrentItem))
{
allItems[i]=DeepClone<Item>(copiedItem);
}
}
}
}
}
}
[Serializable]
public class Item
{
public string Name {get;set; }
public string Max_Flow {get;set; }
}
public static T DeepClone<T>(T obj)
{
using (var ms = new MemoryStream())
{
var formatter = new BinaryFormatter();
formatter.Serialize(ms, obj);
ms.Position = 0;
return (T)formatter.Deserialize(ms);
}
}
我的代码不会创建新行,但如果你替换
allItems[i]=DeepClone<Item>(copiedItem);
带有
allItems.Add(new Item() {Name=<something>,Max_Flow=<something> });
我认为它会满足你的需要。