c# - 如何通过拖放将列表视图项从一个列表移动到另一个列表?UWP C#
问题描述
我在 UWP 应用程序中有许多列表视图,我希望能够将一个项目从一个列表视图移动到另一个列表视图
我知道 AllowDrop 或 CanDragItems 属性,并且您需要处理一些事件才能使拖放工作,尽管我只是不知道该怎么做。
解决方案
如果您想通过单击添加按钮添加 ListView 控件并在 ListView 控件之间移动项目,请检查以下代码作为示例。以下代码与官方示例不同,ObservableCollection
用于完成拖放操作。您可以将项目从源ListView
项目拖动到目标ListView
,也可以将项目从原始目标拖动ListView
到原始源ListView
。
您可以单击Add
按钮两次,然后ListView
添加两个带有两个项目的按钮。您可以将任何项目从任何ListView
控件拖动到另一个控件。如果要将拖动的项目保留在源代码ListView
管理中,只需注释代码即可dragCollection.Remove(dragedItem as string);
。
例如:
private ObservableCollection<string> dragCollection;
private ObservableCollection<string> dropCollection;
private object dragedItem;
private ListView dragListView;
private ListView dropListView;
……
private void AddButton_Click(object sender, RoutedEventArgs e)
{
ListView listView = new ListView();
listView.CanDragItems = true;
listView.CanDrag = true;
listView.AllowDrop = true;
listView.ReorderMode = ListViewReorderMode.Enabled;
listView.CanReorderItems = true;
listView.ItemsSource = new ObservableCollection<string>() { "item1","item2" };
listView.DragItemsStarting += ListView_DragItemsStarting;
//listView.DropCompleted += ListView_DropCompleted;
listView.DragEnter += ListView_DragEnter;
listView.Drop += ListView_Drop;
listView.DragOver += ListView_DragOver;
listView.BorderBrush = new SolidColorBrush(Colors.Red);
listView.BorderThickness = new Thickness(1);
stackPanel.Children.Add(listView);
}
private void ListView_DragOver(object sender, DragEventArgs e)
{
e.AcceptedOperation = DataPackageOperation.Move;
}
private void ListView_Drop(object sender, DragEventArgs e)
{
dropListView = sender as ListView;
if(dropListView!=null)
{
dropCollection = dropListView.ItemsSource as ObservableCollection<string>;
if (dragedItem != null)
{
dropCollection.Add(dragedItem as string);
//If you need to delete the draged item in the source ListView, then use the following code
dragCollection.Remove(dragedItem as string);
dragedItem = null;
}
}
}
private void ListView_DragEnter(object sender, DragEventArgs e)
{
e.AcceptedOperation = (e.DataView.Contains(StandardDataFormats.Text) ? DataPackageOperation.Move : DataPackageOperation.None);
}
private void ListView_DropCompleted(UIElement sender, DropCompletedEventArgs args)
{
var listView = sender as ListView;
if (listView != null)
{
dropListView = listView;
dropCollection = listView.ItemsSource as ObservableCollection<string>;
if(dropListView==dragListView)
{
return;
}
}
}
private void ListView_DragItemsStarting(object sender, DragItemsStartingEventArgs e)
{
var listView = sender as ListView;
if(listView!=null)
{
dragListView = listView;
dragCollection = listView.ItemsSource as ObservableCollection<string>;
if (dropListView == dragListView)
{
return;
}
if(e.Items.Count==1)
{
dragedItem = e.Items[0];
e.Data.RequestedOperation = Windows.ApplicationModel.DataTransfer.DataPackageOperation.Move;
}
}
}
有关拖放的更多信息,您可以参考文档(https://docs.microsoft.com/en-us/windows/uwp/design/input/drag-and-drop)。
对代码有任何疑问,请随时与我联系。
推荐阅读
- reactjs - 在对象内的数组将项目推送到它之后,反应组件不重新渲染
- swiftui - 如何将依赖项设置为@propertyWrapper 成为@ObservableObject?
- python - AttributeError:“LogInPage”对象没有属性“_frame”
- r - 将扫描的 PDF 转换为可搜索的 PDF(在 R 中)
- python - Groupby、Split 和 Count 组合(删除循环以提高 pytorch 性能)
- sql - 返回具有特定字符串且列为空的行,但还包括列不为空的行?
- python - 带有结构化地址的 Azure 地址地理编码 - 可以使用 Geopy 等 Python 库吗?
- javascript - 在函数中编辑时,React UseState 初始引用被更改
- javascript - 有没有办法从这个请求正文中取出值?
- javascript - Mysql查询执行数组并插入javascript值