博客
关于我
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下载以及安装(新手入门,超详细)
查看>>
MySQL不会性能调优?看看这份清华架构师编写的MySQL性能优化手册吧
查看>>
MySQL不同字符集及排序规则详解:业务场景下的最佳选
查看>>
Mysql不同官方版本对比
查看>>
MySQL与Informix数据库中的同义表创建:深入解析与比较
查看>>
mysql与mem_细说 MySQL 之 MEM_ROOT
查看>>
MySQL与Oracle的数据迁移注意事项,另附转换工具链接
查看>>
mysql丢失更新问题
查看>>
MySQL两千万数据优化&迁移
查看>>
MySql中 delimiter 详解
查看>>
MYSQL中 find_in_set() 函数用法详解
查看>>
MySQL中auto_increment有什么作用?(IT枫斗者)
查看>>
MySQL中B+Tree索引原理
查看>>
mysql中cast() 和convert()的用法讲解
查看>>
mysql中datetime与timestamp类型有什么区别
查看>>
MySQL中DQL语言的执行顺序
查看>>
mysql中floor函数的作用是什么?
查看>>
MySQL中group by 与 order by 一起使用排序问题
查看>>
mysql中having的用法
查看>>