[现状]
我有一个自定义项控件,我将其添加到堆栈面板中,之后可以通过拖动自由移动。
public partial class CustomItem: UserControl
{
private bool IsDragging { get; set; }
private Point clickPosition;
public CustomItem()
{
InitializeComponent();
this.DataContext = this;
this.MouseLeftButtonDown += (s, ea) =>
{
clickPosition = ea.GetPosition(this.LayoutRoot);
this.CaptureMouse();
IsDragging = true;
};
this.MouseMove += (s, ea) =>
{
if (IsDragging)
{
this.transFormThisShit.X = ea.GetPosition(this).X - clickPosition.X;
this.transFormThisShit.Y = ea.GetPosition(this).Y - clickPosition.Y;
}
};
this.MouseLeftButtonUp += (s, ea) =>
{
this.ReleaseMouseCapture();
IsDragging = false;
};
}
[问题]
在我添加3个项目之后,我将第一个项目拖到第二个或第三个项目之后,它会跳到它后面。
当我将第二个项目拖过第一个项目时,它会在前面,但是当我将它拖到第三个项目上时,它会在它后面。
如何进行控制拖动始终位于可视化树的顶部?
答案 0 :(得分:2)
您可以将被拖动项目的ZIndex值设置为高于其他项目。数字越大,项目与屏幕“越接近”,因此最低数字将位于底部。
答案 1 :(得分:0)
当您开始拖动元素时,使用以下代码将其Canvas.ZIndex
属性设置为大于0的值:
Canvas.SetZIndex(element,99);
并在完成拖动后清除它:
element.ClearValue(Canvas.ZIndex);
应该这样做。