我建议使用OnMessage() 来监控按键按下 (0x100) 和按键按下 (0x101) 事件消息。以下是相关帮助文档的一些链接:OnMessage()、List of Windows Messages。
下面是一个工作示例,它将在您的桌面上创建一个文件testEE.txt,其参数与您正在记录的内容相似。请注意,这不会记录鼠标移动或点击(有可能,我只是没有这样设置)。按F1 开始和停止录制。
f1::
bT := !bT
If bT
{
MsgBox ,,, Recording started , 1
KeyBdHook := DllCall( "SetWindowsHookEx" , "int" , 13 , "uint" , RegisterCallback( "KeyBdProc" ) , "uint" , 0 , "uint" , 0 )
nStart := A_TickCount
} Else {
DllCall( "UnhookWindowsHookEx" , "ptr" , KeyBdHook )
MsgBox ,,, Recording terminated , 1
}
Return
KeyBdProc( nCode , wParam , lParam )
{
global
Critical
If ( wParam = 0x100 || wParam = 0x101 )
{
nKey := Format( "{:x}" , NumGet( lParam + 0 , 0 , "int" ) )
nTime := A_TickCount - nStart , nStart := A_TickCount
If ( wParam = 0x100 && nKey != nKeyPrev )
{
nKeyPrev := nKey
FileAppend , % nTime . "|" . nKey . " down`n" , %A_Desktop%/testEE.txt
}
If ( wParam = 0x101 )
{
If ( nKey = nKeyPrev )
nKeyPrev := ""
FileAppend , % nTime . "|" . nKey . " up`n" , %A_Desktop%/testEE.txt
} }
Return DllCall( "CallNextHookEx" , "uint" , KeyBdHook , "int" , nCode , "uint" , wParam , "uint" , lParam )
}
这将重播您的按键:
f2::
aData := []
FileRead , sText , %A_Desktop%/testEE.txt
Loop , Parse , sText , `n , `r
{
nCt := A_Index
Loop , Parse , A_LoopField , |
aData[ nCt , A_Index ] := A_LoopField
}
Loop , % aData.Length()
{
If InStr( aData[ A_Index , 2 ] , "70 " ) ; 0x70 is F1
Continue
Sleep , % aData[ A_Index , 1 ]
Send , % "{vk" . aData[ A_Index , 2 ] . "}"
}
Return
注意,它还记录了开始和停止记录的热键,所以如果它看到这个键,我就把它设为Continue。如果您将热键更改为其他键或组合键,则需要将其设置为忽略该键或组合键。
我发现这些帖子特别有用,供参考:
https://autohotkey.com/board/topic/27067-mouse-move-detection/
https://www.autohotkey.com/boards/viewtopic.php?t=11922
How to activate a function everytime the target window becomes active in AutoHotkey
https://docs.microsoft.com/en-us/windows/desktop/api/winuser/nf-winuser-setwindowshookexa
https://docs.microsoft.com/en-us/windows/desktop/api/winuser/nf-winuser-unhookwindowshookex