服务器之家

服务器之家 > 正文

winform实现可拖动的自定义Label控件

时间:2022-02-22 13:30     来源/作者:炒饭君

本文实例为大家分享了winform可拖动的自定义label控件,供大家参考,具体内容如下

效果预览:

winform实现可拖动的自定义Label控件

实现步骤如下:

(1)首先在项目上右击选择:添加->新建项,添加自定义控件

winform实现可拖动的自定义Label控件

winform实现可拖动的自定义Label控件

(2)自定义的一个label让它继承labelcontrol控件,labelcontrol控件是devexpress控件库里面的一种,和label控件差不多,想了解更多关于devexpress控件,推荐到devexpress控件论坛学习:

?
1
public partial class labelmodule : labelcontrol

(3)这个label需要实现的mousedown。

?
1
2
3
4
5
6
7
private void labelmodule_mousedown(object sender, mouseeventargs e)
   {
     ismousedown = true;
     mousepreposition = new point(e.x, e.y);
     this.borderstyle = devexpress.xtraeditors.controls.borderstyles.simple;
     this.cursor = cursors.sizeall;
   }

(4)mouseup,也就是鼠标弹起的方法。

?
1
2
3
4
5
6
private void labelmodule_mouseup(object sender, mouseeventargs e)
    {
      ismousedown = false;
      this.borderstyle = devexpress.xtraeditors.controls.borderstyles.default;
      this.cursor = cursors.default;
    }

(5)mousemove,也就是鼠标移动时的方法。

?
1
2
3
4
5
6
private void labelmodule_mousemove(object sender, mouseeventargs e)
    {
      if (!ismousedown) return;
      this.top = this.top + (e.y - mousepreposition.y);
      this.left = this.left + (e.x - mousepreposition.x);
    }

e.x,e.y 指的是:鼠标的坐标因所引发的事件而异。例如,当处理 control.mousemove 事件时,鼠标的坐标值是相对于引发事件的控件的坐标。一些与拖放操作相关的事件具有相对于窗体原点或屏幕原点的关联的鼠标坐标值。

完整代码:labelmodule.cs

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
using system;
using system.collections.generic;
using system.componentmodel;
using system.data;
using system.drawing;
using system.linq;
using system.text;
using system.windows.forms;
using devexpress.xtraeditors;
 
namespace ijprintersoftware
{
  public partial class labelmodule : labelcontrol
  {
    private bool ismousedown = false;
    private point mousepreposition;
    
    private void init()
    {
      initializecomponent();
      this.mousedown += new mouseeventhandler(labelmodule_mousedown);
      this.mouseup += new mouseeventhandler(labelmodule_mouseup);
      this.mousemove+=new mouseeventhandler(labelmodule_mousemove);
    }
 
    public labelmodule()
    {
      init();
    }
 
    private void labelmodule_mousedown(object sender, mouseeventargs e)
    {
      ismousedown = true;
      mousepreposition = new point(e.x, e.y);
      this.borderstyle = devexpress.xtraeditors.controls.borderstyles.simple;
      this.cursor = cursors.sizeall;
    }
 
    private void labelmodule_mouseup(object sender, mouseeventargs e)
    {
      ismousedown = false;
      this.borderstyle = devexpress.xtraeditors.controls.borderstyles.default;
      this.cursor = cursors.default;
    }
 
    private void labelmodule_mousemove(object sender, mouseeventargs e)
    {
      if (!ismousedown) return;
      this.top = this.top + (e.y - mousepreposition.y);
      this.left = this.left + (e.x - mousepreposition.x);
    }
  }
}

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持服务器之家。

原文链接:https://blog.csdn.net/a1061747415/article/details/47656307

标签:

相关文章

热门资讯

蜘蛛侠3英雄无归3正片免费播放 蜘蛛侠3在线观看免费高清完整
蜘蛛侠3英雄无归3正片免费播放 蜘蛛侠3在线观看免费高清完整 2021-08-24
2022年最旺的微信头像大全 微信头像2022年最新版图片
2022年最旺的微信头像大全 微信头像2022年最新版图片 2022-01-10
背刺什么意思 网络词语背刺是什么梗
背刺什么意思 网络词语背刺是什么梗 2020-05-22
yue是什么意思 网络流行语yue了是什么梗
yue是什么意思 网络流行语yue了是什么梗 2020-10-11
2020微信伤感网名听哭了 让对方看到心疼的伤感网名大全
2020微信伤感网名听哭了 让对方看到心疼的伤感网名大全 2019-12-26
返回顶部