• WPF: 旋转Thumb后,DragDelta移动距离出错的解决


    当Thumb跟随Grid旋转90度后,拖拽控件时会飞掉。

    <Grid x:Name="gridMain" Width="100" Height="50" Background="Green" RenderTransformOrigin="0.5,0.5" Canvas.Left="100" Canvas.Top="100"> 
                    <Grid.RenderTransform>
                        <RotateTransform x:Name="rotate" Angle="90"></RotateTransform>
                    </Grid.RenderTransform>
                    <Thumb x:Name="thumbMain" Opacity="0.8" DragDelta="Thumb_DragDelta"></Thumb>
                </Grid>
    private void Thumb_DragDelta(object sender, System.Windows.Controls.Primitives.DragDeltaEventArgs e)
            {
                Canvas.SetLeft(gridMain, Canvas.GetLeft(gridMain) + e.HorizontalChange);
                Canvas.SetTop(gridMain, Canvas.GetTop(gridMain) + e.VerticalChange);
            }

     

     

    这是由于坐标系不统一造成的。Canvas.SeltLeft 和 Canvas.SetTop是用的Canvas坐标系。而Thumb的e.HorizontalChange 和 e.VerticalChange 是根据鼠标相对于Thumb自身坐标系计算出来的, 两个坐标系有个90度的角度差。将e.HorizontalChange 和 e.VerticalChange转换到Canvas的坐标系下,拖拽就没问题了。如下:

    private void Thumb_DragDelta(object sender, System.Windows.Controls.Primitives.DragDeltaEventArgs e)
            {
                Point ptChange = rotate.Transform(new Point(e.HorizontalChange, e.VerticalChange));
                Canvas.SetLeft(gridMain, Canvas.GetLeft(gridMain) + ptChange.X);
                Canvas.SetTop(gridMain, Canvas.GetTop(gridMain) + ptChange.Y);
            }
  • 相关阅读:
    对position的认知观
    对于布局的见解
    Java中的多态
    继承中类型的转换
    继承中方法的覆盖
    继承条件下的构造方法调用
    Java函数的联级调用
    关于java中String的用法
    凯撒密码
    检查java 中有多少个构造函数
  • 原文地址:https://www.cnblogs.com/xpvincent/p/3761225.html
Copyright © 2020-2023  润新知