码迷,mamicode.com
首页 > 移动开发 > 详细

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

时间:2014-05-31 12:36:30      阅读:337      评论:0      收藏:0      [点我收藏+]

标签:c   style   class   blog   code   java   

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

bubuko.com,布布扣
<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>
bubuko.com,布布扣
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的坐标系下,拖拽就没问题了。如下:

bubuko.com,布布扣
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);
        }
bubuko.com,布布扣

WPF: 旋转Thumb后,DragDelta移动距离出错的解决,布布扣,bubuko.com

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

标签:c   style   class   blog   code   java   

原文地址:http://www.cnblogs.com/xpvincent/p/3761225.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!