【C#/WPF】用Thumb做可拖拽的UI控件
生活随笔
收集整理的這篇文章主要介紹了
【C#/WPF】用Thumb做可拖拽的UI控件
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
【C#/WPF】用Thumb做可拖拽的UI控件 原文:【C#/WPF】用Thumb做可拖拽的UI控件
需求:簡單的可拖拽的圖片
使用System.Windows.Controls.Primitives.Thumb類
前臺:
<Canvas x:Name="g"><Thumb Canvas.Left="10" Canvas.Top="20" Canvas.ZIndex="99" DragDelta="Thumb_DragDelta"><Thumb.Template><ControlTemplate><Image Width="60" Height="60" Source="你的圖片路徑"/></ControlTemplate></Thumb.Template></Thumb> </Canvas>后臺:
private void Thumb_DragDelta(object sender, System.Windows.Controls.Primitives.DragDeltaEventArgs e) {UIElement thumb = e.Source as UIElement;// 防止Thumb控件被拖出容器。 // if (nTop <= 0)// nTop = 0;// if (nTop >= (g.Height - myThumb.Height))// nTop = g.Height - myThumb.Height;// if (nLeft <= 0)// nLeft = 0;// if (nLeft >= (g.Width - myThumb.Width))// nLeft = g.Width - myThumb.Width;// Canvas.SetTop(myThumb, nTop);// Canvas.SetLeft(myThumb, nLeft);// tt.Text = "Top:" + nTop.ToString() + "\nLeft:" + nLeft.ToString();Canvas.SetLeft(thumb, Canvas.GetLeft(thumb) + e.HorizontalChange);Canvas.SetTop(thumb, Canvas.GetTop(thumb) + e.VerticalChange); }坑點:
- Thumb必須是一個Canvas的子類,因為它依賴該Canvas來定位。
- Thumb必須協商Canvas.Left和Canvas.Top,因為它依賴該Vanvas來定位,否則無法拖動!
重要的參考:
- https://wpf.2000things.com/2012/12/19/715-using-the-thumb-control-to-drag-objects-on-a-canvas/
- https://msdn.microsoft.com/en-us/library/system.windows.controls.primitives.thumb(v=vs.110).aspx
轉載于:https://www.cnblogs.com/lonelyxmas/p/9473503.html
總結
以上是生活随笔為你收集整理的【C#/WPF】用Thumb做可拖拽的UI控件的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: Mysql partition by
- 下一篇: SpringCloud介绍(一)