如何正确实现Silverlight拖拽功能

开发 开发工具
Silverlight拖拽功能的实现方法是一个比较复杂的过程。在这篇文章中,初学者可以通过一段代码范例来具体的解读这一技巧。

Silverlight拖拽功能的实现再实际开发编程中是一个非常重要的基础功能。对于一个开发人员来说,如果想要很好的使用Silverlight来实现相关功能需求,就需要牢固掌握这些基础功能的应用。#t#

下面的示例演示如何在基于 Silverlight 的应用程序中拖放对象。出于安全考虑,不能在应用程序之间拖放对象。因此,说成在 Silverlight 插件区域内"滑动"对象更为准确。但是,术语"拖放"更为人知,因此在此处使用。

Silverlight拖拽功能Xaml脚本:

 

  1. < UserControl x:Class=
    "DragAndDropSimple.Page" 
  2. xmlns="http://schemas.microsoft.
    com/winfx/2006/xaml/presentation"
       
  3. xmlns:x="http://schemas.
    microsoft.com/winfx/2006/xaml"
       
  4. Width="400" Height="300"> 
  5. < Canvas x:Name="rootCanvas" 
  6. Width="640" 
  7. Height="480" 
  8. Background="Gray" 
  9. > 
  10. < !-- You can drag this 
    rectangle around the canvas. --
    > 
  11. < Rectangle 
  12. MouseLeftButtonDown=
    "Handle_MouseDown" 
  13. MouseMove="Handle_MouseMove" 
  14. MouseLeftButtonUp="Handle_MouseUp" 
  15. Canvas.Left="30" Canvas.
    Top
    ="30" Fill="Red" 
  16. Width="50" Height="50" /> 
  17. < /Canvas> 
  18. < /UserControl> 

 

后置代码:

 

  1. // Global variables used to 
    keep track of the   
  2. // mouse position and whether 
    the object is captured  
  3. // by the mouse.  
  4. bool isMouseCaptured;  
  5. double mouseVerticalPosition;  
  6. double mouseHorizontalPosition;  
  7. public void Handle_MouseDown 
    (object sender, MouseEventArgs args)   
  8. {  
  9. Rectangle item = sender as Rectangle;  
  10. mouseVerticalPosition = args.
    GetPosition(null).Y;  
  11. mouseHorizontalPosition = 
    args.GetPosition(null).X;  
  12. isMouseCaptured = true;  
  13. item.CaptureMouse();  
  14. }  
  15. public void Handle_MouseMove
    (object sender, MouseEventArgs args)   
  16. {  
  17. Rectangle item = sender as Rectangle;  
  18. if (isMouseCaptured)   
  19. {  
  20. // Calculate the current 
    position of the object.  
  21. double deltaV = args.GetPosition(null).
    Y - mouseVerticalPosition;  
  22. double deltaH = args.GetPosition(null).
    X - mouseHorizontalPosition;  
  23. double newTop = deltaV + (double)
    item.GetValue(Canvas.TopProperty);  
  24. double newLeft = deltaH + (double)
    item.GetValue(Canvas.LeftProperty);  
  25. // Set new position of object.  
  26. item.SetValue(Canvas.TopProperty, newTop);  
  27. item.SetValue(Canvas.LeftProperty, newLeft);  
  28. // Update position global variables.  
  29. mouseVerticalPosition = args.
    GetPosition(null).Y;  
  30. mouseHorizontalPosition = args.
    GetPosition(null).X;  
  31. }  
  32. }  
  33. public void Handle_MouseUp(object 
    sender, MouseEventArgs args)   
  34. {  
  35. Rectangle item = sender as Rectangle;  
  36. isMouseCaptured = false;  
  37. item.ReleaseMouseCapture();  
  38. mouseVerticalPosition = -1;  
  39. mouseHorizontalPosition = -1;  

 

Silverlight拖拽功能的实现方法就为大家介绍到这里啦。

责任编辑:曹凯 来源: 博客园
相关推荐

2010-02-25 10:10:29

WCF使用Header

2009-12-03 11:11:57

PHP网站优化

2009-12-11 17:52:21

PHP获取博客数据

2009-12-07 18:42:55

PHP与Javascr

2009-12-04 12:51:27

PHP functio

2009-12-09 16:49:09

PHP显示文章发布时间

2010-01-06 15:56:18

.Net Framew

2010-04-29 17:31:56

Oracle存储过程

2009-12-15 14:09:39

Ruby创建可参数化类

2009-12-08 14:31:31

PHP命令行读取参数

2010-01-15 16:03:48

VB.NET重载Win

2010-03-04 15:12:33

Python算法

2010-03-04 11:12:02

Python AOP

2010-02-24 10:07:48

WCF跨越边界

2020-10-15 10:51:05

云计算IT技术

2019-05-07 10:21:48

人工智能AI

2009-12-21 10:09:26

WCF创建客户端服务对

2010-08-05 14:03:46

连接ibm DB2

2009-12-08 19:29:10

PHP生成唯一标识符

2009-11-25 16:36:29

PHP删除数组重复元素
点赞
收藏

51CTO技术栈公众号