Гость_AndreyAGSoft |
Отправлено: 16.06.2003, 08:43 |
|
Не зарегистрирован
|
Уважаемые, у меня есть хук(допустим клавиатуры). Как запретить системе обрабатывать нажатие определённых клавиш
if(lParm==31)
{
//Что здесь написать
} |
|
Admin |
Отправлено: 16.06.2003, 17:21 |
|
Владимир
Группа: Администратор
Сообщений: 1190
|
Тогда уж не запретить системе обрабатывать нажатие определённых
клавиш, а перехватывать эти нажатия и не передавать их
назад в систему.
Где не передавать их дальше — там где вы передаете их
назад в Windows, это смотрите в коде хука.
Если об if, то
if(lParm==31)
{
lParm=0;
}
|
|
Admin |
Отправлено: 17.06.2003, 10:33 |
|
Владимир
Группа: Администратор
Сообщений: 1190
|
QUOTE | Не отсылать сообщения из хука обратно в систему (lParam=0) не получается.
Такой код:
LRESULT CALLBACK KeyboardHook(int nCode,WPARAM wParam,LPARAM lParam)
{
if(wParam==91)
{
wParam=NULL;
}
return 0;
}
Я не хочу чтобы система обрабатывала нажатие клавиши с кодом 91.
Как быть?
|
Если речь об этом, то судя по help вы должны вернуть не 0.
то есть написать так:
CODE |
LRESULT CALLBACK KeyboardHook(int nCode,WPARAM wParam,LPARAM lParam)
{
if(wParam==91)
{
return 1; // !!!
}
return 0;
}
|
Написано в Help:
CODE |
The KeyboardProc hook procedure is an application-defined or library-
defined callback function the system calls whenever an application calls the
GetMessage or PeekMessage function and there is a keyboard message
(WM_KEYUP or WM_KEYDOWN) to be processed.
LRESULT CALLBACK KeyboardProc(
int code, // hook code
WPARAM wParam, // virtual-key code
LPARAM lParam // keystroke-message information
);
Parameters
code
Specifies a code the hook procedure uses to determine how to process the
message. This parameter can be one of the following values:
Value Meaning
HC_ACTION The wParam and lParam parameters contain
information about a keystroke message.
HC_NOREMOVE The wParam and lParam parameters contain
information about a keystroke message, and the keystroke message has
not been removed from the message queue. (An application called the
PeekMessage function, specifying the PM_NOREMOVE flag.)
If code is less than zero, the hook procedure must pass the message to
the CallNextHookEx function without further processing and should return
the value returned by CallNextHookEx.
wParam
Specifies the virtual-key code of the key that generated the keystroke message.
lParam
Specifies the repeat count, scan code, extended-key flag, context code,
previous key-state flag, and transition-state flag. This parameter can be a
combination of the following values:
Value Description
0-15 Specifies the repeat count. The value is the number of times the
keystroke is repeated as a result of the user's holding down the key.
16-23 Specifies the scan code. The value depends on the original
equipment manufacturer (OEM).
24 Specifies whether the key is an extended key, such as a function
key or a key on the numeric keypad. The value is 1 if the key is an
extended key; otherwise, it is 0.
25-28 Reserved.
29 Specifies the context code. The value is 1 if the ALT key is down;
otherwise, it is 0.
30 Specifies the previous key state. The value is 1 if the key is down
before the message is sent; it is 0 if the key is up.
31 Specifies the transition state. The value is 0 if the key is being
pressed and 1 if it is being released.
For more information about the lParam parameter, see Keystroke Message Flags.
Return Values
To prevent Windows from passing the message to the rest of the hook
chain or to the target window procedure, the return value must be a
nonzero value. To allow Windows to pass the message to the target
window procedure, bypassing the remaining procedures in the chain, the
return value must be zero.
Remarks
An application installs the hook procedure by specifying the WH_KEYBOARD
hook type and the address of the hook procedure in a call to the
SetWindowsHookEx function.
KeyboardProc is a placeholder for the application-defined or library-defined
function name.
See Also
CallNextHookEx, GetMessage, PeekMessage, SetWindowsHookEx, WM_KEYUP, WM_KEYDOWN
|
|
|
|