博客
关于我
Windows 8实用窍门系列:4.Windows 8的常用鼠标事件
阅读量:733 次
发布时间:2019-03-22

本文共 3555 字,大约阅读时间需要 11 分钟。

  在Windows 8中采用一些新的鼠标事件以替代以前Silverlight的鼠标事件,其常用事件如下:

  PointerWheelChanged:鼠标中键滑动事件。

  PointerPressed:鼠标点击下去的时候即触发事件。

  PointerReleased:鼠标点击下去的时候释放鼠标时触发事件。

  PointerEntered:鼠标进入有效范围之时触发一次。

  PointerMoved:鼠标在有效范围之内移动之时触发事件。

  PointerExited:鼠标退出有效范围之时触发事件。

  在本文中将通过实例演示各种鼠标事件的响应.下面我们看实例源码如下:

  其中Xaml.cs后台代码如下,

///     /// 可用于自身或导航至 Frame 内部的空白页。    ///     public sealed partial class MainPage : Page    {        public MainPage()        {            this.InitializeComponent();        }        Point start = new Point();        ///         /// 在此页将要在 Frame 中显示时进行调用。        ///         /// 描述如何访问此页的事件数据。Parameter        /// 属性通常用于配置页。        protected override void OnNavigatedTo(NavigationEventArgs e)        {        }        //鼠标中键滑动事件        private void MainCanvas_PointerWheelChanged(object sender, PointerRoutedEventArgs e)        {            this.tbLabel.Text = "滑动了一次鼠标中箭";        }        //鼠标点击下去的事件        private void MainCanvas_PointerPressed(object sender, PointerRoutedEventArgs e)        {            start = e.GetCurrentPoint(MainCanvas).Position;            this.tbLabel.Text = "点击了一次鼠标或者屏幕";        }        //鼠标松键事件        private void MainCanvas_PointerReleased(object sender, PointerRoutedEventArgs e)        {            Point end = e.GetCurrentPoint(MainCanvas).Position;            double angle = 0;            //判断拖动鼠标角度            if (Math.Abs(end.X - start.X) < 1 && Math.Abs(end.Y - start.Y) < 1)            {                angle = 0;            }            else if (end.X > start.X)            {                if (end.Y > start.Y)                {                    angle = 360 - Math.Atan((end.Y - start.Y) * 1.0 / (end.X - start.X)) * 180 / Math.PI;                }                else                {                    angle = Math.Atan((start.Y - end.Y) * 1.0 / (end.X - start.X)) * 180 / Math.PI;                }            }            else if (end.X < start.X)            {                if (end.Y > start.Y)                {                    angle = Math.Atan((end.Y - start.Y) * 1.0 / (start.X - end.X)) * 180 / Math.PI + 180;                }                else                {                    angle = 180 - Math.Atan((start.Y - end.Y) * 1.0 / (start.X - end.X)) * 180 / Math.PI;                }            }            if (angle == 0)            {                this.tbLabel.Text = "点击了一次鼠标或者屏幕";            }            else if (angle >= 45 && angle < 135)            {                this.tbLabelFore.Text = "从下往上";            }            else if (angle <= 45 || angle > 315)            {                this.tbLabelFore.Text = "从左向右滑";            }            else if (angle >= 135 && angle < 225)            {                this.tbLabelFore.Text = "从右向左滑";            }            else if (angle >= 225 && angle < 315)            {                this.tbLabelFore.Text = "从上往下";            }        }                //鼠标移动事件        private void MainCanvas_PointerMoved(object sender, PointerRoutedEventArgs e)        {            Point point = e.GetCurrentPoint(MainCanvas).Position;            this.tbLabel.Text = "鼠标正在移动X:"+point.X+",Y:"+point.Y;        }        //鼠标移出范围事件        private void MainCanvas_PointerExited(object sender, PointerRoutedEventArgs e)        {            this.tbLabelNext.Text = "鼠标移出作用范围";        }        //鼠标进入范围事件        private void MainCanvas_PointerEntered(object sender, PointerRoutedEventArgs e)        {            this.tbLabelNext.Text = "鼠标进入范围";        }    }

  下图是效果演示,如需源码请点击  下载.

转载地址:http://wtkwk.baihongyu.com/

你可能感兴趣的文章
Mysql中存储过程、存储函数、自定义函数、变量、流程控制语句、光标/游标、定义条件和处理程序的使用示例
查看>>
mysql中实现rownum,对结果进行排序
查看>>
mysql中对于数据库的基本操作
查看>>
Mysql中常用函数的使用示例
查看>>
MySql中怎样使用case-when实现判断查询结果返回
查看>>
Mysql中怎样使用update更新某列的数据减去指定值
查看>>
Mysql中怎样设置指定ip远程访问连接
查看>>
mysql中数据表的基本操作很难嘛,由这个实验来带你从头走一遍
查看>>
Mysql中文乱码问题完美解决方案
查看>>
mysql中的 +号 和 CONCAT(str1,str2,...)
查看>>
Mysql中的 IFNULL 函数的详解
查看>>
mysql中的collate关键字是什么意思?
查看>>
MySql中的concat()相关函数
查看>>
mysql中的concat函数,concat_ws函数,concat_group函数之间的区别
查看>>
MySQL中的count函数
查看>>
MySQL中的DB、DBMS、SQL
查看>>
MySQL中的DECIMAL类型:MYSQL_TYPE_DECIMAL与MYSQL_TYPE_NEWDECIMAL详解
查看>>
MySQL中的GROUP_CONCAT()函数详解与实战应用
查看>>
MySQL中的IO问题分析与优化
查看>>
MySQL中的ON DUPLICATE KEY UPDATE详解与应用
查看>>