wpf Canvas 移动拖拽

#xaml    Canvas 事件

MouseLeftButtonDown="Canvas_MouseLeftButtonDown"

MouseMove="Canvas_MouseMove"

MouseLeftButtonUp="Canvas_MouseLeftButtonUp"

#后端

        private bool isDragging;
        private Point lastPosition;


        private void Canvas_MouseLeftButtonDown(object sender, MouseButtonEventArgs e)
        {
            isDragging = true;
            lastPosition = e.GetPosition(ZZCeng);
            ZZCeng.CaptureMouse();
        }

        private void Canvas_MouseMove(object sender, MouseEventArgs e)
        {
            if (isDragging)
            {
                Point currentPosition = e.GetPosition(ZZCeng);
                double differenceX = currentPosition.X - lastPosition.X;
                double differenceY = currentPosition.Y - lastPosition.Y;

                Canvas.SetLeft(ZZCeng.Children[0], Canvas.GetLeft(ZZCeng.Children[0]) + differenceX);
                Canvas.SetTop(ZZCeng.Children[0], Canvas.GetTop(ZZCeng.Children[0]) + differenceY);

                lastPosition = currentPosition;
            }
        }

        private void Canvas_MouseLeftButtonUp(object sender, MouseButtonEventArgs e)
        {
            isDragging = false;
            ZZCeng.ReleaseMouseCapture();
        }

ZZCeng 为 Canvas 的 Name 名称
当鼠标左键按下时,Canvas_MouseLeftButtonDown事件被触发,开始拖动操作。在Canvas_MouseMove事件中,根据鼠标移动的距离,更新Canvas中元素的位置。当鼠标左键释放时,Canvas_MouseLeftButtonUp事件被触发,结束拖动操作。

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值