IT仕事

Excel2013のリボン&タブのカスタマイズで格闘。

投稿日:

今まで、BookのXMLにリボンメニューを仕込むのは難しいのだと思っていた。
実際、Excel2003でアドインメニューを作ったことがあるが、そのときは相当苦労した。

しかし無料のツールを使えば、かなり簡単にリボンにメニューを配置できることがわかった。
Excel 2007 アドインでリボンメニューを作成する方法: ある SE のつぶやき

自分の場合、こちらの記事を参考に、以下のようなコードを書いた。
Office 2007/2010・リボンのカスタマイズ 初心者備忘録

Sub Ribbon_onLoad(ribbon As IRibbonUI)
  Set myRibbon = ribbon
  Call myRibbon.ActivateTab("customTab")
End Sub

ファイルをロードした直後にリボンにカスタムタブをセットするという、単にこれだけですが、結構このコードにするのに時間がかかった。

また、Excelを起動してからファイルを開くとカスタムタブは自動で開くが、エクスプローラからのダブルクリックでファイルを開くと、リボンのカスタムタブが開かずにホームタブのまま。。。

さらに、Workbook_Openの際の処理(IF文でパスワードチェック)と、Ribbon_onLoadの際の処理が、バッティングしているような感じで、ファイルを開くときに、「オブジェクト変数または With ブロック変数が設定されていません」エラーが出ることも。

半日ぐらいあれこれいじって悩んで、結局、Ribbon_onLoadに入れてしまえばよいのではないかと考え、そうしたら、うまくいった。以下のコードに落ち着いた。
起動時は、ExcelのOpenなどの通常のイベントの後に、リボン関係のXMLがロードされる、そんな順番になっている、ということかな。

Sub Ribbon_onLoad(ribbon As IRibbonUI)
  Set myRibbon = ribbon
  Call myRibbon.ActivateTab("customTab")

  '以下、ThisWorkbookのOpenイベントに書いたものを移動

Dim Sht As Worksheet, ActSht As String, r As String
Application.ScreenUpdating = False
    If Sheets("system").Range("A1") = "" Then '1なら管理者、空白なら職人がログイン
        If InputBox("パスワード") = "aaa" Then
            Call ForAdminMeisai
            Sheets("system").Range("A1") = 1
        Else
            MsgBox "パスワードが違います"
            Application.ExecuteExcel4Macro "SHOW.TOOLBAR(""Ribbon"",False)"
        End If
    Else
    End If
Application.ScreenUpdating = True
End Sub

-IT仕事

執筆者:

関連記事

no image

ハンディターミナルのアプリ

知り合いからハンディターミナルのアプリケーションを作れないかと頼まれた。 作った事無いんだけどというと、簡単なのでいいからといわれ、それでいろいろ調べた。 私、そのあたりにどんな開発ツールがあるのかさ …

no image

PhotoshopElementsで枠線を書くには

方法が長らくわからなかったが、今日わかったので書いておく。 図形ツールで図形を描く ラスタライズ メニューの「編集」-「境界線を描く」 上記の方法は、操作対象が「境界線」のため、たとえば「選択範囲」- …

PhotoshopElementsで写真の角を丸くする

方法を見つけるのに2時間ほどかかってしまったので備忘録・・・。 1.写真をCtrl+Aで全選択。 2.選択範囲-選択範囲を変更-境界線-10px。境界線が選択される 3.選択範囲-選択範囲を変更-滑ら …

no image

EC-CUBEをXAMPPを使ってローカルインストールした

表記の情報がWebにあまりなかったので、誰かの参考になるかと思い、記しておく。 ■XAMPPをインストール ごく、普通に。 ■データベースの作成 XAMPPのPHPMyAdminで、eccubeなどと …

no image

ITC

昨晩は飲み会だった。 さるNPOの総会後の懇親会。 酔っ払っていたので帰ってからすぐに布団に入って寝入ってしまったのだが、さっき、腕を蚊に喰われてかゆみで目が醒めてしまい、こうして日記を書いている。 …