雷达扫描图中当雷达指针转动扫描到某一个点上的时候,判断这个点的CPU值是否已经超过60的警戒位置如果超过将此点设置为红色。

在Silverlight中我们的雷达指针是一直在做圆运动的,我们要随时检测雷达指针的位置,以及雷达是否碰撞到一个Device设备了。如果碰撞到 了,就检测设备CPU值为多少?在这里我们需要解决两个问题。第一、如何随时观测雷达指针的当前位置?第二、如何检测雷达指针是否碰撞接触到了设备点?

针对第一个问题,需要做以下处理:

•在本例中使用Timer控件,每隔50毫秒检测一次当前的雷达指针控件位置

•雷达指针的位置根据检测当前雷达指针旋转角度的正余弦函数得到左上角点的X、Y位置,分别加上宽和高得到右下角点的位置。

•在本实例中的碰撞检测函数是根据国外友人Andy的两个函数改编而来的,UserControlBounds函数里面获取Point的方式有所不同。

针对第二个问题,我们需要做以下处理:

•根据雷达指针的左上角和右下角的两个点的位置构造一个Rect结构A(注意Rect结构描述矩形的宽高和原点),然后同理根据Device自定义控件构造一个Rect结构。

•检测者A、B两个Rect是否重合,如果重合则进行像素级别的对比是否碰撞接触在一起。

•因为有很多个设备点,所以需要循环检测每一个设备点在某一个时间点是否和雷达指针碰撞。

本篇实例源码基于上一节所述,本节中将雷达指针单独制作成为一个自定义控件,另外为设备自定义控件增加了一个属性IsOutStrip(设置如果超过警戒值则为红色),现在我们来看看本篇关键源码:

  1. public MainPage()
  2. {
  3. InitializeComponent();
  4. AddCanvasTransform();
  5. }
  6. RandarPointer rpointer = new RandarPointer();
  7. public void AddCanvasTransform()
  8. {
  9. AddDevice();
  10. //设置一个50毫秒启动一次的定时器
  11. time = new Timer(CheckIsContent, rpointer, 0, 50);
  12. }
  13. private void AddDevice()
  14. {
  15. #region 添加闪动的设备
  16. LayoutRoot.Children.Clear();
  17. //添加雷达指针
  18. LayoutRoot.Children.Add(rpointer);
  19. for (int i = 0; i < 15; i++)
  20. {
  21. Device dev = new Device();
  22. //设置X、Y坐标和Z层次
  23. dev.SetValue(Canvas.TopProperty, dev.Y);
  24. dev.SetValue(Canvas.LeftProperty, dev.X);
  25. //设置 dev.Tag为控件的左上角的点坐标和右下角的点坐标
  26. double DevRight = dev.X + 16;
  27. double DevButtom = dev.Y + 16;
  28. dev.SetValue(Canvas.ZIndexProperty, 600);
  29. dev.Tag = dev.X + "|" + dev.Y + "|" + DevRight + "|" + DevButtom;
  30. LayoutRoot.Children.Add(dev);
  31. }
  32. #endregion
  33. }
  34. //添加一个Timer定时器检测当前的指针的位置。
  35. Timer time;
  36. public void CheckIsContent(object state)
  37. {
  38. this.rpointer.Dispatcher.BeginInvoke(new labelDelegete(UpdateLab));
  39. }
  40. public delegate void labelDelegete();
  41. public void UpdateLab()
  42. {
  43. Rectangle rectangle = rpointer.FindName("rectangle") as Rectangle;
  44. //获取到当前雷达指针的左上角点的位置和右下角点的位置,赋值给Tag
  45. double top = -Math.Sin(rpointer.rTransform.Angle) * 253 + 300;
  46. double left = -Math.Cos(rpointer.rTransform.Angle) * 253 + 300;
  47. double right = 300;
  48. double buttom = 300;
  49. rpointer.Tag = left + "|" + top + "|" + right + "|" + buttom;
  50. //循环获取所有的Device控件的位置和当前时间雷达指针是否碰撞
  51. foreach (UIElement ui in LayoutRoot.Children)
  52. {
  53. Device device = ui as Device;
  54. if (device != null)
  55. {
  56. Rectangle rectangleblue = device.Rectangleblue;
  57. //检测雷达指针是否碰撞到设备,
  58. if (CheckCollision(device, rectangleblue, rpointer, rectangle))
  59. {
  60. //检测设备CPU占用值是否大于60%,如果大于则报警
  61. if (device.Value > 60)
  62. {
  63. //让其显示为红色
  64. device.IsOutStrip = true;
  65. }
  66. }
  67. }
  68. }
  69. }
  70. /// <summary>
  71. /// 检查控件的位置是否碰撞在一起
  72. /// </summary>
  73. /// <param name="control1">第一用户控件</param>
  74. /// <param name="controlElem1">第一用户控件内部需要检测是否碰撞的控件</param>
  75. /// <param name="control2">第二用户控件</param>
  76. /// <param name="controlElem2">第二用户控件内部需要检测是否碰撞的控件</param>
  77. /// <returns></returns>
  78. private bool CheckCollision(FrameworkElement control1, FrameworkElement controlElem1, FrameworkElement control2, FrameworkElement controlElem2)
  79. {
  80. // 创建两个Rect结构
  81. Rect rect1 = UserControlBounds(control1);
  82. Rect rect2 = UserControlBounds(control2);
  83. //检测这两个Rect结构是否重合
  84. rect1.Intersect(rect2);
  85. if (rect1 == Rect.Empty)
  86. {
  87. // no collision - GET OUT!
  88. return false;
  89. }
  90. else
  91. {
  92. bool bCollision = false;
  93. Point ptCheck = new Point();
  94. // 更精准的像素级别的碰撞对比
  95. for (int x = Convert.ToInt32(rect1.X); x < Convert.ToInt32(rect1.X + rect1.Width); x++)
  96. {
  97. for (int y = Convert.ToInt32(rect1.Y); y < Convert.ToInt32(rect1.Y + rect1.Height); y++)
  98. {
  99. ptCheck.X = x;
  100. ptCheck.Y = y;
  101. List<UIElement> hits = System.Windows.Media.VisualTreeHelper.FindElementsInHostCoordinates(ptCheck, control1) as List<UIElement>;
  102. if (hits.Contains(controlElem1))
  103. {
  104. // we have a hit on the first control elem, now see if the second elem has a similar hit
  105. List<UIElement> hits2 = System.Windows.Media.VisualTreeHelper.FindElementsInHostCoordinates(ptCheck, control2) as List<UIElement>;
  106. if (hits2.Contains(controlElem2))
  107. {
  108. bCollision = true;
  109. break;
  110. }
  111. }
  112. }
  113. if (bCollision) break;
  114. }
  115. return bCollision;
  116. }
  117. }
  118. /// <summary>
  119. /// 根据需要检测的控件的坐标位置,绘制出需要检测控件的副本Rect控件
  120. /// </summary>
  121. /// <param name="control"></param>
  122. /// <returns></returns>
  123. public Rect UserControlBounds(FrameworkElement control)
  124. {
  125. //重新创建一个Rect结构。
  126. string[] PointDirect = control.Tag.ToString().Split('|');
  127. Point ptTopLeft = new Point(Convert.ToDouble(PointDirect[0]), Convert.ToDouble(PointDirect[1]));
  128. Point ptBottomRight = new Point(Convert.ToDouble(PointDirect[2]), Convert.ToDouble(PointDirect[3]));
  129. return new Rect(ptTopLeft, ptBottomRight);
  130. }

本实例采用VS2010+Silverlight编写,如需源码点击 SLRandarHitTest.rar  下载,点击下图可查看Silverlight运行效果:

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

29.Silverlight碰撞测试、检测自定义控件碰撞,雷达扫描图之扫描雷达点状态相关推荐

  1. Silverlight实用窍门系列:29.Silverlight碰撞测试、检测自定义控件碰撞,雷达扫描图之扫描雷达点状态【附带源码实例】...

    雷达扫描图中当雷达指针转动扫描到某一个点上的时候,判断这个点的CPU值是否已经超过60的警戒位置如果超过将此点设置为红色. 在Silverlight中我们的雷达指针是一直在做圆运动的,我们要随时检测雷 ...

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

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

  3. Silverlight实用窍门系列:27.Silverlight二维旋转+平面渐变+动画,模拟雷达扫描图之基本框架【附带源码实例】...

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

  4. Silverlight实用窍门系列:28.Silverlight制作随机分布雷达扫描点,模拟雷达扫描图之被扫描设备【附带源码实例】...

    实际项目中,我们模拟一个监控多台电脑的雷达扫描图效果.我们假设发现了很多台设备,这些设备具有CPU使用率这个属性,在雷达扫描的时候,如果CPU的值高于90则报警为红色. 本节实例建立在上一节的基础之上 ...

  5. 2018年9月柳叶刀杂志 深度学习技术解决肺炎分类检测问题 高分辨率CT扫描图 病例队列研究 翻译

    Deep learning for classifying fibrotic lung disease on high-resolutino computed tomography: a case-c ...

  6. 【SOAR】使用Soar自动化检测Host碰撞

    前言 在之前,各位大师傅对Host碰撞进行了很多讨论.那么Host碰撞怎么使用SOAR扫描器来进行探测呢?本文主要讨论一下使用SOAR去做Host碰撞的一个实现方法. 什么Host碰撞? 火线Zone ...

  7. Unity 2D检测物体碰撞

    文章目录 添加物理脚本 使用脚本检测碰撞 添加物理脚本 Unity2D中,检测物体碰撞首相要给物体添加两个属性分别是: rigibody和collider,刚体和碰撞器. collider有不同的形状 ...

  8. 假定在使用CSMA/CD协议的10Mb/s以太网中某个站在发送数据时检测到碰撞,执行退避算法时选择了随机数r=100。试问这个站需要等待多长时间后才能再次发送数据?如果是100Mb

    假定在使用CSMA/CD协议的10Mb/s以太网中某个站在发送数据时检测到碰撞,执行退避算法时选择了随机数r=100.试问这个站需要等待多长时间后才能再次发送数据?如果是100Mb/s的以太网呢? 以 ...

  9. ROS 教程2 机器人雷达建图 蒙特卡洛定位 导航 路径规划 仿真

    ros 机器人雷达建图 蒙特卡洛定位 导航 路径规划 仿真 move_base gmapping acml 博文github 一.安装 turtlebot 移动机器人底座 进行导航 1.安装系统依赖 ...

最新文章

  1. git生成ssh keys步骤与使用
  2. Powershell 如何批量获取文件大小的实现代码
  3. Codeforces 861D - Polycarp's phone book 字典树/hash
  4. Windows Runtime (RT)
  5. HashTable 基础
  6. Dockerfile制作自定义镜像
  7. 【Merry Christmas】圣诞节,给博客添加浪漫的下雪效果!
  8. 2个dataframe,df1的每一列分别乘以df2的某一列
  9. 【iPod转换精灵V10.2 官方最新版】强大的视频转换功能
  10. 如何设置内网和外网同时使用
  11. matlab乘除号怎么打,matlab中的乘除法
  12. 【GNN报告】Mila实验室/蒙特利尔大学朱兆成:基于图神经网络的知识图谱推理
  13. 少吃柿子、山楂、黑枣,警惕鞣酸
  14. 【Basic Algebra】群论学习整理
  15. 计算机按硬件组合及用途分为,计算机基础.doc
  16. HTML 版本声明 DOCTYPE 标签
  17. Android Studio 快捷键大全
  18. 怎么给图片名称快速重命名?来跟我学着两个实用方法
  19. 无多普勒频移的海底混响单元散射模型卷积法
  20. python 典型变量分析

热门文章

  1. web页面性能优化及SEO优化
  2. 计算机原理寄存器基础知识,计算机组成原理基础知识
  3. WIN10电脑升级显卡驱动后变慢不少
  4. 骁龙870相当于什么处理器 骁龙870什么水平
  5. 莱诺和柯南Excel甘特图
  6. C语言结合VBS脚本编写朗读小工具,做一个能够发音的C语言程序
  7. 下载及安装NCCL教程
  8. 4G工业路由器DTU的扩展功能
  9. Golang学习(十五) 数组排序和二分查找
  10. 你知道上海社保缴费基数吗?上海各类人员的社保缴费基数