时间:2021-05-20
实现控件拖动的基本原理是对鼠标位置的捕获,同时根据鼠标按键的按下、释放确定控件移动的幅度和时机。
简单示例:
在Grid中有一个Button,通过鼠标事件改编Button的Margin属性,从而改变Button在Grid中的相对位置。
<Grid Name="gd"> <Button Width=90 Height=30 Name="btn">button</Button></Grid>为Button控件绑定三个事件:鼠标按下、鼠标移动、鼠标释放
public SystemMap(){ InitializeComponent(); btn.MouseLeftButtonDown += btn_MouseLeftButtonDown; btn.MouseMove += btn_MouseMove; btn.MouseLeftButtonUp += btn_MouseLeftButtonUp;}定义变量+鼠标按下事件
Point pos = new Point();void btn_MouseLeftButtonDown(object sender, MouseButtonEventArgs e){ Button tmp = (Button)sender; pos = e.GetPosition(null); tmp.CaptureMouse(); tmp.Cursor = Cursors.Hand;}鼠标移动事件
void btn_MouseMove(object sender, MouseEventArgs e){ if (e.LeftButton==MouseButtonState.Pressed) { Button tmp = (Button)sender; double dx = e.GetPosition(null).X - pos.X + tmp.Margin.Left; double dy = e.GetPosition(null).Y - pos.Y + tmp.Margin.Top; tmp.Margin = new Thickness(dx, dy, 0, 0); pos = e.GetPosition(null); }}鼠标释放事件
void btn_MouseLeftButtonUp(object sender, MouseButtonEventArgs e){ Button tmp = (Button)sender; tmp.ReleaseMouseCapture();}以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
WPF实现窗体中的悬浮按钮,按钮可拖动,吸附停靠在窗体边缘。控件XAML代码:控件cs代码:usingSystem;usingSystem.Collection
本文实例讲述了WPF设置窗体可以使用鼠标拖动大小的方法。分享给大家供大家参考。具体实现方法如下:复制代码代码如下:privatevoidWindow_Loade
本文实例为大家分享了WPF实现轮播图切换效果的具体代码,供大家参考,具体内容如下实现效果如下:步骤:1、自定义控件MyImageControl实现图片的裁切和动
本文实例为大家分享了WinForm实现鼠标拖动控件跟随效果的具体代码,供大家参考,具体内容如下1.运行初始窗口如下:2.拖动后效果如下:3.代码如下:publi
本文实例为大家分享了WPF实现左右移动效果展示的具体代码,供大家参考,具体内容如下实现控件或布局的左右移动(晃动)主要用到DoubleAnimation以及St