
テキストボックスにフォーカスがあり、TABキーが押された時のイベントをひろいたいのですが、KeyPressもKeyDownもイベントが発生しません。
(If KeyCode = vbKeyTab Then
MsgBox "タブキー"
End If
If KeyAscii = vbKeyTab Then ~
のようなコードを記述してもメッセージが表示されない)
ヘルプにはKeyDownでは発生しないという記述がありますが、KeyPressではイベントがひろえるようなことが書いてあるのにひろえないので困っています。
なにかよい方法はありませんでしょうか。
わかりにくい説明で申し訳ありませんが困ってます。
宜しくお願いします。
No.3ベストアンサー
- 回答日時:
テキストボックスのほかに、コントロールを貼り付けていませんか?
他のコントロールにタブ移動していてイベントがこなくなっているのでは?
フォーカスを当てられるほかのコントロールのTabStopをFalseにすればいいのでは?
違ってたらすんません。
じゃ、そゆことで。
貼り付けてました・・・。
見た目は全部ラベルだったのでおかしいなとよくよく見たらテキストボックスの不活性継承の為のピクチャボックスがTabstop=Trueになってました。
おかげさまで無事TAB拾えました。どうもありがとうございました。
No.4
- 回答日時:
No.2
- 回答日時:
KeyPressイベントなら、次のどれでも出来るはずです。
(確認済)例1)
Dim str As String
str = Chr(KeyAscii)
If str = vbTab Then
MsgBox "Tab key!"
End If
例2)
If KeyAscii = 9 Then
MsgBox "Tab key!"
End If
例3)
If KeyAscii = vbKeyTab Then
MsgBox "Tab key!"
End If
No.1
- 回答日時:
こんにちは。
itohhといいます。KeyPressとKeyDownイベントの引数ですが、意味合いが違います。
KeyPressイベントのKeyAsciiは、Asciiコードが設定されてきます。
KeyDownイベントのKeyCodeは、VBで決めているキーコード定数が設定されてきます。
KeyPressイベントでTabを拾いたい場合は、以下のように行います。
Private Sub Text1_KeyPress(KeyAscii As Integer)
Dim Rtn As Integer
If KeyAscii = Asc(vbTab) Then
Rtn = MsgBox("Hit!!", vbOKOnly)
End If
End Sub
質問時にコピーしてコードを書いてしまったのでKeyPressとKeyDownのコードを同じにしてしまいました・・・。間違いのご指摘ありがとうございます。
無事解決しました。どうもありがとうございました。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
このQ&Aを見た人はこんなQ&Aも見ています
-
エクセル TABキーの動きをマクロで
Excel(エクセル)
-
PreviewKeyDownイベントが2回発生する
Visual Basic(VBA)
-
DataGridViewでセルクリックイベントを発生させるには
Visual Basic(VBA)
-
-
4
どこにもフォーカスを当てたくない
Access(アクセス)
-
5
VB.net、テキストボックス入力制限、全角のみ
Visual Basic(VBA)
-
6
Ctrl + Cなど複数の入力キーの感知
Visual Basic(VBA)
-
7
Chr(13)とChr(10)の違いは?
PowerPoint(パワーポイント)
-
8
[VB.net] ボタン(Flat)のEnable時の背景色について
Visual Basic(VBA)
-
9
日付型のフィールドに空白を入れる方法を教えてください
その他(データベース)
-
10
VB.NETでのイベントの途中終了
Visual Basic(VBA)
-
11
【VB】タブ切り替え時のイベント
Visual Basic(VBA)
-
12
初期フォーカスについて
Visual Basic(VBA)
-
13
VB.NETで他のプロジェクトで作成したフォームを使う方法
Visual Basic(VBA)
-
14
VBの画面サイズについて
Visual Basic(VBA)
-
15
VBのReturnの使い方
Visual Basic(VBA)
-
16
エクセルVBAのテキストボック、Exitイベント
その他(プログラミング・Web制作)
-
17
コンボボックス ▼ボタンをクリックしたらイベント
PowerPoint(パワーポイント)
-
18
Validated イベントについて
Visual Basic(VBA)
-
19
vba listviewにおけるtextのAlingmentを中央にしたい
Excel(エクセル)
-
20
DataGridViewのフォーカス遷移について
Visual Basic(VBA)
関連するカテゴリからQ&Aを探す
おすすめ情報
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
コマンドボタン(入力)をクリッ...
-
タブキー押下時のイベントをひ...
-
KEYPREVIEW=TRUEについて。意味...
-
C# DateTimePicker をキー入力...
-
【VB】タブ切り替え時のイベント
-
EXCEL VBA でIEを制御して、INP...
-
コンボボックスにキー入力をさ...
-
VB6で電卓を作っているのですが...
-
「ご処理進めて頂きますようお...
-
UPS警告音を止めたい
-
エクセルで、日付を入力すると...
-
CloseとDisposeの違い
-
EXCEL VBA マクロ 実行する度に...
-
DoEventsがやはり分からない
-
銀行の窓口処理の件で知ってる...
-
エクセルVBAで、MsgBox やInput...
-
【Excel】特定の文字を含むセル...
-
VBの質問#if 0 then ってどう...
-
EXCELのマクロが 実行時エラー5...
-
月度は何て読みますか?
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
【VB】タブ切り替え時のイベント
-
特定のキーを押すまでループさ...
-
KEYPREVIEW=TRUEについて。意味...
-
WPFでの時刻入力コントロールに...
-
Visual Basic 6.0 コンボボック...
-
タブキー押下時のイベントをひ...
-
(VBA)チェックボックスのclick...
-
コンボボックスにキー入力をさ...
-
EXCEL VBA でIEを制御して、INP...
-
VB.NETのDropDownListをReadOnl...
-
VB.NETでフォームがない...
-
NULLで検索を行ったときは全件...
-
キーバッファについての質問
-
フォーカスについてお教えください
-
Excel VBA マクロ実行中のみテンキ...
-
コントロールキーが押されたキ...
-
vba set Focus
-
テキストボックスの入力文字を1...
-
一定時間操作されないと自動で...
-
キーイベントを擬似的に発生さ...
おすすめ情報