博客
关于我
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中kill掉所有锁表的进程
查看>>
mysql中like % %模糊查询
查看>>
MySql中mvcc学习记录
查看>>
mysql中null和空字符串的区别与问题!
查看>>
MySQL中ON DUPLICATE KEY UPDATE的介绍与使用、批量更新、存在即更新不存在则插入
查看>>
MYSQL中TINYINT的取值范围
查看>>
MySQL中UPDATE语句的神奇技巧,让你操作数据库如虎添翼!
查看>>
Mysql中varchar类型数字排序不对踩坑记录
查看>>
MySQL中一条SQL语句到底是如何执行的呢?
查看>>
MySQL中你必须知道的10件事,1.5万字!
查看>>
MySQL中使用IN()查询到底走不走索引?
查看>>
Mysql中使用存储过程插入decimal和时间数据递增的模拟数据
查看>>
MySql中关于geometry类型的数据_空的时候如何插入处理_需用null_空字符串插入会报错_Cannot get geometry object from dat---MySql工作笔记003
查看>>
mysql中出现Incorrect DECIMAL value: '0' for column '' at row -1错误解决方案
查看>>
mysql中出现Unit mysql.service could not be found 的解决方法
查看>>
mysql中出现update-alternatives: 错误: 候选项路径 /etc/mysql/mysql.cnf 不存在 dpkg: 处理软件包 mysql-server-8.0的解决方法(全)
查看>>
Mysql中各类锁的机制图文详细解析(全)
查看>>
MySQL中地理位置数据扩展geometry的使用心得
查看>>
Mysql中存储引擎简介、修改、查询、选择
查看>>
Mysql中存储过程、存储函数、自定义函数、变量、流程控制语句、光标/游标、定义条件和处理程序的使用示例
查看>>