用API函数定义热键又一法
给自己一点时间接受自己,爱自己,趁着下午茶的时间来学习图老师推荐的用API函数定义热键又一法,过去的都会过去,迎接崭新的开始,释放更美好的自己。
三个API函数是必须的:
RegisterHotKey——用于定义热键
UnregisterHotKey——用于注销热键
PeekMessage——用于检测热键(尚有其它的主要用途)
这里举个实例:程序启动后窗体不可见,按下Ctrl F12窗体弹出来。本例仅需要一个窗体,在PWin98、VB6.0企业版下调试通过。
'申明API函数
PrivateDeclareFunctionRegisterHotKeyLib"user32"(ByValhWndAsLong,ByValidAsLong,ByValfsModifiersAsLong,ByValvkAsLong)AsLong
PrivateDeclareFunctionUnregisterHotKeyLib"user32"(ByValhWndAsLong,ByValidAsLong)AsLong
PrivateDeclareFunctionPeekMessageLib"user32"Alias"PeekMessageA"(lpMsgAsMsg,ByValhWndAsLong,ByValwMsgFilterMinAsLong,ByValwMsgFilterMaxAsLong,ByValwRemoveMsgAsLong)AsLong
PrivatebCancelAsBoolean'用于热键有效与否的变量
'全局变量
PrivateConstMOD_ALT=&H1
PrivateConstMOD_CONTROL=&H2
PrivateConstMOD_SHIFT=&H4
PrivateConstPM_REMOVE=&H1
PrivateConstWM_HOTKEY=&H312
PrivateTypeMsg'定义Message类型
hWndAsLong
MessageAsLong
wParamAsLong
lParamAsLong
timeAsLong
EndType
PrivateSubproMsg()'声明进程
DimMessageAsMsg
'循环直到bCancel为真
DoWhileNotbCancel
'检测到热键被按下则令窗体隐藏
IfPeekMessage(Message,Me.hWnd,WM_HOTKEY,WM_HOTKEY,PM_REMOVE)Then
Me.Visible=True
EndIf
DoEvents
Loop
EndSub
PrivateSubForm_Load()'窗体加载时初始化程序
DimretAsLong
bCancel=False
'定义热键为Ctrl F12
ret=RegisterHotKey(Me.hWnd,&HBFFF&,MOD_CONTROL,vbKeyF12)
Me.Visible=False'窗体不可见
proMsg
EndSub
'退出时注销热键
PrivateSubForm_Unload(CancelAsInteger)
bCancel=True
CallUnregisterHotKey(Me.hWnd,&HBFFF&)
EndSub->