zoukankan      html  css  js  c++  java
  • KeyDown,KeyPress 和KeyUp

    研究了一下KeyDown,KeyPress 和KeyUp ,发现之间还是有点学问的。
    让我们带着如下问题来说明,如果你看到这些问题你都知道,那么这篇文章你就当复习吧:)


    1.这三个事件的顺序是怎么样的?
    2.KeyDown 触发后,KeyUp是不是一定触发?
    3.三个事件的定义
    4.KeyDown、KeyUp 和KeyPress 之间的区别
    5.如何区分是否按的是小键盘?
    6.PrScrn按键三个事件能够捕获吗?
    7.{菜单键}和{开始键}KeyPress能够捕获吗?
    8.如何捕获系统的组合键?
    9.通过什么方式捕获PrScrn按键事件?


    (一)键事件按下列顺序发生:
    KeyDown
    KeyPress
    KeyUp


    (二)KeyDown触发后,不一定触发KeyUp,当KeyDown 按下后,拖动鼠标,那么将不会触发KeyUp事件。


    (三)定义
    KeyDown:在控件有焦点的情况下按下键时发生。
    KeyPress:在控件有焦点的情况下按下键时发生。(下面会说和KeyDown 的区别)
    KeyUp:在控件有焦点的情况下释放键时发生。


    (四)KeyPress 和KeyDown 、KeyPress之间的区别
               1.KeyPress主要用来捕获数字(注意:包括Shift+数字的符号)、字母(注意:包括大小写)、小键盘等除了F1-12、SHIFT、Alt、Ctrl、Insert、Home、PgUp、Delete、End、PgDn、ScrollLock、Pause、NumLock、{菜单键}、{开始键}和方向键外的ANSI字符
                 KeyDown 和KeyUp 通常可以捕获键盘除了PrScrn所有按键(这里不讨论特殊键盘的特殊键)
                2.KeyPress 只能捕获单个字符
                    KeyDown 和KeyUp 可以捕获组合键。
               3.KeyPress 可以捕获单个字符的大小写
               4.KeyDown和KeyUp 对于单个字符捕获的KeyValue 都是一个值,也就是不能判断单个字符的大小写。
               5.KeyPress 不区分小键盘和主键盘的数字字符。
                    KeyDown 和KeyUp 区分小键盘和主键盘的数字字符。
               6.其中PrScrn 按键KeyPress、KeyDown和KeyUp 都不能捕获。


    (五)系统组合键的判定
    在使用键盘的时候,通常会使用到CTRL+SHIFT+ALT 类似的组合键功能。对于此,我们如何来判定?
         通过KeyUp 事件能够来处理(这里说明一下为什么不用KeyDown,因为在判定KeyDown的时候,CTRL、SHIFT和ALT 属于一直按下状态,然后再加另外一个键是不能准确捕获组合键,所以使用KeyDown 是不能准确判断出的,要通过KeyUp 事件来判定 )


       (六)捕获PrScrn按键事件
    通过一种钩子的方式可以判定PrScrn 按键事件,钩子可以获取任何键盘事件。

  • 相关阅读:
    《Geometric Deep Learning综述介绍》
    《和想象不太一样的'Graph Neural Network + Zero Shot'》
    《几何深度学习前沿》
    《【Paper Live】滴滴出行-探索资源约束的Contextual Bandits问题 & KDD Cup滴滴出行比赛解读>
    《PDP: 解决约束满足问题的神经网络架构 | 刘晶 | 集智俱乐部图网络论文读书会20190819》
    《NeuroSAT: Learning a SAT Solver from Single-Bit Supervision》
    《OR Talk NO.5 | Facebook 田渊栋:用深度(强化)学习为组合优化寻找更好的启发式搜索策略》
    《OR Talk NO.15 | 在业界实验室做AI设计师是一种什么体验?》
    超级跳马 —— 矩阵快速幂优化DP
    图SLAM:Noob的同时本地化和映射指南
  • 原文地址:https://www.cnblogs.com/dachie/p/2548880.html
Copyright © 2011-2022 走看看