相对于单击的位置移动表单

时间:2013-05-11 18:37:16

标签: c# .net

我有一个表单可以在用户点击并拖动边框区域时移动。我看到的实现都锁定了当前的鼠标位置,因此当表单移动时,表单会跳转,以便鼠标位于左上角。我想改变它,使其行为像普通的窗体一样,并且移动时窗体相对于鼠标保持相同的位置。我目前的代码如下:

Point locationClicked;
bool isMouseDown = false;

private void Form1_MouseDown(object sender, MouseEventArgs e)
{
    isMouseDown = true;
    locationClicked = new Point(e.Location.X, e.Location.Y);
}

private void Form1_MouseUp(object sender, MouseEventArgs e)
{
    isMouseDown = false;
}

private void Form1_MouseMove(object sender, MouseEventArgs e)
{
    if (isMouseDown && targetCell == new Point(-1, -1) && (mouseLocation.X < margin.X || mouseLocation.Y < margin.Y ||
        mouseLocation.X > margin.X + cellSize.Width * gridSize.Width ||
        mouseLocation.Y > margin.Y + cellSize.Height * gridSize.Height))
    {
        this.Location = new Point(e.Location.X - locationClicked.X, e.Location.Y - locationClicked.Y);
    }
}

当我拖动窗口时,它的行为与我想要的相似。表格在屏幕上的两个位置之间闪烁,其中一个位置以鼠标速率的一半左右移动。有没有办法解决这个问题?

1 个答案:

答案 0 :(得分:3)

试试这个......

public partial class Form1 : Form
{
    public Form1()
    {
        InitializeComponent();
    }

    Point locationClicked;
    bool dragForm = false;

    private void Form1_MouseDown(object sender, MouseEventArgs e)
    {
        if (e.Button == System.Windows.Forms.MouseButtons.Left)
        {
            locationClicked = new Point(e.Location.X, e.Location.Y);
            if (isMouseDown && targetCell == new Point(-1, -1) && (mouseLocation.X < margin.X || mouseLocation.Y < margin.Y ||
                mouseLocation.X > margin.X + cellSize.Width * gridSize.Width ||
                mouseLocation.Y > margin.Y + cellSize.Height * gridSize.Height))
            {
                dragForm = true;
            }
        }

    }

    private void Form1_MouseMove(object sender, MouseEventArgs e)
    {
        if (dragForm)
        {
            this.Location = new Point(this.Location.X + (e.X - locationClicked.X), this.Location.Y + (e.Y - locationClicked.Y));
        }
    }

    private void Form1_MouseUp(object sender, MouseEventArgs e)
    {
        dragForm = false;
    }

}