Создайте подменю в существующем меню в Excel Shared Add-In

StackOverflow https://stackoverflow.com/questions/2690879

  •  01-10-2019
  •  | 
  •  

Вопрос

Я разрабатываю дополнительный дополнение Excel, который имеет меню под названием Custom который создан с использованием MACROS Excel. Теперь я хочу создать подменю под Custom Меню с использованием CSHARP Shared Add -in. IAM, используя код ниже для этого, но нет помощи

oStandardBar = oCommandBars["Custom"];
oCmdBarCtrl = oStandardBar.Controls.Add(MsoControlType.msoControlPopup, Type.Missing, Type.Missing, Type.Missing, true);
oCmdBarCtrl.Visible = false;
oCmdBarCtrl.Caption = "Sub Menu1";

Но это не создает подменю, где, как будто я даю «помощь» вместо пользовательского, я создаю меню. Любая работа для этого?

Это было полезно?

Решение

Вот быстрый образец, чтобы помочь вам на вашем пути:

        var m_toolbar = this.Application.CommandBars.Add("WpfAddIn",
            Office.MsoBarPosition.msoBarTop, false, true);

        var mainMenu = (Office.CommandBarPopup)m_toolbar.Controls
            .Add(Office.MsoControlType.msoControlPopup, 
            missing, missing, missing, true);
        mainMenu.Caption = "Main menu";

        var subMenu1 = (Office.CommandBarButton)mainMenu.Controls
            .Add(Office.MsoControlType.msoControlButton, 
            missing, missing, missing, true);
        subMenu1.Caption = "Sub menu 1";
        subMenu1.FaceId = 1958;

        var subMenu2 = (Office.CommandBarPopup)mainMenu.Controls
            .Add(Office.MsoControlType.msoControlPopup,
            missing, missing, missing, true);
        subMenu2.BeginGroup = true;
        subMenu2.Caption = "Sub menu 2";

        var subMenu2Button = (Office.CommandBarButton)subMenu2.Controls
            .Add(Office.MsoControlType.msoControlButton,
            missing, missing, missing, true);
        subMenu2Button.Caption = "Sub menu 1";
        subMenu2Button.FaceId = 1958;

        m_toolbar.Visible = true;
Лицензировано под: CC-BY-SA с атрибуция
Не связан с StackOverflow
scroll top