Silverlight拖放功能相关应用技巧分享

Silverlight工具是一个非常有用的开发工具。可以帮助开发人员轻松实现基于多媒体播放操作等功能。在实际使用中,我们会体会到其强大的功能特定。在这里就先来了解其中Silverlight拖放功能的作用。#t#

创新互联坚持“要么做到,要么别承诺”的工作理念,服务领域包括:成都网站设计、做网站、企业官网、英文网站、手机端网站、网站推广等服务,满足客户于互联网时代的资中网站设计、移动媒体设计的需求,帮助企业找到有效的互联网解决方案。努力成为您成熟可靠的网络建设合作伙伴!

在Silverlight拖放功能的实现中,分为三个步骤:

1.按下鼠标,触发MouseLeftButtonDown事件,选择要拖动的对象。

2.移动鼠标,触发MouseMove事件,移动选择的对象。

3.放开鼠标,触发MouseLeftButtonUp事件,停止捕捉事件。

做一个简单的界面,用一个按钮来显示Silverlight拖放功能,如下XAML声明:

 
 
 
  1. < Canvas Background="#46461F"> 
  2. < Button   
  3. MouseLeftButtonDown="OnMouseDown"   
  4. MouseMove="OnMouseMove" 
  5. MouseLeftButtonUp="OnMouseUp"   
  6. Canvas.Left="50" Canvas.Top="50"
     Background="Red" 
  7. FontSize="18" 
  8. Width="160" Height="80"> 
  9. < Button.Content> 
  10. < StackPanel Orientation=
    "Horizontal" HorizontalAlignment
    ="Center" 
  11. VerticalAlignment="Center"> 
  12. < Image Source="smile_6.png">< /Image> 
  13. < TextBlock Text="拖动我" 
    VerticalAlignment="Center"
     Margin="10">< /TextBlock> 
  14. < /StackPanel> 
  15. < /Button.Content> 
  16. < /Button> 
  17. < /Canvas> 

这里为了界面显示效果,使用了控件模板,后续会专门讲到。

Silverlight拖放功能之开始拖放操作

开始拖放操作,实现MouseLeftButtonDown事件处理程序,用两个全局变量来记录当前鼠标的位置和鼠标是否保持移动。

 
 
 
  1. bool trackingMouseMove = false;  
  2. Point mousePosition;  
  3. void OnMouseDown(object sender, 
    MouseButtonEventArgs e)  
  4. {  
  5. FrameworkElement element = sender 
    as FrameworkElement;  
  6. mousePosition = e.GetPosition(null);  
  7. trackingMouseMove = true;  
  8. if (null != element)  
  9. {  
  10. element.CaptureMouse();  
  11. element.Cursor = Cursors.Hand;  
  12. }  

Silverlight拖放功能之移动对象

移动对象,实现MouseMove事件处理程序,计算元素的位置并更新,同时更新鼠标的位置。

 
 
 
  1. void OnMouseMove(object sender, 
    MouseEventArgs e)  
  2. {  
  3. FrameworkElement element = 
    sender as FrameworkElement;  
  4. if (trackingMouseMove)  
  5. {  
  6. double deltaV = e.GetPosition(null).
    Y - mousePosition.Y;  
  7. double deltaH = e.GetPosition(null).
    X - mousePosition.X;  
  8. double newTop = deltaV + (double)
    element.GetValue(Canvas.TopProperty);  
  9. double newLeft = deltaH + (double)
    element.GetValue(Canvas.LeftProperty);  
  10. element.SetValue(Canvas.TopProperty, newTop);  
  11. element.SetValue(Canvas.LeftProperty, newLeft);  
  12. mousePosition = e.GetPosition(null);  
  13. }  

Silverlight拖放功能之完成拖放操作

完成拖放操作,实现MouseLeftButtonUp事件处理程序。

 
 
 
  1. void OnMouseUp(object sender, 
    MouseButtonEventArgs e)  
  2. {  
  3. FrameworkElement element = 
    sender as FrameworkElement;  
  4. trackingMouseMove = false;  
  5. element.ReleaseMouseCapture();  
  6. mousePositionmousePosition.X = 
    mousePosition.Y = 0;  
  7. element.Cursor = null;  

本文名称:Silverlight拖放功能相关应用技巧分享
文章源于:http://www.csdahua.cn/qtweb/news0/80600.html

网站建设、网络推广公司-快上网,是专注品牌与效果的网站制作,网络营销seo公司;服务项目有等

广告

声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 快上网