C# 模仿 IBOX 程序管理 (简易版)

2023-12-04 04:50

本文主要是介绍C# 模仿 IBOX 程序管理 (简易版),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

  C# IBOX 程序管理简易版,该程序是2009年闲来无事做的程序,本来是想做成网络程序下载器的,结果做成程序管理器了。

今天整理以前代码的时候发现了这个东东,发给刚入门不久的.net 童鞋学习用,希望笑纳。

  里面会涉及一些API调用,图标布局算法问题,系统消息机制的拦截,动态添加事件处理。可能对于刚学习不久的有点困难。


 先上一个主界面截图:(图像被我压缩了不然的有1.4MB,所以有点模糊)


 拖入增加文件或程序。。。


手动添加文件或程序


选择删除程序快捷方式


隐藏起来的快捷方式


显示隐藏的程序


程序管理界面


 以上为程序的部分截图,下面贴出核心代码含注释。

#region [获取图标和可以拖动窗体]

//调用系统API获取程序的图标信息
[System.Runtime.InteropServices.DllImport("shell32.dll", EntryPoint = "ExtractAssociatedIcon")]
private static extern IntPtr ExtractAssociatedIconA(
IntPtr hInst,
[System.Runtime.InteropServices.MarshalAs(
System.Runtime.InteropServices.UnmanagedType.LPStr)] string lpIconPath,
ref int lpiIcon);
//private static IntPtr hInst;



private const int WM_NCHITTEST = 0x84;//客户区消息
private const int HTCLIENT = 0x1;
private const int HTCAPTION = 0x2;
private const int WM_NCLBUTTONDBLCLK = 0xA3;//双击消息


//窗体消息,拦截标题区域双击消息和窗体移动区域消息
protected override void WndProc(ref Message m)
{

switch (m.Msg)
{
case WM_NCHITTEST:
base.WndProc(ref m);
if ((int)m.Result == HTCLIENT)
m.Result = (IntPtr)HTCAPTION;
return;
// break;
case WM_NCLBUTTONDBLCLK:
if ((int)m.Result == WM_NCLBUTTONDBLCLK)
m.Result = (IntPtr)0xa1;
return;
}
base.WndProc(ref m);
}

/// <summary>
/// 获取图标
/// </summary>
public static Icon ExtractAssociatedIcon(string fileName)
{

if (File.Exists(fileName) || Directory.Exists(fileName))
{
int i = 0;
//根据文件路径获取图标指针
IntPtr hIcon = ExtractAssociatedIconA(new IntPtr(), fileName, ref i);

if (!hIcon.Equals(IntPtr.Zero))
{
//图标指针转换为ICO图标
return Icon.FromHandle(hIcon);
}
else
{
return null;
}
}
else
{
throw new Exception("加载某些文件失败!可能有些文件已不存在!\n【请在[-管理界面-]删除或者重新指定】");
}


}
#endregion

 

/// <summary>
/// 只能打开一个这个程序,这个是有BUG的,改了名称就可以继续打开
/// </summary>
private void IsOpen()
{
int isOpen = 0;
//得到所有的进程
Process[] computer = Process.GetProcesses();
foreach (Process p in computer)
{
if (p.ProcessName.Equals("MyBox"))
{
isOpen = isOpen + 1;
}
}
if (isOpen == 1)
{
//清空
pnlMain.Controls.Clear();
//重新加载
pnlMain.Controls.Add(this.msMenu);
pnlMain.Controls.Add(this.grpAddMain);
pnlMain.Controls.Add(this.pnlPwd);
//读取设置
if (File.Exists("FileConfig.ini"))
{

try
{
gm.loadSet();
}
catch (Exception e)
{
MessageBox.Show("配置文件读取失败!文件被篡改!所有文件列表已重置!");
MessageBox.Show("请手动删除被更改FileConfig.ini文件!");
this.Close();
Console.WriteLine(e.Message);
this.Dispose();
return;
}
}
else
{
MessageBox.Show("配置文件不存在!所有信息已重置!");
//重置配置
gm.saveSet(Application.StartupPath.ToString());
//清空文件
gm.save(Application.StartupPath.ToString());
}
//配置设置
MainSet();
//加载文件
CreateGame(false);
}
if (isOpen == 2)
{
MessageBox.Show("此程序已经打开!");
this.Close();
this.Dispose();
}
}

 

/// <summary>
/// 创建所有文件
/// </summary>
/// <param name="ispwd">true为加载加密文件</param>
public void CreateGame(bool ispwd)
{
int errFileNum = 0;//错误文件数量
gm.load();
PictureBox pb;
Label lb;
int x=0;
int y=0;
int width = this.Size.Width;
bool iscreate=true;//是否创建
foreach (string key in gm.Info.Keys)
{
iscreate = true;
pb= new PictureBox();
lb = new Label();
Icon icon=null;
Bitmap appicon;
//如果找不到指定文件!弹出警告信息!
try
{
icon = ExtractAssociatedIcon(@gm.Info[key].Path);
}
catch (Exception e)
{
errFileNum++;
MessageBox.Show(e.Message+"\n\t加载错误文件数:["+errFileNum+"]","提示:出错啦!(MyBox作者提醒您!)",MessageBoxButtons.OK,MessageBoxIcon.Information);
iscreate = false;//出错文件不加载
}
if (iscreate)
{
appicon = icon.ToBitmap();
//定义图片
pb.Cursor = Cursors.Hand;
pb.BackgroundImage = appicon;
if (ispwd == true)
{
pb.Location = new Point((x + 1) + 25, (y + 1) + 15);
}
else
{
pb.Location = new Point((x + 1) + 25, (y + 1) + 50);
}
pb.Size = new Size(50, 50);
pb.DoubleClick += new EventHandler(picIco_DoubleClick);
pb.MouseEnter += new EventHandler(picGame_MouseEnter);
pb.MouseLeave += new EventHandler(picGame_MouseLeave);
pb.BackColor = Color.Transparent;
pb.Tag = gm.Info[key].Name.ToString();
pb.BackgroundImageLayout = ImageLayout.Center;
pb.ContextMenuStrip = cmsGame;
//定义文本
lb.Text = gm.Info[key].Name.ToString();
lb.Location = new Point(pb.Location.X - 13, pb.Location.Y + 50);
lb.BackColor = Color.Transparent;
lb.Size = new Size(pb.Size.Width + 30, lb.Size.Height);
lb.TextAlign = ContentAlignment.MiddleCenter;
lb.ForeColor = Color.Aqua;
if (ispwd == true&&gm.Info[key].Type==true)
{
pnlPwd.Controls.Add(pb);
pnlPwd.Controls.Add(lb);
x = x + 100;
if (x > width - 25)
{
x = 0;
y = y + 100;
}
}
else if (gm.Info[key].Type == false && ispwd == false)
{
pnlMain.Controls.Add(pb);
pnlMain.Controls.Add(lb);
x = x + 100;
if (x > width - 25)
{
x = 0;
y = y + 100;
}
}
}
}
}

代码太多!这里就不一一贴出!
直接放源码:C# IBOX 程序管理简易版

 

对于API调用有兴趣的可以先看看:http://www.cnblogs.com/NatureSex/archive/2011/12/07/2278575.html

转载于:https://www.cnblogs.com/NatureSex/archive/2011/12/08/2280742.html

这篇关于C# 模仿 IBOX 程序管理 (简易版)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/452161

相关文章

2. c#从不同cs的文件调用函数

1.文件目录如下: 2. Program.cs文件的主函数如下 using System;using System.Collections.Generic;using System.Linq;using System.Threading.Tasks;using System.Windows.Forms;namespace datasAnalysis{internal static

C#实战|大乐透选号器[6]:实现实时显示已选择的红蓝球数量

哈喽,你好啊,我是雷工。 关于大乐透选号器在前面已经记录了5篇笔记,这是第6篇; 接下来实现实时显示当前选中红球数量,蓝球数量; 以下为练习笔记。 01 效果演示 当选择和取消选择红球或蓝球时,在对应的位置显示实时已选择的红球、蓝球的数量; 02 标签名称 分别设置Label标签名称为:lblRedCount、lblBlueCount

用命令行的方式启动.netcore webapi

用命令行的方式启动.netcore web项目 进入指定的项目文件夹,比如我发布后的代码放在下面文件夹中 在此地址栏中输入“cmd”,打开命令提示符,进入到发布代码目录 命令行启动.netcore项目的命令为:  dotnet 项目启动文件.dll --urls="http://*:对外端口" --ip="本机ip" --port=项目内部端口 例: dotnet Imagine.M

C# dateTimePicker 显示年月日,时分秒

dateTimePicker默认只显示日期,如果需要显示年月日,时分秒,只需要以下两步: 1.dateTimePicker1.Format = DateTimePickerFormat.Time 2.dateTimePicker1.CustomFormat = yyyy-MM-dd HH:mm:ss Tips:  a. dateTimePicker1.ShowUpDown = t

C#关闭指定时间段的Excel进程的方法

private DateTime beforeTime;            //Excel启动之前时间          private DateTime afterTime;               //Excel启动之后时间          //举例          beforeTime = DateTime.Now;          Excel.Applicat

C# 防止按钮botton重复“点击”的方法

在使用C#的按钮控件的时候,经常我们想如果出现了多次点击的时候只让其在执行的时候只响应一次。这个时候很多人可能会想到使用Enable=false, 但是实际情况是还是会被多次触发,因为C#采用的是消息队列机制,这个时候我们只需要在Enable = true 之前加一句 Application.DoEvents();就能达到防止重复点击的问题。 private void btnGenerateSh

C# double[] 和Matlab数组MWArray[]转换

C# double[] 转换成MWArray[], 直接赋值就行             MWNumericArray[] ma = new MWNumericArray[4];             double[] dT = new double[] { 0 };             double[] dT1 = new double[] { 0,2 };

C# Hash算法之MD5、SHA

MD5我们用的还是比较多的,一般用来加密存储密码。但是现在很多人觉MD5可能不太安全了,所以都用上了SHA256等来做加密(虽然我觉得都差不多,MD5还是能玩)。 还是跟上一篇说的一样,当一个算法的复杂度提高的同时肯定会带来效率的降低,所以SHA和MD5比较起来的话,SHA更安全,MD5更高效。 由于HASH算法的不可逆性,所以我认为MD5和SHA主要还是应用在字符串的"加密"上。 由于

js私有作用域(function(){})(); 模仿块级作用域

摘自:http://outofmemory.cn/wr/?u=http%3A%2F%2Fwww.phpvar.com%2Farchives%2F3033.html js没有块级作用域,简单的例子: for(var i=0;i<10;i++){alert(i);}alert(i); for循环后的i,在其它语言像c、java中,会在for结束后被销毁,但js在后续的操作中仍然能访

C#线程系列(1):BeginInvoke和EndInvoke方法

一、线程概述 在操作系统中一个进程至少要包含一个线程,然后,在某些时候需要在同一个进程中同时执行多项任务,或是为了提供程序的性能,将要执行的任务分解成多个子任务执行。这就需要在同一个进程中开启多个线程。我们使用 C# 编写一个应用程序(控制台或桌面程序都可以),然后运行这个程序,并打开 windows 任务管理器,这时我们就会看到这个应用程序中所含有的线程数,如下图所示。