WPF拖放源代码

8
几乎所有与WPF中的拖放相关的StackOverflow问题都会回溯到这篇文章。但是文章的源代码已经丢失。是否有人有备份或知道在哪里可以找到备份?
附言:我主要关心这篇文章中的一行话:“DragAdorner中有更多的代码,但主要用于定位adorner如何随着拖动而发生变化...请参考示例...”我不知道他是如何定位拖动adorner的。

如果您还没有尝试过,页面上有一个链接可以给博客作者发送电子邮件。 - Benjamin Gale
谢谢,我也给作者发了电子邮件。 - Nathan Hillyer
我用过那段代码。它真的很有 bug。如果你想要实际应用,你将需要修复很多小细节。 - Lee Louviere
啊,也许这样做是最好的。感谢您的反馈。 - Nathan Hillyer
3个回答

3

我有一些基于原博客系列的工作代码。完整的代码太长了,无法在这里发布;我已经将其发布到PasteBin

DragAdorner中的代码非常简单:

internal sealed class DragAdorner : Adorner
{
   private readonly UIElement _child;
   private readonly double _xCenter;
   private readonly double _yCenter;
   private double _leftOffset;
   private double _topOffset;

   public DragAdorner(UIElement owner, UIElement child, bool useVisualBrush, double opacity) : base(owner)
   {
      if (!useVisualBrush)
      {
         _child = child;
      }
      else
      {
         var size = GetRealSize(child);
         _xCenter = size.Width / 2;
         _yCenter = size.Height / 2;

         _child = new Rectangle
         {
            RadiusX = 3,
            RadiusY = 3,
            Width = size.Width,
            Height = size.Height,
            Fill = new VisualBrush(child)
            {
               Opacity = opacity,
               AlignmentX = AlignmentX.Left,
               AlignmentY = AlignmentY.Top,
               Stretch = Stretch.None,
            },
         };
      }
   }

   protected override int VisualChildrenCount
   {
      get { return 1; }
   }

   public double LeftOffset
   {
      get
      {
         return _leftOffset + _xCenter;
      }
      set
      {
         _leftOffset = value - _xCenter;
         UpdatePosition();
      }
   }

   public double TopOffset
   {
      get
      {
         return _topOffset + _yCenter;
      }
      set
      {
         _topOffset = value - _yCenter;
         UpdatePosition();
      }
   }

   private static Size GetRealSize(UIElement child)
   {
      return child == null ? Size.Empty : child.RenderSize;
   }

   public void UpdatePosition(Point point)
   {
      _leftOffset = point.X;
      _topOffset = point.Y;
      UpdatePosition();
   }

   public void UpdatePosition()
   {
      var adorner = Parent as AdornerLayer;
      if (adorner != null) adorner.Update(AdornedElement);
   }

   protected override Visual GetVisualChild(int index)
   {
      if (0 != index) throw new ArgumentOutOfRangeException("index");
      return _child;
   }

   protected override Size MeasureOverride(Size availableSize)
   {
      _child.Measure(availableSize);
      return _child.DesiredSize;
   }

   protected override Size ArrangeOverride(Size finalSize)
   {
      _child.Arrange(new Rect(_child.DesiredSize));
      return finalSize;
   }

   public override GeneralTransform GetDesiredTransform(GeneralTransform transform)
   {
      var result = new GeneralTransformGroup();
      result.Children.Add(new TranslateTransform(_leftOffset, _topOffset));

      var baseTransform = base.GetDesiredTransform(transform);
      if (baseTransform != null) result.Children.Add(baseTransform);

      return result;
   }
}

1
我通过电子邮件联系作者,得到了回复,作者表示他已不再拥有该文章的源代码。

如果你需要的话,我有一些基于原始文章的可用代码。 - Richard Deeming
如果可以的话,那太好了!我设法解决了这个问题,但其他人可能会遇到同样的问题。 - Nathan Hillyer

0

请查看Bea Stollnitz的博客

http://www.zagstudio.com/blog/488#.UQRZCL9fA7X 

这个拖放示例是早期WPF相对较新时的首批样例之一。它确实帮助了我和我的同事们...


现在也已经下架了。文章可以在Web Archive上找到 https://web.archive.org/web/20150912232819/http://www.zagstudio.com:80/blog/488#.WpnN2qjwa70 (希望这些Web Archive链接能够有效一段时间) - FrankyB

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接