
No.3ベストアンサー
- 回答日時:
一番簡単な方法は、メッセージループで処理を切ることです。
F10などのシステムキーを押したとき、ウィンドウには WM_SYSKEYDOWN メッセージが飛んできます。
これを Translate & Dispatch することでフォーカスがメニューに移ります。
なので、WinSDKであれば
while( GetMessage(&msg, NULL, 0, 0) )
{
if( msg.message == WM_SYSKEYDOWN && msg.wParam == VK_F10 )
{
処理
}
else
{
TranslateMessage
DispatchMessage
}
}
という感じです。(エラーチェックとか無視してます)
MFCならば、PretranslateMessageをオーバーライドして
BOOL CXXX::PreTranslateMessage(MSG* pMsg)
{
if( pMsg->message == WM_SYSKEYDOWN && pMsg->wParam == VK_F10 )
{
return TRUE;
}
return CXXXWnd::PreTranslateMessage(pMsg);
}
みたいな感じで、TRUEを返してやります。
要するに、TranslateされることでWindows標準の処理がされるので、その前にメッセージをきります。
ウィンドウプロシージャには、TranslateおよびDispatchされたあとにメッセージが飛んでくるので、どうやっても対処できません。
No.2
- 回答日時:
#1です。
補足です。
::RegisterHotKey( hWnd , id , 0 , VK_F10 );
を使った後F10を押すとWM_HOTKEYが飛んできます。
そこでKeyDownイベントの処理をしてください。
RegisterHotKeyで複数登録してもWPARAMにidが入っているのでどのキーかの判断が可能です。
詳細はMSDNを参照してください。
No.1
- 回答日時:
WinAPIのRegisterHotKeyでF10を無効化できると思います。
他にも同じくWinAPIのSetWindowHookEx( WH_KEYBOARD_LL ・・・
でキーボード入力をフックする方法もあります。
// ユニークなID取得
static int id = ::GlobalAddAtom(_T("RegisterHotKey"));
// F10を無効化
::RegisterHotKey( hWnd , id , 0 , VK_F10 );
// F10を有効に戻す
::UnregisterHotKey( hWnd , id );
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
関連するカテゴリからQ&Aを探す
おすすめ情報
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
VBSの処理中一旦処理を止めて再...
-
Excel(VBA)シート上のコマンド...
-
VB Loopを一時停止し再開あるい...
-
ACCESS側からEXCELの書式を設定...
-
【C#】 あるイベントから別イ...
-
PostMessageの連続送信
-
beforecloseの中からの抜け出し方
-
VBA、UserFormを前面に出力して...
-
c#でボタンのアクションが終わ...
-
Excel VBA で処理中断(DoEvents...
-
VBA kernel32 の意味
-
メッセージボックスのボタン名変更
-
<input type="file">タグで「キ...
-
CreateCompatibleDCを初期化時...
-
マウスのクリックを無視したい
-
Excel VBA 自動的に閉じるMsgBox
-
VBSで応答不要のメッセージボッ...
-
ボタンが押された事を検知する...
-
Excelのワークシートに行を挿入...
-
Windowsがシャットダウンする前に
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
VBSの処理中一旦処理を止めて再...
-
VBA kernel32 の意味
-
メッセージボックスのボタン名変更
-
ACCESS側からEXCELの書式を設定...
-
VBSで応答不要のメッセージボッ...
-
VBA、UserFormを前面に出力して...
-
【C#】 あるイベントから別イ...
-
Excel VBA で処理中断(DoEvents...
-
PostMessageの連続送信
-
ボタンが押された事を検知する...
-
Application.ScreenUpdating=Fa...
-
エクセルVBAでクリップボード内...
-
VB Loopを一時停止し再開あるい...
-
起動後直に実行するコードはど...
-
DirectX環境下での方向キー同時...
-
Excel VBA 実行中に一瞬フリー...
-
OSシャットダウン時の常駐アプ...
-
マウスのクリックを無視したい
-
エクセルVBAで
-
メッセージボックスの表示につ...
おすすめ情報