WPF Rendertransform 发生抖动,TranslateTransform位置偏移;拖拽抖动

本文探讨了在WPF中使用TranslateTransform进行拖拽操作时出现的控件抖动问题,详细分析了原因并提供了两种解决方案:一是将源对象转换为Control控件以避免鼠标事件引起的抖动;二是针对触控事件,通过设置触控容器为父级控件来解决抖动现象。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

使用场景

我们需要将控件随着鼠标拖拽,位置实时随着鼠标偏移。

在对控件进行拖拽时,使用的是TranslateTransform对Image控件进行的平移操作。

  public MainWindow()
        {
            InitializeComponent();
            fieldsImage.RenderTransform = translateT;
        }

        TranslateTransform translateT = new TranslateTransform();

 为了让控件随鼠标拖拽而移动,我们在MouseDown事件中记录下当前鼠标的 位置,并在拖拽时计算偏移量。

  <Image Margin="0"  Source="{Binding ImageSource}" RenderTransform="{Binding TransGroup}" 
                   Name="fieldsImage"  MouseDown="ContentControl_MouseDown" 
                   MouseMove="ContentControl_MouseMove" MouseWheel="ContentControl_MouseWheel"  />
   private void ContentControl_MouseDown(object sender, MouseButt
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值