当前位置: 首页 > news >正文

封装WPF中列表控件的剪贴板操作(附源码)

文章目录

  • 前言
  • 1.剪贴板功能演示
  • 2. 功能说明
    • 2.1 框选效果
    • 2.2 复制
    • 2.3 剪切
    • 2.4 粘贴
    • 2.5 删除
    • 2.6 键盘快捷键支持
    • 2.7 多语言支持
    • 2.8 跨应用程序支持
  • 3.如何获取


前言

在WPF中,ListBox、ListView和DataGrid等控件原生不支持直接通过剪贴板批量操作数据(复制、剪切、粘贴),为了可以在不同的项目中复用剪贴板操作,我们可以将这个功能进行封装,这样我们就可以在新的项目中快速移植剪贴板功能。


1.剪贴板功能演示

在这里插入图片描述

2. 功能说明

2.1 框选效果

定义一个名为SelectorExtension静态扩展类,并 在该类中新建一个名为IsEnableDragSelection的附加属性,在属性的PropertyChangedCallback中订阅控件的鼠标按下、移动、松开事件,在事件处理方法中获取到鼠标的坐标及状态,并用装饰器添加框选效果。

2.2 复制

新建一个名为IsEnableCopy的附加属性,在属性的PropertyChangedCallback中获取到MenuItem,并为MenuItem添加ApplicationCommands.Copy命令绑定,然后实现复制功能。

命令绑定关键代码:

menuItem.Command = ApplicationCommands.Copy;
selector.CommandBindings.Add(new CommandBinding(ApplicationCommands.Copy, CopyCmdExecuted, CopyCmdCanExecuted));

复制功能关键代码:


var copyingItems = new List<string>();
foreach (var item in selectedItems)
{if (item is ICloneable obj){copyingItems.Add(JsonSerializer.Serialize(obj.Clone()));}else{copyingItems.Add(JsonSerializer.Serialize(item));}
}
Clipboard.SetText(string.Join(Environment.NewLine, copyingItems));

2.3 剪切

新建一个名为IsEnableCut的附加属性,在属性的PropertyChangedCallback中获取到MenuItem,并为MenuItem添加ApplicationCommands.Cut命令绑定,然后实现剪切功能。

命令绑定关键代码:

menuItem.Command = ApplicationCommands.Cut;
selector.CommandBindings.Add(new CommandBinding(ApplicationCommands.Cut, CutCmdExecuted, CutCmdCanExecuted));

剪切功能关键代码:

var removeItems = new List<object>();
var cuttingItems = new List<string>();
foreach (var item in selectedItems)
{removeItems.Add(item);cuttingItems.Add(JsonSerializer.Serialize(item));
}
Clipboard.SetText(string.Join(Environment.NewLine, cuttingItems));
foreach (var item in removeItems)
{if (items.Contains(item)){items.Remove(item);}
}

2.4 粘贴

新建一个名为IsEnablePaste的附加属性,在属性的PropertyChangedCallback中获取到MenuItem,并为MenuItem添加ApplicationCommands.Paste命令绑定,然后实现粘贴功能。

命令绑定关键代码:

menuItem.Command = ApplicationCommands.Paste;
selector.CommandBindings.Add(new CommandBinding(ApplicationCommands.Paste, PasteCmdExecuted, PasteCmdCanExecuted));

粘贴功能关键代码:

var clipboardObjects = GetClipboardObject(selector);
if (clipboardObjects != null)
{var selectedItems = selector.GetSelectedItems();if (selector.ItemsSource is IList items){var length = selectedItems.Count;if (length == 0){// 未选中foreach (var clipboardObject in clipboardObjects){items.Add(clipboardObject);selectedItems.Add(clipboardObject);}}else{// 已选中               int index = items.IndexOf(selectedItems[length - 1]);selectedItems.Clear();foreach (var clipboardObject in clipboardObjects){items.Insert(index, clipboardObject);selectedItems.Add(clipboardObject);index++;}}}
}

2.5 删除

新建一个名为IsEnableDelete的附加属性,在属性的PropertyChangedCallback中获取到MenuItem,并为MenuItem添加ApplicationCommands. Delete命令绑定,然后实现删除功能。
命令绑定关键代码:

menuItem.Command = ApplicationCommands.Delete;
selector.CommandBindings.Add(new CommandBinding(ApplicationCommands.Delete, DeleteCmdExecuted, DeleteCmdCanExecuted));

删除功能关键代码:

var selectedItems = selector.GetSelectedItems();
if (selector.ItemsSource is IList items &&selectedItems != null &&selectedItems.Count > 0)
{var removeItems = new List<object>();foreach (var item in selectedItems){removeItems.Add(item);}foreach (var item in removeItems){if (items.Contains(item)){items.Remove(item);}}
}

2.6 键盘快捷键支持

以上代码支持键盘组合键Ctrl+C(复制)、Ctrl+X(剪切)、Ctrl+V(粘贴)、Delete(删除)。

2.7 多语言支持

以上代码支持自动语言切换。

2.8 跨应用程序支持

使用Json转换对象,剪贴板中存储的是Json字符串,可以支持跨应用程序复制粘贴。

3.如何获取

完整源代码已经上传到群(661224882)文件,如有需要,请自行获取。

技术赋能,共创未来
我们是一支深耕WPF及Avalonia十余年的开发团队,专注于为企业和开发者提供高性能桌面应用解决方案,目前已经为二十多家企业提供过服务,无论您是哪种需求,我们都可以用我们丰富的经验助力您的业务高效落地。如果您有相关需求,请与我们联系。

联系方式
QQ/VX:446522563
手机号:17898179019

技术交流
QQ群:661224882
在这里插入图片描述

相关文章:

  • Flask框架全方位深度解析
  • 告别繁琐操作,一键批量发布!
  • Docker安装Nginx(最完整的安装方式)
  • 2025年5月网工基础知识
  • Linux iSCSI存储共享实验指南
  • SpringMVC(结合源码浅析工作流程)
  • 一条SQL语句的旅程:解析、优化与执行全过程研究
  • 【论文精读】2023 AAAI--FastRealVSR现实世界视频超分辨率(RealWorld VSR)
  • Flutter遇到的问题
  • 数据结构(5)线性表-栈
  • Flutter - 国际化
  • 【JVM 02-JVM内存结构之-程序计数器】
  • 线程池介绍,分类,实现(工作原理,核心组成,拒绝策略),固态线程池的实现+详细解释(支持超时取消机制和不同的拒绝策略)
  • OBS 玩转你直播录视频
  • 【SSL部署与优化​】​​OCSP Stapling配置指南:减少证书验证延迟​​
  • ten-vad:低延迟、轻量化且高性能的流式语音活动检测系统
  • HTTP协议接口三种测试方法之-postman
  • vue pinia 独立维护,仓库统一导出
  • leetcode hot100刷题日记——11.相交链表
  • Linux 之 Ubuntu Server 安装
  • wordpress建站镜像/提交网址给百度
  • 河北省做网站哪家公司好/南京网络建站公司
  • 网站建站哪个品牌好/百度服务
  • 政府网站内容建设/微信拓客的最新方法
  • 如何对自己做的php网站加密/直播营销
  • 申请个网站/郑州网站排名优化公司