C# 图片框跟随鼠标移动
2010-05-27 20:58
981 查看
先贴上代码
private bool isMouseDown = false;
private Point mouseOffset; //记录鼠标指针的坐标
private void PicBox_MouseDown(object sender, MouseEventArgs e)
{
if (e.Button == MouseButtons.Left)
{
mouseOffset.X = e.X;
mouseOffset.Y = e.Y;
isMouseDown = true;
}
}
private void PicBox_MouseMove(object sender, MouseEventArgs e)
{
if (isMouseDown)
{
int left = PicBox.Left + e.X - mouseOffset.X;
int top = PicBox.Top + e.Y - mouseOffset.Y;
PicBox.Location = new Point(left,top);
}
}
private void PicBox_MouseUp(object sender, MouseEventArgs e)
{
if (e.Button == MouseButtons.Left)
{
isMouseDown = false;
}
}
事件中的 MouseEventArgs e :
根据e得到的坐标,不是鼠标相对与Form左上角的坐标,而是相对于图片框的左上角坐标,所以算鼠标偏移量的时候,只要计算两次事件对象e中的坐标的差值!
保存鼠标按下时相对于图片框左上角的坐标
mouseOffset.X = e.X;
mouseOffset.Y = e.Y;
移动时得到偏移量
e.X - mouseOffset.X;
e.Y - mouseOffset.Y;
算出图片框的新位置
int left = PicBox.Left + e.X - mouseOffset.X;
int top = PicBox.Top + e.Y - mouseOffset.Y;
private bool isMouseDown = false;
private Point mouseOffset; //记录鼠标指针的坐标
private void PicBox_MouseDown(object sender, MouseEventArgs e)
{
if (e.Button == MouseButtons.Left)
{
mouseOffset.X = e.X;
mouseOffset.Y = e.Y;
isMouseDown = true;
}
}
private void PicBox_MouseMove(object sender, MouseEventArgs e)
{
if (isMouseDown)
{
int left = PicBox.Left + e.X - mouseOffset.X;
int top = PicBox.Top + e.Y - mouseOffset.Y;
PicBox.Location = new Point(left,top);
}
}
private void PicBox_MouseUp(object sender, MouseEventArgs e)
{
if (e.Button == MouseButtons.Left)
{
isMouseDown = false;
}
}
事件中的 MouseEventArgs e :
根据e得到的坐标,不是鼠标相对与Form左上角的坐标,而是相对于图片框的左上角坐标,所以算鼠标偏移量的时候,只要计算两次事件对象e中的坐标的差值!
保存鼠标按下时相对于图片框左上角的坐标
mouseOffset.X = e.X;
mouseOffset.Y = e.Y;
移动时得到偏移量
e.X - mouseOffset.X;
e.Y - mouseOffset.Y;
算出图片框的新位置
int left = PicBox.Left + e.X - mouseOffset.X;
int top = PicBox.Top + e.Y - mouseOffset.Y;
相关文章推荐
- C# 图片框跟随鼠标移动
- C#文字跟随鼠标移动
- ASP.NET案例--图片框跟随鼠标移动.doc
- C#图片框跟随鼠标移动_Asp_net教程__Net教程_Vb_net教程_Vc_net_C#编程.txt
- 仿265网址导航logo的两只眼睛跟随鼠标移动js实现方法
- C#GDI绘制矩形框,用鼠标移动、放大缩小矩形框
- c#实现随鼠标移动窗体
- C# 鼠标移动到指定位置,并且单击
- 背景图跟随鼠标移动的Mootools插件
- 给网页添加跟随你鼠标移动的线条动画
- 跟随鼠标移动-实例
- 文字或图片跟随鼠标移动或键盘控制图片移动实例(javascript实现)
- C#:鼠标移动None Form界面
- 第3课 02 JS中级课程-event-事件(跟随鼠标移动的div)
- Javascript 鼠标移动上去 滑块跟随效果代码分享
- datagrid 上面的行的光亮条跟随鼠标移动
- jquery 鼠标停留显示提示框,提示框位置跟随鼠标移动
- [脚本]实现游戏对象跟随鼠标方向移动
- U3D 小球跟随鼠标在地上移动(二)
- 跟随鼠标单击移动的div