Добавил:
Upload Опубликованный материал нарушает ваши авторские права? Сообщите нам.
Вуз: Предмет: Файл:
Введение примеры по VBA.doc
Скачиваний:
11
Добавлен:
22.09.2019
Размер:
1.99 Mб
Скачать

Создание меню с помощью vba

      Новое меню в Excel, Word или PowerPoint обычно создается средствами VBA, поскольку в этих приложениях диалоговое окно «Настройка» не содержит кнопки Свойства.Новое меню создается методом Add коллекции CommandBars (Панели команд):

       Выражение.Add(Name, Position, MenuBar, Temporary),

      где выражение –обязательное выражение, возвращающее объект CommandBars, а все параметры в скобках необязательны. Nameзадает имя нового меню;        Positionопределяет его положение (значения-константы msoBarLeft, msoBarTop, msoBarRight, msoBarButtom определяют положение меню слева, вверху, справа или внизу окна, msoBarFloating задает «плавающее» меню, msoBarPopup указывает, что новое меню будет всплывающим).         Значение True параметра MenuBarуказывает на то, что новое меню заменит текущую активную строку меню (по умолчанию – False). Значение True параметра Temporaryозначает, что новое меню будет временным и исчезнет, когда закроется содержащее его приложение (по умолчанию – False).       В следующем примере создается новое меню «Головное меню»:

      Dim CstmBar As CommandBar       Set CstmBar = CommandBars.Add(Name:="Головнoe меню",       Position:=msoBarTop, MenuBar:=True, Temporary:=False)

       Добавление выпадающих меню       Чтобы добавить новое меню программно, надо использовать метод Add коллекции CommandBarControls, применив его к объекту типа CommandBar, который представляет панель нашего меню. Данный метод позволяет помещать на панель кнопки (CommandBarButton), комбинированные списки (CommandBarComboBox) и выпадающие меню (ComandBarPopup). Вызов метода имеет вид:

      выражение. Add(Type, Id, Parameter, Before, Temporary),

      где Выражениедолжно возвратить объект типа CommandBarsControl.         Параметры в скобках необязательны. Параметр Туре(Тип) задает тип добавляемого объекта. Его значение msoControlPopup указывает, что добавляемый управляющий элемент – выпадающее меню. Для пользовательских меню параметры Idи Parameterможно опустить. Значение аргумента Before –число, указывающее положение нового элемента в последовательности элементов панели: если его нет, элемент помещается в конец. Определить имя и ключ быстрого доступа к созданному меню можно, задав значение свойства Caption.       Пример добавления выпадающего меню Ввод документовпанели Головное менюс ключом быстрого доступа «В»:

      Dim CstmCtrl As CommandBarControl       Set CstmCtrl = CstmBar.Controls.Add(Type:=msoControlPopup,       Before:=1)       CstmCtrl.Caption = «&Ввод документов»

      Чтобы добавить новое подменю программно, к объекту, представляющему родительское выпадающее меню, нужно применить метод Add коллекции CommandBarControls. В качестве параметра Туре (Тип) надо использовать значение msoControlPopup.       В следующем примере в конец выпадающего меню Ввод документов,расположенного на панели меню Головное меню,добавляется подменю «о движении товаров»:

      Dim CstmPopUpi As CommandBarPopup       Set CstmPopUpi =       stmCtrl.Controls.Add(Type:=msoControlPopup)       CstmPopUpi.Caption = «о движении товаров»

       Добавление команд       Добавить новую команду в меню можно, применив метод Add коллекции CommandBarControls к объекту, представляющему изменяемое меню. Для того чтобы добавить собственную команду, вставьте ее имя в меню, а затем в качестве значения свойства OnAction задайте имя VBA-процедуры, которая должна вызываться при выборе данной команды. В качестве значения аргумента Туре (Тип) метода Add укажите msoControlButton, означающее, что вставляемый в меню элемент будет командой. Добавим команду «Накладная» в выпадающее меню Ввод документовиз панели Головное меню.Выбор этой команды запускает процедуру Invoice:

      Set CstmCtrl = CstmPopUpi.Controls.Add(Type:=msoControlButton)       CstmCtrl.Caption = «Накладная»       CstmCtrl.OnAction = «Module1.Invoice»

      Метод Add позволяет вставлять в меню и встроенные команды. Для этого при вызове задайте значение параметра Id, равное числовому идентификатору данной команды в Office. Поскольку в Office 2000 количество команд доходит до 4000, в табл. 22 приведем основные команды редактирования.          Таблица 22