且构网

分享程序员开发的那些事...
且构网 - 分享程序员编程开发的那些事

27.Silverlight二维旋转+平面渐变+动画,模拟雷达扫描图之基本框架

更新时间:2022-09-12 10:32:43

    在现实生活中的雷达运行扫描到物体的某一些属性(比如:速度,频率)超过安全范围值将会报警。在实际的某一些项目中(比如监控系统),我们也想制作一个雷达扫描图来模拟扫描各种设备那么应该如何做呢?

        我们将各种设备作为雷达需要扫描到的点,然后在每次扫描的时候扫描这些点,如果指针扫描碰撞到这些点的时候,会触发一个碰撞实际,以检测设备的项属性是否超过正常范围值。如果超过则让其闪亮不同的颜色。

        本节将讲诉如何制作一个雷达扫描图的基本框架如下。

              第一步制作一个雷达图的背景

              第二步雷达图的指针围绕中心点不停旋转

              第三步为了让雷达图的效果看起来更美观一些,我们应该让指针后面绘画一个倾斜的拖影效果

        首先我们使用PhotoShop绘制一个雷达图的背景图如下:

27.Silverlight二维旋转+平面渐变+动画,模拟雷达扫描图之基本框架

        接着我们使用DoubleAnimation动画和RotateTransform旋转对象让指针旋转起来,添加一个白色的指针,并且设置白色指针的旋转 中心点RenderTransformOrigin="0.0,0.0",现在我们先看XAML代码如下:


  1. <Canvas Margin="300 300 0 0" Name="layRoot"
  2. <Line X1="0" Y1="0" X2="252" Y2="0" StrokeThickness="1" RenderTransformOrigin="0.0,0.0" Stroke="#ffffffff" Fill="#ffffffff"></Line> 
  3. </Canvas> 

         为这个白色的指针所属的Canvas设置一个RotateTransform二维坐标的旋转对象,其参数Angle为角度。然后添加一个DoubleAnimation对象来让这个角度在10秒内从360度变化到0度即可,操作的后台代码如下:


  1. public void AddCanvasTransform() 
  2. #region 为Canvas添加一个二维 x-y 坐标系内围绕指定点顺时针旋转对象 
  3. RotateTransform rTransform = new RotateTransform(); 
  4. //设置旋转的初始角度为360度 
  5. rTransform.Angle = 360; 
  6. //设置旋转对象的名称属性为rTrans,让下面的DoubleAnimation使用 
  7. rTransform.SetValue(NameProperty, "rTrans"); 
  8. //将此旋转对象给Canvas 
  9. this.layRoot.RenderTransform = rTransform; 
  10. #endregion 
  11.  
  12. #region 设置动画板且让Canvas对象内的物品以某点位圆心360度旋转下去 
  13. //设置一个DoubleAnimation动画来翻转这个旋转对象。 
  14. Storyboard sboard = new Storyboard(); 
  15. DoubleAnimation danima = new DoubleAnimation();//设置rectangle1矩形控件的透明度的Double类型数字变化 
  16. //设置DoubleAnimation动画的作用对象名称和作用对象属性 
  17. danima.SetValue(Storyboard.TargetNameProperty, "rTrans"); 
  18. danima.SetValue(Storyboard.TargetPropertyProperty, new PropertyPath("RotateTransform.Angle")); 
  19. //在10秒的时间内让动画作用的角度属性从360到0,且永远循环下去 
  20. danima.From = 360; danima.To = 0; 
  21. danima.Duration = new Duration(new TimeSpan(0, 0, 10)); 
  22. danima.RepeatBehavior = RepeatBehavior.Forever; 
  23. sboard.Children.Add(danima); 
  24. LayoutRoot.Resources.Add("colorboard", sboard); 
  25. sboard.Begin(); 
  26. #endregion 

        最后为指针添加一个拖影效果,让指针在旋转的时候有一个拖影,使其更为美观。在这里我们使用一个矩形控件,让其产生一个渐变效果(采用 LinearGradientBrush渐变对象),再旋转一下它的角度即可完成。这个矩形控件也放在Canvas对象里面那么他就会跟着白色雷达指针一 起旋转,其XAML代码如下:


  1. <Rectangle x:Name="rectangle" Height="60" Width="253" RenderTransformOrigin="0.0,0.0"
  2. <Rectangle.Fill> 
  3. <LinearGradientBrush EndPoint="0.5,1" MappingMode="RelativeToBoundingBox" StartPoint="0.5,0"
  4. <LinearGradientBrush.RelativeTransform> 
  5. <CompositeTransform CenterY="0.5" CenterX="0.5" Rotation="39.2"/> 
  6. </LinearGradientBrush.RelativeTransform> 
  7. <GradientStop Color="#8Dffffff"/> 
  8. <GradientStop Color="#00ffffff" Offset="0.483"/> 
  9. <GradientStop Color="Transparent" Offset="1"/> 
  10. </LinearGradientBrush> 
  11. </Rectangle.Fill> 
  12. </Rectangle> 

        完整的MainPage.xaml代码如下:

MainPage.xaml

  1. <UserControl x:Class="SLRandar.MainPage" 
  2. xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation" 
  3. xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml" 
  4. xmlns:d="http://schemas.microsoft.com/expression/blend/2008" 
  5. xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006" 
  6. mc:Ignorable="d" 
  7. d:DesignHeight="600" d:DesignWidth="600"
  8.  
  9. <Grid x:Name="LayoutRoot" HorizontalAlignment="Left" VerticalAlignment="Top"
  10. <Image HorizontalAlignment="Left" Source="Randar.png" Width="600" Height="600" Name="image1" Stretch="Fill" VerticalAlignment="Top" /> 
  11. <Canvas Margin="300 300 0 0" Name="layRoot"
  12. <Line X1="0" Y1="0" X2="252" Y2="0" StrokeThickness="1" RenderTransformOrigin="0.0,0.0" Stroke="#ffffffff" Fill="#ffffffff"></Line> 
  13. <Rectangle x:Name="rectangle" Height="60" Width="253" RenderTransformOrigin="0.0,0.0"
  14. <Rectangle.Fill> 
  15. <LinearGradientBrush EndPoint="0.5,1" MappingMode="RelativeToBoundingBox" StartPoint="0.5,0"
  16. <LinearGradientBrush.RelativeTransform> 
  17. <CompositeTransform CenterY="0.5" CenterX="0.5" Rotation="39.2"/> 
  18. </LinearGradientBrush.RelativeTransform> 
  19. <GradientStop Color="#8Dffffff"/> 
  20. <GradientStop Color="#00ffffff" Offset="0.483"/> 
  21. <GradientStop Color="Transparent" Offset="1"/> 
  22. </LinearGradientBrush> 
  23. </Rectangle.Fill> 
  24. </Rectangle> 
  25. </Canvas> 
  26. </Grid> 
  27.  
  28. </UserControl> 

        完整的MainPage.xaml.cs文件代码如下:

MainPage.xaml.cs

  1. using System; 
  2. using System.Collections.Generic; 
  3. using System.Linq; 
  4. using System.Net; 
  5. using System.Windows; 
  6. using System.Windows.Controls; 
  7. using System.Windows.Documents; 
  8. using System.Windows.Input; 
  9. using System.Windows.Media; 
  10. using System.Windows.Media.Animation; 
  11. using System.Windows.Shapes; 
  12.  
  13. namespace SLRandar 
  14. public partial class MainPage : UserControl 
  15. public MainPage() 
  16. InitializeComponent(); 
  17.  
  18. AddCanvasTransform(); 
  19. public void AddCanvasTransform() 
  20. #region 为Canvas添加一个二维 x-y 坐标系内围绕指定点顺时针旋转对象 
  21. RotateTransform rTransform = new RotateTransform(); 
  22. //设置旋转的初始角度为360度 
  23. rTransform.Angle = 360; 
  24. //设置旋转对象的名称属性为rTrans,让下面的DoubleAnimation使用 
  25. rTransform.SetValue(NameProperty, "rTrans"); 
  26. //将此旋转对象给Canvas 
  27. this.layRoot.RenderTransform = rTransform; 
  28. #endregion 
  29.  
  30. #region 设置动画板且让Canvas对象内的物品以某点位圆心360度旋转下去 
  31. //设置一个DoubleAnimation动画来翻转这个旋转对象。 
  32. Storyboard sboard = new Storyboard(); 
  33. DoubleAnimation danima = new DoubleAnimation();//设置rectangle1矩形控件的透明度的Double类型数字变化 
  34. //设置DoubleAnimation动画的作用对象名称和作用对象属性 
  35. danima.SetValue(Storyboard.TargetNameProperty, "rTrans"); 
  36. danima.SetValue(Storyboard.TargetPropertyProperty, new PropertyPath("RotateTransform.Angle")); 
  37. //在10秒的时间内让动画作用的角度属性从360到0,且永远循环下去 
  38. danima.From = 360; danima.To = 0; 
  39. danima.Duration = new Duration(new TimeSpan(0, 0, 10)); 
  40. danima.RepeatBehavior = RepeatBehavior.Forever; 
  41. sboard.Children.Add(danima); 
  42. LayoutRoot.Resources.Add("colorboard", sboard); 
  43. sboard.Begin(); 
  44. #endregion 

        本实例采用VS2010+Silverlight4.0编写,如需源码 SLRandar.rar 点击下载。本实例也可以点击一下图片预览效果:

27.Silverlight二维旋转+平面渐变+动画,模拟雷达扫描图之基本框架


本文转自程兴亮 51CTO博客,原文链接:http://blog.51cto.com/chengxingliang/822544