前言
标签(label)控件是最常用的控件,在任何windows应用程序中都可以中都可以看到标签控件。标签控件用于显示用户不能编辑的文件或图像,常用于对窗体上各种控件进行标注或说明。
在窗体中添加标签控件时,会创建一个label类的实例。label控件派生自control控件,和其他控件一样支持事件,但通常不需要添加任何事件代码。
本文主要给大家介绍了关于c#用label标签控件模拟窗体标题移动及窗体颜色不断变换的相关内容,分享出来供大家参考学习,下面话不多说了,来一起看看详细的介绍吧。
开发工具:vs2017
语言:c#
dotnet版本:.net framework 4.0及以上
一、使用的win32 api有两个,一个为releasecapture,另外一个为sendmessage,这两个函数说明如下:
releasecapture函数:为了说明releasecapture的用法,需要先知道setcapture的用法,msdn是这样描述setcapture函数:
该函数在属于当前线程的指定窗口里设置鼠标捕获。一旦窗口捕获了鼠标,所有鼠标输入都针对该窗口,无论光标是否在窗口的边界内。同一时刻只能有一个窗口捕获鼠标。如果鼠标光标在另一个线程创建的窗口上,只有当鼠标键按下时系统才将鼠标输入指向指定的窗口。
而releasecapture悄悄相反,函数的功能就是释放对鼠标的捕捉。
为什么要使用这个releasecapture函数,原因在于移动窗体标题时,需要释放对鼠标的捕捉,否则,就不能移动窗体标题。
sendmessage函数:该函数是用来给窗体发送windows消息,
在本文中,该函数是模拟给非窗体客户区域(如窗体标题、最大化、最小化及关闭按钮区域)发送windows消息,使特定区域能收到拖动窗体标题的消息。
两者在c#的定义如下:
1
2
|
[dllimport( "user32.dll" )] static extern void releasecapture(); |
1
2
|
[dllimport( "user32.dll" )] static extern void sendmessage(intptr hwnd, int msg, int wparam, int lparam); |
关于hwnd、msg、wparam,lparam的具体说明,可以自行百度。
二、构建模拟移动窗体标题的应用程序,在这里我们使用了一个label(左边,label1),用来将鼠标移到该控件并拖动时,可以移动窗体,
另外一个label(右边,label2)则用来关闭窗体,如下图所示:
我们在label1的mousedown事件写下如下代码:
1
2
3
4
5
|
private void label1_mousedown( object sender, mouseeventargs e) { releasecapture(); sendmessage(handle, wm_nclbuttondown, ht_caption, 0); } |
其中,wm_nclbuttondown(0x00a1),用来给非客户端发送左键按下消息,
ht_caption(0x0002),为所需要作用的区域,此次为窗体标题。
我们在label2的mouseenter、mouserleave、click事件写下如下代码:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
|
private void label2_mouseenter( object sender, eventargs e) { label2.backcolor = color.fromargb(255, 192, 191); tooltip1.settooltip(label2, "关闭" ); } private void label2_mouseleave( object sender, eventargs e) { label2.backcolor = color.silver; tooltip1.settooltip(label2, "" ); } private void label2_click( object sender, eventargs e) { this .close(); } |
其中,需要为关闭按钮填写显示“关闭”按钮的提示,因此需要使用tooltip控件。
三、窗体颜色变换
这里主要用到了一个变换彩虹颜色的算法,参考如下:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
|
public static color rainbow( float progress) { var div = (math.abs(progress % 1) * 6); var ascending = ( int )((div % 1) * 255); var descending = 255 - ascending; switch (( int )div) { case 0: return color.fromargb(255, 255, ascending, 0); case 1: return color.fromargb(255, descending, 255, 0); case 2: return color.fromargb(255, 0, 255, ascending); case 3: return color.fromargb(255, 0, descending, 255); case 4: return color.fromargb(255, ascending, 0, 255); default : return color.fromargb(255, 255, 0, descending); } } |
可以借用一个while循环,内部再嵌套一个for循环,达到不断变换颜色的目的,如下代码所示:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
|
private void changecolor() { task.factory.startnew(() => { color color; while ( true ) { try { for ( float i = 0; i < 1f; i += 0.01f) { color = rainbow(i); this .invoke((action)(() => { backcolor = color; })); thread.sleep(150); } } catch { } } }); } |
四、构建完的程序界面如下:
五、源代码及exe如下:
源代码:
exe:
总结
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,如果有疑问大家可以留言交流,谢谢大家对服务器之家的支持。
原文链接:http://www.cnblogs.com/cncc/p/8005667.html