C# 系统应用之ListView控件 (三).添加ContextMenuStrip右键菜单打开删除文件

简介:

        在前面讲述过使用TreeView控件和ListView控件显示磁盘目录信息,但仅仅是显示信息是不够的,我们还需要具体的操作.在"个人电脑使用历史痕迹"项目中我还需要添加"打开文件"和“删除文件”两种方法.具体如下:
        在第一篇文章"C# 系统应用之TreeView控件 (一).显示树状磁盘文件目录及加载图标"中显示如下:
        http://blog.csdn.net/eastmount/article/details/19453107
        免费下载地址:http://download.csdn.net/detail/eastmount/7414709

        在第二篇文章"C# 系统应用之ListView控件 (二).加载选中节点文件夹下文件信息"中显示加载文件信息,如下图所示:http://blog.csdn.net/eastmount/article/details/21241313

        该文章第三篇主要讲述的是为ListView控件中显示的文件添加一个鼠标右键菜单栏"打开文件"和"删除文件",打开文件能打开具体的文件,删除文件能删除至回收站.效果图如下图所示:
        打开文件

        删除文件


一.添加控件ContextMenuStrip
        首先添加一个ContextMenuStrip控件(右键关联控件显示相关菜单),并在"请在此处键入"处添加"打开文件"和"删除文件"两栏,将添加两项的Name设置为openFileToolStripMenuItem和deleteFileToolStripMenuItem.(否则为中英名)
        然后为filesList(ListView)控件添加鼠标事件,添加代码如下:

#region 鼠标右击事件 添加contextMenuStrip控件
private void filesList_MouseClick(object sender, MouseEventArgs e)
{
    //禁止多选
    filesList.MultiSelect = false;
    //鼠标右键
    if (e.Button == MouseButtons.Right)
    {
        //filesList.ContextMenuStrip = contextMenuStrip1;
        //选中列表中数据才显示 空白处不显示
        String fileName = filesList.SelectedItems[0].Text; //获取选中文件名
        Point p = new Point(e.X, e.Y);
        contextMenuStrip1.Show(filesList, p);
    }
}
#endregion

        此时,运行软件点击文件就会添加了相应的菜单栏.
二.打开文件
        现在需要添加打开文件功能.需要自定义两个全局变量记录打开文件的路径和名称.

//全局变量
public string fileNamePublic = ""; //文件名
public string filePathPublic = ""; //文件路径

        在更改选定内容AfterSelect事件中为选中的路径赋值,同时为openFileToolStripMenuItem添加Click事件.具体代码如下:

#region 打开文件操作
//设置contextMenuStrip1控件中"打开文件"Name为openFile
private void openFileToolStripMenuItem_Click(object sender, EventArgs e)
{
    //文件没有选中
    if (this.filesList.SelectedItems.Count == 0)
        return;
    //获取选中文件
    var selectedItem = this.filesList.SelectedItems[0];
    //全局变量文件名 SubItems[1]表示文件名
    fileNamePublic = filePathPublic + "\\" + selectedItem.SubItems[1].Text;
    //MessageBox.Show(fileNamePublic);
    try
    {
        //实例化一个新的Process类 命名空间using System.Diagnostics;
        using (Process p = new Process())
        {
            p.StartInfo.FileName = fileNamePublic; //指定要启动的文件路径
            p.StartInfo.CreateNoWindow = false; //在当前窗口启动程序
            //指定窗口的显示样式
            p.StartInfo.WindowStyle = System.Diagnostics.ProcessWindowStyle.Normal;
            p.StartInfo.UseShellExecute = true; //使用操作系统的shell启动进程
            p.Start(); //开始打开文件
        }
    }
    catch (Exception msg) //异常处理
    {
        MessageBox.Show(msg.Message);
    }   
}
#endregion

        它是通过实例化一个Process进程类,指定ProcessStartInfo参数,调用Process的Start()方法执行打开文件.
三.删除文件
        删除文件开始准备的方法是使用File.Delete删除,但是删除的文件并不是添加至回收站的,同时系统文件不能访问.所以采用了SHFileOperation外壳函数实现文件操作.为deleteFileToolStripMenuItem添加Click事件,具体代码如下:

#region 删除文件
//删除文件
//文件删除到回收站中
private const int FO_DELETE = 3;               //删除
private const int FOF_SILENT = 0x0004;         //不显示进度条提示框
private const int FOF_NOCONFIRMATION = 0x0010; //不出现任何对话框
private const int FOF_ALLOWUNDO = 0x0040;      //允许撤销
private const int FOF_NOCONFIRMMKDIR = 0x0200; //创建文件夹的时候不用确认

//添加命名空间using System.Runtime.InteropServices;
[StructLayout(LayoutKind.Sequential)]
private struct SHFILEOPSTRUCT
{
    public int hwnd;                     //父窗口句柄,0为桌面
    public int wFunc;                    //功能标志 FO_COPY复制 FO_DELETE删除 FO_MOVE移动 FO_RENAME重命名
    public string pFrom;                 //source file源文件或者源文件夹
    public string pTo;                   //destination目的文件或文件夹
    public int fFlags;                   //控制文件的标志位 FOF_ALLOWUNDO 准许撤销 FOF_CONFIRMMOUSE 没有被使用
    public bool fAnyOperationsAborted;
    public int hNameMappings;
    public string lpszProgressTitle;
}

//SHFileOperation外壳函数 实现文件操作 参数SHFILEOPSTRUCT结构
[DllImport("shell32.dll")]
private static extern int SHFileOperation(ref SHFILEOPSTRUCT FileOp);

/// <summary>
/// 删除文件 Delete("c:\\test.txt",true) 把"c:/test.text"删除到回收箱
/// </summary>
/// <param name="sender"></param>
/// <param name="e"></param>
private static int Delete(string sPath, bool recycle)
{
    SHFILEOPSTRUCT FileOp = new SHFILEOPSTRUCT();
    FileOp.hwnd = 0;
    FileOp.wFunc = FO_DELETE;      //实现操作是删除文件
    FileOp.fFlags = 0;
    FileOp.fFlags = FileOp.fFlags | FOF_SILENT;
    FileOp.fFlags = FileOp.fFlags | FOF_NOCONFIRMATION;
    FileOp.fFlags = FileOp.fFlags | FOF_NOCONFIRMMKDIR;
    if (recycle)
    {
        FileOp.fFlags = FileOp.fFlags | FOF_ALLOWUNDO;
    }
    FileOp.pFrom = sPath + "\0";
    return SHFileOperation(ref FileOp);
}

//设置contextMenuStrip1控件中"删除文件"Name为deleteFile
private void deleteFileToolStripMenuItem_Click(object sender, EventArgs e)
{
    //文件没有选中
    if (this.filesList.SelectedItems.Count == 0)
        return;
    //获取选中文件
    var selectedItem = this.filesList.SelectedItems[0];
    //全局变量文件名 SubItems[1]表示文件名
    fileNamePublic = filePathPublic + "\\" + selectedItem.SubItems[1].Text;
    //MessageBox.Show(fileNamePublic);
    try
    {
        if (MessageBox.Show("确认要删除该最近浏览文件信息?", "提示",
                    System.Windows.Forms.MessageBoxButtons.YesNo,
                    System.Windows.Forms.MessageBoxIcon.Question) ==
                    System.Windows.Forms.DialogResult.Yes)
        {
            //删除文件
            Delete(fileNamePublic, true);
            //移除文件
            foreach (ListViewItem item in this.filesList.SelectedItems)
            {
                this.filesList.Items.Remove(item);
            }
        }
        MessageBox.Show(this, "成功删除了文件!", "信息提示", MessageBoxButtons.OK, MessageBoxIcon.Information);
    }
    catch (Exception msg) //异常处理
    {
        MessageBox.Show(msg.Message);
    }   
}
#endregion

四.总结
       
最后,希望该文章对大家有所帮助.这三篇文章主要讲述了如何使用C#的TreeView控件加载磁盘目录信息,同时在ListView控件中显示具体信息,为ListView控件添加鼠标右键ContextMenuStrip控件菜单栏.在这几篇文章中你可以实现到项目中的:
       
1.如何使用TreeView控件添加图标,添加节点及其展开事件
        2.如何使用ListView控件加载数据,设置标题头、添加数据、listItem.SubItems.Add等,尤其在数据库处理等操作或显示信息时,经常会应用到该控件显示内容
        3.如何为控件添加右键菜单栏ContextMenuStrip,并设置其Item,为其添加相应的响应事件
       
最后,希望文章对大家有所帮助,如果文章中有错误或不足之处,还请海涵.我这系列文章最后的运行效果如下图所示,高仿360同时能实现各种功能,具体参照博客每部分:

        上面的打开删除文件源代码地址:http://download.csdn.net/detail/eastmount/7414709

(By:Eastmount 2014-5-28 夜8点 原创CSDNhttp://blog.csdn.net/eastmount/)


目录
相关文章
|
SQL 数据库 数据安全/隐私保护
C#wpf学习卡后台管理系统
C#wpf学习卡后台管理系统
340 32
|
存储 监控 算法
基于 C# 的局域网计算机监控系统文件变更实时监测算法设计与实现研究
本文介绍了一种基于C#语言的局域网文件变更监控算法,通过事件驱动与批处理机制结合,实现高效、低负载的文件系统实时监控。核心内容涵盖监控机制选择(如事件触发机制)、数据结构设计(如监控文件列表、事件队列)及批处理优化策略。文章详细解析了C#实现的核心代码,并提出性能优化与可靠性保障措施,包括批量处理、事件过滤和异步处理等技术。最后,探讨了该算法在企业数据安全监控、文件同步备份等场景的应用潜力,以及未来向智能化扩展的方向,如文件内容分析、智能告警机制和分布式监控架构。
314 3
|
存储 监控 算法
基于 C# 时间轮算法的控制局域网上网时间与实践应用
在数字化办公与教育环境中,局域网作为内部网络通信的核心基础设施,其精细化管理水平直接影响网络资源的合理配置与使用效能。对局域网用户上网时间的有效管控,已成为企业、教育机构等组织的重要管理需求。这一需求不仅旨在提升员工工作效率、规范学生网络使用行为,更是优化网络带宽资源分配的关键举措。时间轮算法作为一种经典的定时任务管理机制,在局域网用户上网时间管控场景中展现出显著的技术优势。本文将系统阐述时间轮算法的核心原理,并基于 C# 编程语言提供具体实现方案,以期深入剖析该算法在局域网管理中的应用逻辑与实践价值。
316 5
|
SQL 小程序 API
如何运用C#.NET技术快速开发一套掌上医院系统?
本方案基于C#.NET技术快速构建掌上医院系统,结合模块化开发理念与医院信息化需求。核心功能涵盖用户端的预约挂号、在线问诊、报告查询等,以及管理端的排班管理和数据统计。采用.NET Core Web API与uni-app实现前后端分离,支持跨平台小程序开发。数据库选用SQL Server 2012,并通过读写分离与索引优化提升性能。部署方案包括Windows Server与负载均衡设计,确保高可用性。同时针对API差异、数据库老化及高并发等问题制定应对措施,保障系统稳定运行。推荐使用Postman、Redgate等工具辅助开发,提升效率与质量。
596 0
|
存储 监控 算法
企业内网监控系统中基于哈希表的 C# 算法解析
在企业内网监控系统中,哈希表作为一种高效的数据结构,能够快速处理大量网络连接和用户操作记录,确保网络安全与效率。通过C#代码示例展示了如何使用哈希表存储和管理用户的登录时间、访问IP及操作行为等信息,实现快速的查找、插入和删除操作。哈希表的应用显著提升了系统的实时性和准确性,尽管存在哈希冲突等问题,但通过合理设计哈希函数和冲突解决策略,可以确保系统稳定运行,为企业提供有力的安全保障。
|
存储 安全 物联网
C# 在物联网 (IoT) 应用中的应用
本文介绍了C#在物联网(IoT)应用中的应用,涵盖基础概念、优势、常见问题及其解决方法。重点讨论了网络通信、数据处理和安全问题,并提供了相应的代码示例,旨在帮助开发者更好地利用C#进行IoT开发。
735 3
|
编译器 C#
c# - 运算符<<不能应用于long和long类型的操作数
在C#中,左移运算符的第二个操作数必须是 `int`类型,因此需要将 `long`类型的位移计数显式转换为 `int`类型。这种转换需要注意数据丢失和负值处理的问题。通过本文的详细说明和示例代码,相信可以帮助你在实际开发中正确使用左移运算符。
414 2
|
编译器 C#
c# - 运算符<<不能应用于long和long类型的操作数
在C#中,左移运算符的第二个操作数必须是 `int`类型,因此需要将 `long`类型的位移计数显式转换为 `int`类型。这种转换需要注意数据丢失和负值处理的问题。通过本文的详细说明和示例代码,相信可以帮助你在实际开发中正确使用左移运算符。
401 0
|
9月前
|
XML 前端开发 C#
C#编程实践:解析HTML文档并执行元素匹配
通过上述步骤,可以在C#中有效地解析HTML文档并执行元素匹配。HtmlAgilityPack提供了一个强大而灵活的工具集,可以处理各种HTML解析任务。
393 19
|
C# 开发者
C# 一分钟浅谈:Code Contracts 与契约编程
【10月更文挑战第26天】本文介绍了 C# 中的 Code Contracts,这是一个强大的工具,用于通过契约编程增强代码的健壮性和可维护性。文章从基本概念入手,详细讲解了前置条件、后置条件和对象不变量的使用方法,并通过具体代码示例进行了说明。同时,文章还探讨了常见的问题和易错点,如忘记启用静态检查、过度依赖契约和性能影响,并提供了相应的解决建议。希望读者能通过本文更好地理解和应用 Code Contracts。
445 3