繁体   English   中英

用鼠标移动PictureBox

[英]Move a PictureBox with mouse

我正在为Windows Mobile开发一个应用程序(Compact Framework 2.0)。 它有一个带有PictureBox的WinForms。

我想移动PictureBox的图像,但我不知道该怎么做,所以我选择移动孔PictureBox。

为此,我使用此事件:

private void imagenMapa_MouseMove(object sender, MouseEventArgs e)
{
      imagenMapa.Left = e.X;
      imagenMapa.Top = e.Y;
      this.Refresh();
}

但是当我移动PictureBox时,它会闪烁并移动到每个地方。

我做错了什么?

eXeY相对于图片框(例如,如果鼠标位于图片框的左上角,则为0,0)。

imagenMapa.LeftimagenMapa.Top的值是相对于表单(或任何控件包含imagenMapa

如果你试图在没有转换的情况下混合来自这两个系统的值,你就会得到跳跃(就像你所看到的那样)。

你可能最好将鼠标位置转换为包含图片框的东西所使用的相同坐标系。

您可以使用imagenMapa.PointToScreen来获取屏幕坐标中的鼠标坐标(或者Cursor.Position直接获取位置),并使用yourForm.PointToClient将它们返回到窗体坐标中。

请注意,根据您的需要,您可以通过覆盖/处理控件的Paint事件并自己绘制图像来完成“在控件内移动图像”。 如果你这样做,你可以将所有内容保存在图片框坐标中,因为这些可能是你在调用graphicsObject.DrawImage时使用的内容。

实际代码(需要.NET Framework 3.5及更高版本,不确定它是否在Compact Framework中可用)...

// Global Variables
private int _xPos;
private int _yPos;
private bool _dragging;

// Register mouse events
pictureBox.MouseUp += (sender, args) =>
{
    var c = sender as PictureBox;
    if (null == c) return;
    _dragging = false;
};

pictureBox.MouseDown += (sender, args) =>
{
    if (args.Button != MouseButtons.Left) return;
    _dragging = true;
    _xPos = args.X;
    _yPos = args.Y;
};

pictureBox.MouseMove += (sender, args) =>
{
    var c = sender as PictureBox;
    if (!_dragging || null == c) return;
    c.Top = args.Y + c.Top - _yPos;
    c.Left = args.X + c.Left - _xPos;
};

拥抱数学!

control.Left = control.Left - (_lastMousePos.X - currentMousePos.X);
control.Top = control.Top - (_lastMousePos.Y - currentMousePos.Y);

快速说明:您从鼠标位置获得差异并将其应用于您想要移动的对象。

示例:如果旧鼠标X位置为382,而新鼠标位置为385,则差值为-3。 如果控制当前X位置是10然后10 - ( - 3)= 13

原因:它适用于任何事物,并且比不断地来回转换坐标要便宜得多。

eX&eY位于pictureBox的坐标空间中,imagenMapa.Left&imagenMapa.Top位于Form的坐标空间中。 :-)

另外不要忘记将表单设置为双缓冲,这可能有助于闪烁,但对于它的实际定位,我喜欢Daniel的建议

实际上你所做的是正确的。 但是您将MouseMove属性赋予了图片框。 您应该将该属性提供给表格(背景)。

例如:

private void Form1_MouseMove(object sender, MouseEventArgs e)
{
  imagenMapa.Left = e.X;
  imagenMapa.Top = e.Y;
}

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM