- •Часть 1. Макросы и язык программирования vba. Среда редактора visual basic
- •Часть 2. Редактирование простых макросов
- •2U Object Browser
- •Import File
- •Часть 3. Типы данных, переменные и константы. Выражения в visual basic. Использование функций visual basic
- •Часть 4. Изменения порядка выполнения операторов в vba
- •Часть 5. Повторение действий в vba: циклы
- •I Statements
- •Часть 6. Массивы. Объекты vba для ввода-вывода
- •Часть 7. Создание и использование функций и функций-процедур
- •Часть 8. Элементы диалоговых окон
- •' Мним ' ' IIIIIIIII ' тГмшмГ ' ' ниши' |( ' .... Jwli ....
- •Часть 1. Макросы и язык программирования vba. Среда редактора Visual
Часть 8. Элементы диалоговых окон
До сих пор вы учились использовать диалоговые окна, которые встроены в VBA, а именно, функции MsgBox и InputBox. Хотя MsgBox и InputBox придают вашим программам гибкость, которой могут обладать только интерактивные программы, их возможности в известной степени ограничены. При разработке более сложных программ вы захотите выводить диалоговые окна, которые дают
104
возможность пользователям ваших программ задавать при помощи одного диалогового окна сразу несколько опций, выбирать пункты из списка или вводить в одном окне несколько значений подобно тому, как это можно делать с помощью диалоговых окон, выводимых Word, Excel и другими приложениями Windows.
VBA позволяет создавать и применять пользовательские диалоговые окна в написанных вами программах и процедурах при помощи добавления в проект объекта UserForm. Используя VBA-формы пользователя (VBA User Forms), вы можете создавать диалоговые окна для вывода данных или получения значений от пользователя вашей программы именно в том виде, который требуется вашей программе.
Из этой части вы узнаете об основных элементах диалоговых окон и их свойствах, научитесь создавать простые диалоговые окна.
Лабораторная работа № 8. Формы пользователя
Цель занятия: Уметь создавать формы пользователя и элементы
управления Материалы к занятию: MS Excel 2003.
Свойства и методы объекта UserForm
Диалоговое окно в VBA создается добавлением в проект объекта UserForm. Объект UserForm – это пустое диалоговое окно. Настройку диалогового окна можно выполнить добавлением к объекту UserForm (обычно называют просто форма) элементов управления. Каждому объекту UserForm присущи определенные свойства, методы и события, которые он наследует от класса объектов UserForm. Каждый объект UserForm включает в себя также модуль класса, в который вы можете добавлять собственные методы и свойства или код обработки событий формы.
Первый шаг в создании пользовательского диалогового окна состоит в добавлении к проекту новой формы (объекта UserForm). Форма содержит рабочую область, в которую вы можете поместить элементы, необходимые для выполнения некоторого диалога пользователя с приложением. Поскольку объекты UserForm хранятся в коллекции UserForms проекта, они являются частью проекта.
Задание 1. Добавьте в проект новую форму.
Для этого:
ь выберите команду Insert/UserForm (Вставка/UserForm).
Редактор VB добавляет к текущему проекту новую форму, присваивая ей по умолчанию имя UserFormN и используя ту же систему нумерации, что и для модулей. Редактор VB выводит новую форму в режиме разработки (рис. 23). В режиме разработки вы можете добавлять (или удалять) элементы управления к форме, устанавливать свойства формы или ее элементов управления и выполнять другие манипуляции с внешним видом формы в интерактивном режиме. Когда форма выведена и используется как часть выполняющейся программы, она находится в режиме выполнения.
105
Рис. 23
Обратите внимание на сетку из точек на поверхности формы и панель элементов (Toolbox). Сетка из точек помогает выравнивать и контролировать размеры элементов управления, помещаемых на форму, и появляется только в режиме разработки. Панель элементов является «палитрой», с помощью которой вы можете выбирать элементы управления и добавлять их к форме. Панель, как правило, появляется только в том случае, если выбрана форма и ни один из ее элементов управления.
Вы можете переименовать объект UserForm так же, как стандартный модуль или модуль класса. Для этого отредактируйте в Properties Window (окно свойств) свойство Name этого объекта. Не оставляйте вновь созданной форме имя, присвоенное ей по умолчанию, например UserForm1 или UserForm2. Напротив, переименовывайте новую форму сразу, как только ее создали.
Упражнение 1
Переименуйте созданную форму заданием 1, дав ей имя NewForm8_21.
Когда форма выводится на экран в режиме разработки, вы можете протестировать ее поведение, используя команду Run/ ► ^ sub/u^m fs (Запуск/Запуск подпрограммы/UserForm). После этого Редактор VB выведет форму в режиме выполнения и все ее элементы управления будут активными. Однако следует помнить, что любой код, используемый формой, хранящийся не в модуле класса формы, не может быть инициализирован. При запуске формы инициализируется только код, находящийся в модуле класса формы. Переменные в стандартных модулях необязательно будут инициализироваться. В результате
106
этого, если форма не является полностью независимой, некоторые из программ связанных с ней, могут не выполняться, выдавая сообщения о различных runtime-ошибках.
Форма как объект имеет некоторые встроенные свойства, и вы можете устанавливать эти свойства или программным образом, или в Properties Window (окне свойств) Редактора VB. Строго говоря, данные способы изменения свойств форм не являются эквивалентными. Некоторые из свойств могут быть установлены только посредством Properties Window Программным способом свойства форм устанавливаются таким же образом, как и свойства других объектов: путем присвоения свойству нового значения (в табл. 22 перечислены свойства UserForm, на которые вам, скорее всего, придется ссылаться или изменять их).
Таблица 22 – Наиболее часто используемые свойства объектов UserForm
Свойство
Описание
ActiveControl
Возвращает объектную ссылку на элемент управления, находящийся в фокусе в данный момент. Только для чтения
BackColor
Caption
Controls Cycle
Целое типа Long определяет цвет фона формы. Самый простой способ установить это свойство – использовать Properties Window; чтобы выбрать желаемый цвет (если необходимо), можно скопировать номер цвета из Properties Window в свою программу Текст, выводимый в качестве заголовка формы. Запись/Чтение
Возвращает коллекцию всех элементов управления формы. Только
для чтения
Определяет, должно ли нажатие клавиши табуляции вызывать
последовательный выбор всех элементов управления во всех группах
и на каждой странице многостраничных элементов управления или
только в пределах текущей группы или страницы. Может содержать
одну из двух встроенных констант: fmCycleAllForms или
fmCycleCurrentForm. Чтение/Запись
Enabled
Содержит значение типа Boolean, указывающее, доступна ли форма.
Если его значение равно False, ни один из элементов управления
Font ForeColor
формы не доступен. Чтение/Запись
Возвращает ссылку на объект Font, посредством которого вы можете
выбрать параметры шрифта формы или элемента управления
используемый для переднего плана (обычно — это цвет текста)
объекта формы
раз создавая в проекте новый объект UserForm, вы создаете новый
То же самое, что и свойство BackColor, но устанавливает цвет
Всякий
подкласс объекта UserForm. Любые процедуры или функции, написанные вами в разделе General (общий) модуля класса, относящегося к форме, становятся дополнительными методами для отдельного подкласса объекта. Вы также можете создать для формы новые свойства, добавив в ее модуль класса процедуры Property Get и Property Let. Вы можете создавать экземпляры подкласса вашей UserForm с помощью оператора Dim и ключевого слова New.
Однако чаще всего вы будете манипулировать объектом формы при
107
помощи стандартных методов и свойств класса UserForm и при помощи собственных процедур обработки событий для определенной вами формы и ее элементов управления.
В этой части при написании примеров процедур обработки событий нам понадобится метод Show. Поэтому рассмотрим его подробнее. Синтаксис метода Show:
FormName.Show
в данной синтаксической конструкции FormName может быть любым объектом UserForm текущего проекта. FormName – имя формы в том виде, как оно отображается в Project Explorer. Если форма в данный момент не загружена в память, метод Show загрузит ее и выведет на экран. Если форма уже загружена, метод Show просто выведет ее на экран. В любом случае метод Show выводит форму и затем передает ей управление. Форма будет оставаться на экране до тех пор, пока или не будет выполнен метод Hide (скрывает форму, не выгружая ее из памяти) объекта UserForm, или форма не будет выгружена при помощи оператора Unload.
Все формы VBA являются модальными (modal) приложениями, это означает, что вы не сможете выполнить какое-либо другое действие в приложении до тех пор, пока форма диалога не будет закрыта или скрыта.
Когда VBA выполняет метод Show для отображения формы диалогового окна, процедура, содержащая вызов метода Show, приостанавливается до тех пор, пока выведенная форма не будет закрыта пользователем. Однако VBA будет выполнять программу для любых событийных процедур в модуле класса формы.
События и событийные процедуры
Событие (event) – это что-то, что может произойти с диалоговым окном или элементом управления диалогового окна. Типичные примеры событий: щелчок на кнопке, переключателе и т.д. Другие примеры событий: изменение содержимого окна редактирования или выбор элемента списка. Щелчок мышью, нажатие клавиши и действия внутренние для вашего компьютера, – все они запускают или, иными словами, влекут за собой события.
Использование событий позволяет создавать действительно диалоговые приложения. В таких приложениях все действия пользователя приводят к определенной реакции приложения, если эти действия предусмотрены и не заблокированы. Если вы хотите, чтобы ваши пользователи чувствовали себя комфортно при работе с вашими программами, начинайте создавать свои диалоговые окна с разработки событийных процедур.
Такие объекты, как формы и элементы управления приводят в действие, то есть делают доступными, некоторые события. Вы можете написать собственные VBA-процедуры, реагирующие на события. Такие процедуры, называются событийными процедурами (event procedures) или процедурами обработки событий.
Событийные процедуры следует записывать в модуль класса, который является частью UserForm. При этом такие процедуры должны иметь имена в виде ObjectName_EventName, где ObjectName – имя формы или элемента
108
управления, a
EventName
– имя
события, с которым вы хотите работать.
Такой формат имени, позволяет VBA
сопоставлять заданному событию требуемую
процедуру.
Большая часть
программы, которую вы записываете в
модуль класса формы, будет связана с
обработкой событий (в таблице 23
перечислены события, для которых вы
можете написать процедуры обработки).
Таблица 22 –
События объектов UserForm
выгружается из
памяти. Используйте это событие для
осуществления любых специальных
служебных задач, которые необходимо
выполнить прежде, чем переменные
формы будут выгружены. В
дополнение к методам, свойствам и
событиям, встроенным в объект UserForm,
VBA
предоставляет два оператора, которые
особенно полезны при работе с объектами
форм: Load
и Unload.
Вы можете использовать эти операторы
109
Activate
Click DblClick
Deactivate
Initialize
Resize
Terminate
заголовка обработки
Синтаксис процедуры события
Private Sub
object_Activate()
Private Sub
object_Click(index As Long) Private Sub
objecf_DblClick(index As Long, ByVal Cancel As MSForms. ReturnBoolean) Private Sub
object_Deactivate()
Private Sub
object_Initialize()
Private Sub
UserForm_Resize() Private Sub
object_Terminate()
Описание
Инициируется всякий раз, когда окно формы становится активным. Используйте это событие для обновления содержимого диалоговых элементов управления, чтобы отразить любые изменения, которые произошли, пока окно формы было неактивным
Инициируется всякий раз, когда по форме (любой ее части, не занятой элементами управления) щелкают мышью
Инициируется всякий раз, когда по форме (любой ее части, не занятой элементами управления) дважды щелкают мышью
Инициируется всякий раз, когда форма перестает быть активной (при открытии другой формы) Инициируется всякий раз, когда форма
впервые загружается в память посредством
выполнения оператора Load или с
помощью метода Show. Используйте это
событие для инициализации элементов
управления формы при ее появлении на
экране
Инициируется при изменении размеров
формы
Инициируется всякий раз, когда форма
для того, чтобы или загрузить форму в память, или же удалить ее оттуда. Синтаксические конструкции для использования операторов Load и Unload выглядят следующим образом:
Load Object Unload Object
здесь Object представляет любую допустимую ссылку на объект UserForm. Оператор Load загружает в память объект UserForm и запускает метод формы Initialize, но не выводит форму на экран. Когда форма загружена, вы можете использовать написанную на VBA программу для работы с объектом UserForm. Оператор Unload удаляет из памяти UserForm, а также все переменные формы. После того как форма выгружена, она перестает быть доступной для VBA-кода.
Рассмотрим несколько простых примеров использования свойств и методов формы с помощью процедур обработки событий.
Задание 2. Создайте форму, выводящую сообщения на события Click, Activate, Terminate.
Для этого:
ь выберите команду Insert/UserForm (Вставка/UserForm); ь дважды щелкнуть на форме в режиме разработки, и вам будет предоставлен шаблон процедуры в виде:
1 Private Sub UserForm_Click() 2
3 End Sub
ь запишите после заголовка процедуры следующий оператор
2 MsgBox("Событие: Click")
ь запустите форму на выполнение командой Run/Run Sub/UserForm. После появления формы на экране щелкните на ней мышью, на экране появится сообщение (рис. 24);
Рис. 24 ь запишите в модуле рассматриваемой формы следующую процедуру (или выберете в Procedure событие Activate):
1 Private Sub UserForm_Activate()
2 MsgBox ("Событие: Activate")
3 End Sub
ь снова запустите форму на выполнение командой Run/Run Sub/UserForm. После появления формы на экране вы увидите сообщение о том, что произошло событие Activate (рис. 25);
110
ь выберете в Procedure событие Terminate;
ь запишите после заголовка процедуры UserForm_Terminate следующий оператор 2 MsgBox("Событие: Terminate")
ь запустите форму на выполнение командой Run/Run Sub/UserForm. После появления формы на экране щелкните на ней мышью, на экране появится сообщение (рис. 26).
Рис. 26
Если даже вам не часто будет нужно использовать подобное событие для формы, не забывайте о такой возможности. А еще лучше поступайте следующим образом. Всегда используйте это событие на случай, когда пользователь ваших форм при попытке щелкнуть на каком либо элементе управления не совсем точно позиционирует курсор мыши. Если при этом будет выполняться процедура обработки события Click для формы с выводом шутливого сообщения о недостаточной уверенности в действиях пользователя, с вашим приложением станет приятно работать. Вы также никогда не забудете о возможности использовать это событие, когда для этого появятся серьезные причины.
Событие Initialize инициализируется при загрузке формы при помощи оператора Load или метода Show. При выполнении команды Run/Run Sub/UserForm это событие не инициализируется. Это событие следует использовать при первой загрузке формы для установки каких-либо свойств формы и ее элементов управления. В следующем примере (листинг 21) для этого события устанавливается свойство формы BackColor.
Задание 3. Создайте форму, изменяющую фон цвета на событие Click.
Для этого:
ь выберите команду Insert/UserForm (Вставка/UserForm); ь дважды щелкнуть на форме в режиме разработки и введите следующие процедуры событий UserForm2 (листинг 21):
Листинг 21 – Процедуры событий UserForm2 1 Dim sRED, sGREEN, sBLUE 'переменные для задания цвета формы 2
111
'Процедура обработки события Initialize
'инициализируется один раз: при загрузке
Private Sub UserForm_Initialize()
' задаем начальный цвет формы
sRED = 100
sGREEN = 100
sBLUE = 200
UserForm2.BackColor = RGB(sRED, sGREEN, sBLUE)
11 End Sub 12
'Процедура обработки события Click
'При каждой инициализации меняет цвет формы. При недопустимых
'значениях sRED, sGREEN, sBLUE выдает ошибку времени исполнения
Private Sub UserForm_Click()
17 Dim i 18
'Меняем цвет формы:
sRED = sRED + 20
sGREEN = sGREEN + 10
SBLUE = SBLUE – 20
i = RGB(SRED, SGREEN, SBLUE)
UserForm2.BackColor = i
UserForm2.Caption = "Цвет: " & Str(i) 'Изменить заголовок формы:
26 End Sub
После вывода формы с именем UserForm2 на экран событие Click будет приводить к изменению цвета и заголовка формы.
В листинге 21 для установки свойства формы BackColor используется функция RGB, которая возвращает RGB-значение типа Long, используемое далее для присвоения свойству UserForm2.BackColor. Синтаксис функции RGB:
RGB(red, green, blue)
именованные аргументы: Red, Green, Blue – обязательные; тип: Variant (Integer); числа в диапазоне 0–255; представляют красный, зеленый и синий компоненты цвета).
Упражнение 2
Создайте форму, выводящую сообщения на события DblClick, Deactivate, Resize.
Элементы управления
Объект UserForm может содержать те же элементы управления, что и находящиеся в диалоговых окне Excel или других приложений Windows. Элементы управления (controls) – это элементы диалогового окна, которые дают возможность пользователю взаимодействовать с программой. Они включают в себя кнопки-переключатели, текстовые поля, линейки прокрутки, командные кнопки и так далее. В этом разделе вы познакомитесь со стандартными
112
элементами управления, включенными в VBA, которые сможете добавлять в свои формы.
Каждый элемент управления – это объект с определенными свойствами, методами и событиями. Как и для формы, их содержащей, вы можете устанавливать свойства элементов управления программным путем или посредством Properties Window Редактора VB. В программе вы можете присваивать или восстанавливать значения свойств элементов управления так же, как для любых других объектов.
В табл. 23 перечислены стандартные элементы управления, включенные в VBA, и описано назначение каждого элемента. Как видно из этой таблицы, к стандартным относятся, практически, все элементы управления, которые вам встречались в приложениях Windows. В зависимости от host-приложения VBA, в котором вы работаете, на панели Toolbox могут появляться дополнительные элементы управления, не перечисленные в табл. 23. Эти дополнительные элементы доступны через библиотеки элементов управления, поставляемые с каждым из host-приложений.
Таблица 23 – Стандартные элементы управления, включенные в VBA
Элемент управления |
Кнопка его Назначение создающая | |
Label (надпись, метка) |
А |
Позволяет создавать заголовки элементов управления, которые не имеют собственных встроенных заголовков. Используйте этот элемент для того, чтобы поместить на форму статический текст, например, инструкции, советы по заполнению других диалоговых элементов управления |
TextBox (текстовое поле) |
аЫ |
Окно редактируемого текста свободной формы для ввода данных. Может быть одно- или многострочным |
ComboBox (поле со списком) |
ш |
Этот элемент управления объединяет окно редактирования и окно списка. Используйте, когда хотите предложить пользователю выбрать значение, но при этом дать ему возможность ввести данные, отсутствующие в списке. Вы можете также ограничить выбор только теми значениями, которые появляются в ComboBox для эмуляции ниспадающего списка |
ListBox (список) |
и |
Отображает список значений, из которых пользователь может сделать выбор. Окна списка можно использовать, чтобы дать возможность пользователю выбрать только одно значение или же несколько |
CheckBox (флажок) |
F |
Стандартный флажок (квадратное окно, содержащее, если элемент выбран, «галочку»). Используйте флажки для выбора вариантов, которые не являются взаимоисключающими |
OptionButton (переключатель) |
р |
Стандартная кнопка-переключатель (круглое окно, при выборе в центре него находится черная точка). Используйте OptionButton, когда пользователю |
113
Элемент Кнопка его Назначение управления создающая | ||
|
|
необходимо сделать выбор между «включено/выключено», «истина/ложь». Кнопки-переключатели, как правило, объединяются вместе при помощи рамки для создания группы переключателей |
ToggleButton (выключатель) |
_| |
Выключатели служат для той же цели, что и флажки, но выводят установки в виде кнопки находящейся в «нажатом» или «отжатом» состоянии |
Frame (рамка) |
а |
Визуально и логически объединяет некоторые элементы управления (особенно флажки, переключатели и выключатели). Используйте Frame, чтобы показать пользователю, какие элементы управления в диалоговом окне связаны между собой, или чтобы выделить группу элементов управления, отделяя ее от остальных элементов управления, находящихся в диалоговом окне |
CommandBut ton (кнопка) |
_i |
Используйте кнопки для выполнения таких действий, как Отмена (Cancel), Сохранить (Save), ОК и так далее. Когда пользователь щелкает по кнопке, выполняется VBA-процедура, закрепленная за данным элементом управления |
TabStrip (набор вкладок) |
|
Этот элемент управления состоит из области, в которую следует помещать другие элементы управления (такие как текстовые поля, флажки и так далее) и полосы кнопок табуляции. Используйте элемент управления TabStrip для создания диалоговых вкладок, отображающих одни и те же данные в различных категориях |
MultiPage (набор страниц) |
_и |
Этот элемент управления состоит из нескольких страниц. Вы можете выбрать любую из них, щелкнув по соответствующей вкладке. Используйте элемент управления MultiPage для создания диалоговых окон с вкладками, такими, например, как диалоговое окно, появляющееся при выборе команды Tools/Options (Панели инструментов/Настройка) |
ScrollBar (полоса прокрутки) |
±i |
Элемент управления ScrollBar позволяет выбирать линейное значение, аналогично тому, как это можно сделать при помощи счетчика |
SpinButton (счетчик) |
и |
Элемент управления SpinButton является специальной разновидностью текстового поля. Обычно счетчики используются для того, чтобы ввести число, дату или какие-либо иные последовательные величины, которые заведомо находятся в определенном интервале значений. Щелчок по указывающей вверх стрелке счетчика увеличивает значение в окошке, а щелчок по стрелке, направленной вниз, соответственно, уменьшает его. |
114
Элемент управления
Image (рисунок)
Кнопка его Назначение создающая
Элемент управления Image позволяет вывести на форме
графическое изображение. Используйте Image для вывода графических изображений в любом из следующих форматов: *.bmp, *.cur, *.gif, *.ico, *.jpg, *.wmf. Вы можете обрезать и масштабировать графическое изображение, чтобы подобрать размер элемента Image, но только не редактировать графическое изображение. Можно даже написать специальную VBA-процедуру, выполняющуюся, если пользователь щелкнет по элементу управления Image. Обращение к элементам управления происходит, в основном, через их свойства и с помощью процедур обработки событий, написанных для каждого элемента. В табл. 24 перечислены наиболее часто используемые свойства элементов управления, которые могут понадобиться для работы с вашими VBA-программами – свойства, которые позволяют изменять заголовок, определять состояние элемента управления (то есть обнаруживать установки, выполненные пользователем) и так далее.
Таблица 24 – Наиболее часто используемые свойства стандартных элементов управления
Свойство |
Где применяется |
Описание |
Accelerator |
CheckBox, Tab, CommandButto n, Label, Page, OptionButton, ToggleButton |
Содержит символ, используемый, в качестве быстрой клавиши вызова, элемента управления. При нажатии ALT+<клавиша быстрого вызова> происходит выбор элемента управления |
BackColor |
Все элементы |
Число, представляющее определенный цвет фона элемента управления |
Caption |
CheckBox, CommandButto n, Frame, Label, OptionButton, ToggleButton, Page, Tab, UserForm |
Для надписи – текст, отображаемый, элементом управления. Для других элементов управления – надпись, которая появляется на кнопке или вкладке или рядом с рамкой, флажком или переключателем |
Cancel |
CommandButto n |
Задает кнопку отмены диалогового окна. При нажатии на эту кнопку или клавишу Esc диалоговое окно исчезает. Только одна кнопка формы может иметь данное свойство |
ControlTipTe xt |
Все элементы управления |
Устанавливает текст, который отображается в виде всплывающей подсказки (ControlTip, называемой также ToolTip), когда указатель мыши помещается на элемент управления |
115
Свойство |
Где применяется |
Описание |
Default |
CommandButto Определяет заданную по умолчанию кнопку. Когда n пользователь нажимает в процессе диалога клавишу Enter, эта кнопка ведет себя так, как если бы по ней щелкнули мышью | |
Enabled |
Все элементы управления |
Хранит значение типа Boolean, определяющее доступен или нет элемент управления. Если Enabled имеет значение False, то элемент управления продолжает отображаться в диалоговом окне, но не может быть выбран |
ForeColor |
Все элементы управления |
То же самое, что и BackColor, но устанавливает цвет для переднего плана элемента управления, как правило, символов текста |
List |
ComboBox |
Массив типа Variant (одно- или многомерный), представляет список содержащийся в элементе управления. Используйте индекс Value как нижний индекс в коллекции List, чтобы получить текст для выбранного пункта списка. Используйте методы элемента управления Addltem и Removeltem для добавления или удаления пунктов списка |
Max |
ScrollBar, SpinButton |
Переменная типа Long, определяющая максимальное значение счетчика или значение, при котором полоса прокрутки находится в самом верху (для вертикальной полосы) или справа (для горизонтальной) |
Min |
ScrollBar, SpinButton |
Переменная типа Long, определяющая минимальное значение счетчика или значение, при котором полоса прокрутки находится в самом низу (для вертикальной полосы) или слева (для горизонтальной) |
Name |
Все элементы управления |
Содержит имя элемента управления. Вы можете установить данное свойство только с помощью Properties Window |
RowSource |
ComboBox |
Задает источник, из которого ListBox берет список объекта. В Excel VBA RowSource обычно использует диапазон рабочего листа |
Selected |
ListBox |
Возвращает массив значений типа Boolean для списка, который допускает множественный выбор. Каждый элемент массива содержит по одному элементу, соответствующему каждому пункту списка. Если значение элемента в массиве Selected равно True, то соответствующий пункт списка выбран |
TabIndex |
Все элементы управления |
Число, указывающее положение элемента управления в порядке табуляции (может иметь |
116
Свойство |
Где применяется |
Описание |
|
|
значение от 0 до значения, равного количеству элементов управления на форме) |
TabStop |
Все элементы управления |
Значение типа Boolean, указывающее может ли элемент управления быть выбран клавишей Tab. Если значение TabStop равно False вы, тем не менее, можете щелкнуть на элементе и таким образом его выбрать |
Value |
Все элементы управления |
Значение текущих установок элемента управления: текст в текстовом поле, какие выбраны флажки и переключатели, индекс выбранного раздела списка или число, указывающее, текущее положение полосы прокрутки или счетчика |
Visible |
Все элементы управления |
Значение типа Boolean, указывающее, является ли элемент управления видимым. |
Использование Toolbox (панели элементов)
Прежде чем мы рассмотрим примеры обработки событий, связанных с элементами управления, вам следует научиться помещать элементы управления на форму и задавать им необходимые свойства.
Редактор VB в режиме разработки вместе с формой выводит на экран Toolbox (панель элементов) (если вывод этой панели не отключен при помощи меню View/Toolbox) (рис. 27). Кнопки на панели Toolbox активизируют различные инструменты, которые позволяют помещать на форму элементы управления.
Рис. 27
Toolbox (подобно всем другим панелям инструментов) можно настраивать.
Вы можете изменить размер самой формы. Щелкните по строке заголовка формы для ее выделения и затем, перемещая один из маркеров изменения размеров, увеличьте или уменьшите размер формы до желаемого. Маркеры изменения размеров (sizing handles) - это маленькие квадратики, которые появляются в углах и на серединах сторон графического объекта (наряду с толстой серой границей) при выделении объекта.
Когда вы создаете новую форму, Редактор VB предоставляет чистую (без элементов управления) форму. Вы можете добавить к форме элементы управления с использованием различных инструментов панели Toolbox.
117
Добавив к форме кнопку, вы можете заметить, что верхний левый угол кнопки (также как и сама граница кнопки) автоматически выравнивается по шаблону сетки на форме. Это действие, называемое привязка к сетке (snap to grid), поможет вам выровнять размещенные на форме элементы управления и текст. Вы можете включать и отключать привязку к сетке, настраивать шаг сетки или скрывать ее, изменяя установки в диалоговом окне Option (Параметры) Редактора VB. Выберите Tools/Options (Сервис/Параметры) и щелкните по вкладке General (общие), чтобы вывести Form Grid Settings (Параметры сетки в форме). Выберите или сбросьте необходимые опции.
Все элементы управления формы должны иметь уникальные имена. Эти имена следует использовать при ссылках на элемент управления в своей программе. Всякий раз, когда вы добавляете к форме новый элемент управления, VBA присваивает ему имя по умолчанию, состоящее из имени типа элемента и номера. VBA обеспечивает уникальность имени включением в имя элемента управления числа. Число в имени больше, чем число любого другого подобного элемента управления. Если кнопка, которую вы добавили в начале этого раздела, является первой кнопкой, она получит имя CommandButton1. Следующая добавленная вами кнопка будет CommandButton2 и так далее. Если после этого вы добавите поле, оно получит имя TextBox1.
Задание 4. Создайте форму, выводящую сообщение текущей даты и время.
Для этого:
выберите команду Insert/UserForm (Вставка/UserForm); * убедитесь, что форма активна, щелкнув по ней;
щелкните на пиктограмме с буквой а в панели элементов управления;
• поместите указатель мыши в форму ближе к левому верхнему краю и, нажав левую кнопку мыши, перетащите указатель вправо вниз, чтобы появившийся при этом прямоугольник мог вместить нужное сообщение (рис.28);