aardio 文档

aardio 范例: 超级热键演示

//超级热键
import win.ui;
/*DSG{{*/
var winform = win.form(text="超级热键演示";right=796;bottom=434;bgcolor=16777215)
winform.add(
edit={cls="edit";left=8;top=8;right=784;bottom=360;edge=1;multiline=1;z=1};
editLog={cls="edit";left=9;top=375;right=784;bottom=427;bgcolor=16777215;multiline=1;z=2}
)
/*}}*/

import key.hotkey; 
var superHotkey = key.hotkey(winform) //创建超级热键,必须用于窗口程序中

//批量加载热键配置表
superHotkey.loadTable({
    (function(){
        //这里的代码可以直接执行 
    })();

    /* 大写金额(可输入数学表达式)、日期、时间  */
    ["Ctrl+$"] = function(hFocus){  
        win.dlg.chineseNumber().show();
    }; 
});
import win.dlg.chineseNumber;

superHotkey.reg(
    "CTRL","K", 
    function(hwnd,...){
        ..winex.say("你按了CTRL+K!")
    } 
)

superHotkey.reg(
    "CTRL","K","K", 
    function(hwnd,...){
        ..winex.say("你按了CTRL+K,K!")
    } 
)

//添加新的热键方案  
superHotkey.reg(
    "~","H","I",
    function(hwnd,...){
        ..winex.say("hello world!")
    } 
)

//添加新的热键方案
import fsys.lnk;
import process;
superHotkey.reg(
    "SHIFT","Q","Q", 
    function(hwnd,...){  
        var path  = fsys.lnk.search( {"qq.exe";"QQScLauncher.exe";"QQProtect.exe"} ) ;
        process.execute(path)
    } 
)

superHotkey.regStr(
    "@SHIFT",
    function(hwnd,...){ 
        ..winex.say("单按 SHIFT")
    } 
)

superHotkey.regStr(
    "~aa",
    function(hwnd,...){ 
        ..winex.say("http://www.aardio.com",hwnd)
    } 
)

//允许在下面的事件中拦截所有按键,返回 true 阻止按键消息
superHotkey.onKeyDown = function(vk){

}

superHotkey.setEndKeys("SPACE")

//可选指定下面的触发器函数, 当用户按下部分热键、并有一个或多个可能的候选键时触发
import win.util.tray;
superHotkey.onWaiting = function(hwnd,enteredKeys,waitingKeys){

    if(!enteredKeys){
        winform.editLog.text = "准备就绪......";
        return;
    }  

    winform.editLog.text =   '已按下:'  
        + ..string.join(enteredKeys,"+")  
        + ' 等待候选键:' 
        + ..string.join(waitingKeys,",") 
        ,"超级热键模式已启动" 
} 

winform.edit.text = /*
热键  Ctrl+$  用法:按下 Ctrl 不放,再按$
热键  Ctrl+K  用法:按下 Ctrl 不放,再按K, 然后都放开
热键  Ctrl+K,K    用法:按下Ctrl不放,再按2次K
热键  @Shift  用法:按下 Shift 再放开,中间不按其他键,通常不会阻止 Shift 切换输入法状态的默认热键。
热键  ~hi 用法:依次按键,每个键都放开
热键  Shift+Q,Q   用法:按下Shift不放,再按2下Q
热键  ~AA 用法:依次按键,每个键都放开

点这里,连续按上面各行的键。
注意这是超级热键,不是热字符串,以键为输入单位而不是字符。
例如 ~hi 只按3次键,第一个键不要按Shift + `

超级热键是操作系统级别的热键,系统全局可用。 

超级热键的更多用法请参考开源软件 ImTip (http://imtip.aardio.com)
*/

/**details(超级热键规则)

一、超级热键检测规则

1、如果首个按下的键不是控制键,则不需要同时按住多个键。
如果按下的键是已注册的热键前半部分,则阻止当前按键继续发送。
如果继续按键已不符合任何热键,则释放已捕获的按键并按原顺序重新发送。
2、如果首次按住的是控制键( CTRL,ALT,SHIFT,WIN 之一),则必须同时按住多个键才算已完成热键。
如果这样同时按住的多个键是一个已完成的热键,但同时又是其他热键的前半部分,则必须放开所有键才会生效。
3、如果注册单个控制键热键,并且加上 @ 前缀,则放开该键(且中间没有按其他键)才算完成热键。
4、按键保持按下不放时不会触发多次超级热键。

超键热键中任何键名都只表示该键名所在的按键,不区分上档键。
例如热键 "~hi" 指连续按 3 个键,其中 ~ 不是指同时按 Shift + ` 。

二、示例
例如注册了以下 4 个热键,则使用规则如下:
热键 "~hi" 用法:按连续按 3 个键,每个键都要放开。
热键 "SHIFT+Q,Q" 用法:按下Shift不放,再按2下Q。
热键 "Ctrl+K" 用法:按下Ctrl不放,再按K, 然后都放开。
热键 "Ctrl+K,K"   用法:按下Ctrl不放,再按2次K(因为不是其他热键的前半部分,不需要等待放开)。

三、热键回调函数
热键回调函数返回 true 表示允许系统继续发送按键,
否则取消该按键,不再继续发送。

如果热键回调函数返回一个函数对象,
则取消该按键不再发送,并在返回函数以后异步执行返回的函数对象。
这样可以避免在热键回调函数中执行耗时操作。

超级热键基于低级键盘钩子,
在热键回调中不允许做耗时操作(在热键回调中返回异步执行的函数则不受限制),
如果耗时超过一秒或超过注册表限制的更小时间,系统会直接删除键盘钩子(导致热键不可用)。
没有任何方法可以检查到删除操作,应当遵守规则避免滥用。

如果仍然出现过一段时间键盘钩子失效。
建议检查一下是否安装了什么特别的软件导致了这样的问题。
end details**/

winform.show();
win.loopMessage();

Markdown 格式