Wpf控件移动

     

<Window x:Class="WpfApp4.MainWindow"
        xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
        xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
        xmlns:d="http://schemas.microsoft.com/expression/blend/2008"
        xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"
        xmlns:MyControls="clr-namespace:WpfControls;assembly=WpfControls"
        mc:Ignorable="d"
        Title="MainWindow" Height="450" Width="800">
    <Grid x:Name="MyGrid">       
        <Button x:Name="btn" Content="Button" HorizontalAlignment="Left" Margin="100,100,0,0" VerticalAlignment="Top" Width="100"/>
    </Grid>
</Window>

        public MainWindow()
        {
            InitializeComponent();

            btn.AddHandler(Control.MouseLeftButtonDownEvent, new MouseButtonEventHandler(this.Btn_MouseLeftButtonDown), true);
            btn.AddHandler(Control.MouseLeftButtonUpEvent, new MouseButtonEventHandler(this.Btn_MouseLeftButtonUp), true);

            btn.MouseLeftButtonDown += Btn_MouseLeftButtonDown;
            btn.PreviewMouseMove += Btn_PreviewMouseMove;
            btn.MouseLeftButtonUp += Btn_MouseLeftButtonUp;
        }

        Point pos = new Point();

        private void Btn_MouseLeftButtonUp(object sender, MouseButtonEventArgs e)
        {
            FrameworkElement tmp = (FrameworkElement)sender;
            trackMouseMove = false;
            tmp.ReleaseMouseCapture();
            tmp.Cursor = null;
        }

        private void Btn_PreviewMouseMove(object sender, MouseEventArgs e)
        {
            if (trackMouseMove)
            {
                FrameworkElement tmp = (FrameworkElement)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);
            }
        }

        private void Btn_MouseLeftButtonDown(object sender, MouseButtonEventArgs e)
        {
            FrameworkElement tmp = (FrameworkElement)sender;
            trackMouseMove = true;
            pos = e.GetPosition(null);
            tmp.CaptureMouse();
            tmp.Cursor = Cursors.Hand;
        }

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
WPF中的Thumb控件通常用于实现可拖动的控件或者可调整大小的控件。可以通过设置Thumb控件的拖动和调整大小事件来实现控件移动和缩放。 例如,可以使用Thumb控件来实现一个可拖动和可调整大小的矩形控件,代码如下: ```xaml <Grid> <Rectangle Width="100" Height="100" Fill="Blue"> <Rectangle.RenderTransform> <TransformGroup> <TranslateTransform x:Name="translateTransform"/> <ScaleTransform x:Name="scaleTransform"/> </TransformGroup> </Rectangle.RenderTransform> </Rectangle> <Thumb Width="10" Height="10" DragDelta="Thumb_DragDelta" DragStarted="Thumb_DragStarted" DragCompleted="Thumb_DragCompleted" Canvas.Right="-5" Canvas.Bottom="-5"/> </Grid> ``` 在代码中,Rectangle控件使用了RenderTransform来实现控件移动和缩放。Thumb控件的DragDelta事件用于处理拖动过程中的事件,DragStarted和DragCompleted事件用于处理开始和结束拖动的事件。 ```csharp private Point _lastPosition; private double _lastWidth; private double _lastHeight; private void Thumb_DragStarted(object sender, DragStartedEventArgs e) { _lastPosition = Mouse.GetPosition(this); _lastWidth = ((FrameworkElement)Content).ActualWidth; _lastHeight = ((FrameworkElement)Content).ActualHeight; } private void Thumb_DragDelta(object sender, DragDeltaEventArgs e) { var position = Mouse.GetPosition(this); var dx = position.X - _lastPosition.X; var dy = position.Y - _lastPosition.Y; var scaleX = (_lastWidth + e.HorizontalChange) / _lastWidth; var scaleY = (_lastHeight + e.VerticalChange) / _lastHeight; translateTransform.X += dx; translateTransform.Y += dy; scaleTransform.ScaleX *= scaleX; scaleTransform.ScaleY *= scaleY; } private void Thumb_DragCompleted(object sender, DragCompletedEventArgs e) { _lastPosition = default(Point); _lastWidth = 0; _lastHeight = 0; } ``` 在代码中,DragStarted事件记录了拖动前的位置和大小,DragDelta事件计算出当前的位置和大小,并更新RenderTransform的TranslateTransform和ScaleTransform属性,最后DragCompleted事件重置拖动前的状态。 这样就可以实现一个可拖动和可调整大小的矩形控件了。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值