当前位置: 移动技术网 > IT编程>开发语言>.net > C#制作浮动图标窗体

C#制作浮动图标窗体

2019年06月28日  | 移动技术网IT编程  | 我要评论

普通相机,浪漫传说,伪装者第一季

先看效果:

  这个小图标可以进行随意拖拽,点击还可以产生事件

随便演示一下,效果就是这样的。

下面直接演示如何制作:

新建一个窗体,设置窗体的formborderstylenone(去掉窗体边框);

调整窗体的大小,和你的图标差不多大小就行,至于动态图,还在测试中,图标必须是没有背景的,因为有背景的图片展示出来,即时窗体透明,也会显示图片的白色背景,会很丑,所以要选没有背景的图片,可以网上找到之后自己拿ps把背景去掉,记住这里是图片背景,不是窗体背景!

窗体背景一般默认backcolorcontrol,可以不用改,

去属性中将transparencykey改为control,也就是和窗体背景颜色一致的背景色就行了,这样整个窗体就透明了,在窗体的backgroundimage中设置你找的无背景图片,要是太大,就把backgroundimagelayouyt设置为zoom

showintaskbar改为false(不会产生任务栏图标);

一定要设置topmosttrue(始终置顶);

设置好上面的就开始敲代码了

具体代码如下

 1 using system;
 2 using system.collections.generic;
 3 using system.componentmodel;
 4 using system.data;
 5 using system.drawing;
 6 using system.linq;
 7 using system.runtime.interopservices;
 8 using system.text;
 9 using system.threading.tasks;
10 using system.windows.forms;
11 
12 namespace ui
13 {
14     public partial class test01 : form
15     {
16         public test01()
17         {
18             initializecomponent();
19         }
20         //设置按鼠标移动窗体,调用外部接口
21         [dllimport("user32.dll")]
22         public static extern bool releasecapture();
23         [dllimport("user32.dll")]
24         public static extern bool sendmessage(intptr hwnd, int wmsg, int wparam, int lparam);
25         private void test01_mousedown(object sender, mouseeventargs e)
26         {
27             if (e.button == mousebuttons.left)
28             {
29                 form form = sender as form;
30                 point point = form.location;
31                 releasecapture(); //释放鼠标捕捉
32                 sendmessage(handle, 0xa1, 0x02, 0);
33                 if (form.location == point)
34                 {
35                     messagebox.show("哈哈");
36                 }
37 
38             }
39         }
40     }
41 }

 

可能前面有点啰嗦,希望大家不要责怪,因为我是怕新手拿到代码不知道怎么用,因为我也是从新手过来的,我也是个新手,深有同感。

希望能仔细看一下本课题中是如何处理在mousedown中式如何处理判断是点击还是拖动的,因为这个可能在以后会用到,这个问题我本人在网上查了好久都没有找到解决办法,然后自己想通过判断位置是否改变来实现的。

转载请注明出处,谢谢,我不太会排版,抱歉。这是原创的第一篇博客,请大家见谅!

 

如对本文有疑问,请在下面进行留言讨论,广大热心网友会与你互动!! 点击进行留言回复

相关文章:

验证码:
移动技术网