前言
标签(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