• ベストアンサー
※ ChatGPTを利用し、要約された質問です(原文:Excel-VBA ショートカットメニュー追加)

Excel-VBA ショートカットメニュー追加

このQ&Aのポイント
  • マウス右クリックでのショートカットメニュー「テストA、テストB、テストC」を追加するExcel-VBAの方法について教えてください。
  • CommandBarControls.AddメソッドのBeforeパラメータを定義することで最上段にメニューを追加する方法を教えてください。
  • 現在のコードでは最後にメニューが追加されてしまう状態です。正しい記述方法を教えてください。

質問者が選んだベストアンサー

  • ベストアンサー
  • Wendy02
  • ベストアンサー率57% (3570/6232)
回答No.1

>最上段に追加(挿入)したい、 このようにすればよいと思います。 Sub RightClickMenuAdding()  '右クリックメニュー登録  With Application.CommandBars("CELL") '二重登録を避けるために入れる   On Error Resume Next   .Controls("テストA").Delete   .Controls("テストB").Delete   .Controls("テストC").Delete   On Error GoTo 0   With .Controls.Add _    (Type:=msoControlButton, Before:=1, Temporary:=True)    .BeginGroup = False    .Caption = "テストC"    .OnAction = "mymsgC"   End With     With .Controls.Add _    (Type:=msoControlButton, Before:=1, Temporary:=True)    .BeginGroup = False    .Caption = "テストB"    .OnAction = "mymsgB"   End With   With .Controls.Add _    (Type:=msoControlButton, Before:=1, Temporary:=True)    .BeginGroup = False '←True, False どちらでも良い    .Caption = "テストA"    .OnAction = "mymsgA"   End With  End With End Sub

sakuraww
質問者

お礼

早々の回答有難うございました。 非力な私なのですがやっと皆様の回答内容を理解できました。両者ともBerryGood-感謝。 参考1:指定に[After]が無いため苦肉の策として次のダミーを追記して実践運用する事としました。 With .Controls.Add(Type:=msoControlButton, Before:=1, Temporary:=True) .BeginGroup = True '←グループの初め(横線) .Enabled = False '←不活性化する End With 参考2:二重登録回避策として最良かどうか半信半疑ですが、 「.Controls("テストA").Delete」ではなく、 次の「.Reset」で実践運用しています。 Application.CommandBars("Cell").Reset '←標準に戻す 以上

その他の回答 (1)

  • imogasi
  • ベストアンサー率27% (4737/17070)
回答No.2

既出回答で良いのだと思いますが、下記でもやってみました。 加える位置はBeforeで指定するようですが、Afterがあるかどうか判りません(エラーになった)。 追加位置と、インデックス番号を使った。Add-Selectがうまく行かなかったので。 配列で繰り回せるが、類似コードを3回記述した。 Sub ShortCutMenuAdd1() Application.CommandBars("Cell").Controls.Add Type:=msoControlButton, Temporary:=True, Before:=1 With Application.CommandBars("CELL").Controls(1) .Caption = "テストA" .OnAction = "mymsgA" .BeginGroup = True End With Application.CommandBars("Cell").Controls.Add Type:=msoControlButton, Temporary:=True, Before:=2 With Application.CommandBars("CELL").Controls(2) .Caption = "テストB" .OnAction = "mymsgB" .BeginGroup = True End With Application.CommandBars("Cell").Controls.Add Type:=msoControlButton, Temporary:=True, Before:=3 With Application.CommandBars("CELL").Controls(3) .Caption = "テストC" .OnAction = "mymsgC" .BeginGroup = True End With 'Set newMenu = Nothing End Sub ーー 参考 ついでにテスト中に余分なまたは位置を誤った追加が行われたときは、訂正には下記を使いました。 適当にコメント記号をはずして実行しました。 インデックス番号での指定(位置での指定)がわかりやすかった。 Public Sub ShortCutMenuAdd() 'Excel-VBA ショートカットメニューアイテム表示・削除 Dim newMenu As CommandBarControls Dim ctl ' With Application.CommandBars("CELL") For Each ctl In Application.CommandBars("CELL").Controls MsgBox ctl.Index & " " & ctl.Caption Next With Application.CommandBars("CELL") '.Controls(1).Delete '.Controls(2).Delete '.Controls(3).Delete .Controls(4).Delete '.Controls(5).Delete '.Controls("テストA").Delete '.Controls("テストB").Delete '.Controls("テストC").Delete End With End Sub

sakuraww
質問者

お礼

早々の回答有難うございました。 複数の方から回答を頂いたのですが何れも実用的に申し分ない事例であると感謝しています。 両者は何れもベストアンサーなのですが、やむを得ず先に回答いただいた方をベストアンサーとした事をご理解下さい。 類似コードを3回記述するのも理解しやすくて良い方法だと思います。 次の記述はデバッグ時おおいに役にたちそう…使わせていただきます。 ▽ショートカットメニューアイテム表示 For Each ctl In Application.CommandBars("CELL").Controls MsgBox ctl.Index & " " & ctl.Caption Next 以上

関連するQ&A