C# 实现桌面图片飘浮效果

来源:百度文库 编辑:神马文学网 时间:2024/04/28 15:52:10
读大学时写的桌面飘着Love(完全用GDI+绘制的),现在想让桌面飘着圣诞老人,其实稍微研究下,大家都会写,于是我想让代码更优美点。

如果想让桌面既飘着Love又飘着圣诞老人,怎么办呢,象装饰模式?不过不是。如果我想让程序全部封装成dll后,别人也能用很简单的代码进行扩展,怎么办呢?于是我定义好了整个结构,可以继承类然后写很简单的程序完成功能,无需修改我的类,可以支持运行时"热插拔"要显示到桌面飘着的Fly(比如通过配置app.config).

先看效果图吧:
christmas.jpg(168.12 K)
2008-12-13 21:18:21
上面是飘着圣诞老人
gdidiagram.jpg(107.10 K)
2008-12-13 21:18:21
上面是飘着LOVE
together.jpg(139.79 K)
2008-12-13 21:19:19
上面是飘着LOVE和圣诞老人一起
rightclick.jpg(102.46 K)
2008-12-13 21:19:19
上面是右键关于或者退出
configure.jpg(135.58 K)
2008-12-13 21:20:23
上面是关于
classDiagram.jpg(67.73 K)
2008-12-13 21:20:23
上面是类图
structure.jpg(15.82 K)
2008-12-13 21:26:09
上面是程序结构图
由于多种原因,我电脑WORD都没,所以没什么好的画图工具好表达上面的类图的关系。

其中ProxyImage类中采用了策略模式对采用什么图片进行出来。

在上面类图中:第一个注释里说:“ MainForm发送[多个]装载图片的命令给ProxyImage,而ProxyImage只返回[一个]图片给MainForm。”为什么是返回一个图片呢,原因有两点:第一:一个ILIST<>的一个对象只能装一个。第二:如果用其他方式返回两个,则会出现这种情况:如果显示LOVE,桌面可以飘100个,但如果桌面同时飘LOVE和圣诞老人,则桌面会飘着:200个,如果以后扩展,桌面飘着很多个,那桌面将会成为:N*100个,这个肯定不能这样。于是综合一些设计模式,我改造了下,变成现在我的程序的样子了。

如果我的程序全部编译为类库DLL文件了,要想扩展也非常方便。有两种情况:第一:用GDI+绘制图片,比如我这里的LOVE。第二:直接用图片。
第一种情况,扩展的类继承GdiImage抽象类,重载DrawImage方法,这个方法没有其它任何额外的代码,只做GDI+绘制;
第二种情况,扩展的类直接继承IImage接口,实现GetBitmap方法就行了。

如果想让桌面飘着的物体在运行时加载它,则可配置相应的配置文件则可。

程序中起桥梁作用的proxyImage类的代码如下:

proxyImage类代码
  1. #region 版权
  2. /*
  3. * 版权归Lawson所有
  4. * QQ:313769823
  5. * Blog:lawson.cnblogs.com
  6. */
  7. #endregion
  8. using System;
  9. using System.Collections;
  10. using System.Collections.Generic;
  11. using System.Drawing;
  12. using System.Text;
  13. namespace Main
  14. {
  15.     ///
  16.     /// 负责桌面飘动的图片处理
  17.     ///

  18.     public class ProxyImage
  19.     {
  20.        private static Hashtable imageList = new Hashtable();
  21.         ///
  22.         /// 默认构造函数
  23.         ///

  24.         public ProxyImage()
  25.         {
  26.             //无操作
  27.         }
  28.         ///
  29.         /// 添加图片种类
  30.         ///

  31.         /// 图片类型
  32.         public static void AddImage(IImage image)
  33.         {
  34.             imageList.Add(imageList.Count + 1, image);
  35.         }
  36.         ///
  37.         /// 获取图片
  38.         ///

  39.         /// 图片
  40.         public static Image GetImage()
  41.         {
  42.             object obj = null;
  43.             Image result = null;
  44.             if (imageList.Count == 1)
  45.             {
  46.                 obj = imageList[1];
  47.             }
  48.             else
  49.             {
  50.                 Random random = new Random();
  51.                 obj = imageList[random.Next(1, imageList.Count)];
  52.             }
  53.             if (obj == null)
  54.             {
  55.                 //防止扩展图片时,引用生成图片类而没先实例化它
  56.                 throw new Exception("添加生成图片类时请先实例化该类");
  57.             }
  58.             obj = obj as IImage;
  59.             if (obj != null)
  60.             {
  61.                 result = ((IImage)obj).GetBitmap();
  62.             }
  63.             else
  64.             {
  65.                 throw new Exception("GetImage时出错误了,您可以把给错误发送给我:)");
  66.             }
  67.             return result;
  68.         }
  69.     }
  70. }
复制代码

这个程序研究起来还是很有意思,肯定还有更好的方法,欢迎大家批评,这样不仅可以在实际项目中采用设计模式设计出更合理的软件架构,更重要的是它还能给我们带来快乐。(文/Lawson