Visual FoxPro является языком, управляемым по событиям. Событие представляет собой некоторое действие, которое активизирует стандартную реакцию объекта. В качестве события в Visual FoxPro могут рассматриваться нажатие кнопки мыши, выбор пункта меню или открытие таблицы.
Аналогично свойствам, наследуются события и методы базового класса, на основе которого создается объект. Список методов, определенных для объекта, можно просмотреть на вкладке Methods (Методы) окна свойств объекта (рис. 19.4).
Для каждого события определен соответствующий ему метод, который выполняется при возникновении данного события. Например, метод click (Нажатие) выполняется при нажатии кнопки мыши.
Список доступных методов обработки событий определяется базовым классом. Именно эти методы обеспечивают обработку всех действий пользователя (нажатие клавиш, управление мышью). Visual FoxPro предоставляет возможность модифицировать действия, выполняемые при обработке события данного объекта. Для редактирования метода установите курсор на этот метод в списке методов и дважды щелкните мышью. На экране откроется окно редактирования метода (рис. 19.5), в котором вы можете написать программу обработки события. Например, для кнопки формы вы можете определить программу перемещения по записям.
Для каждого события объекта выполняется определенное в базовом классе действие. В некоторых случаях вам может понадобиться запретить выполнение этих действий. Для этого используйте ключевое слово NODEFAULT в начале метода, связанного с этим событием.
Рис. 19.4. Вкладка Methods окна свойств объекта
Рис. 19.5. Окно редактирования методов
Замечание
Методы, выполняющиеся при наступлении событий, в окне свойств объекта в списке методов в дополнение к имени содержат слово Event (Событие).
Команда MOUSE позволяет вам программным путем имитировать события click (Нажатие), Doubleclick (Двойное нажатие), MouseMove (Перемещение мыши) и DragDrop (Перенести и оставить). Остальные события не могут имитироваться программно, но вы можете вызвать методы, связанные с этими событиями.
Кроме методов, связанных с событиями, объект может содержать и дополнительные методы, которые выполняются только при их вызове. Например, для формы могут быть определены методы перехода на следующую запись, удаления записи и т. п. Эти методы могут наследоваться из базового класса, но вы можете создавать новые методы и для отдельных объектов.
Для создания нового метода в меню Form (Форма) выберите команду New Method (Новый метод) и в открывшемся диалоговом окне New Method (Новый метод) (рис. 19.6) определите имя и краткое описание метода. Созданный вами метод добавляется в список методов объекта, и вы можете открыть окно редактирования метода для ввода программного кода.
Для выполнения метода необходимо не только указать имя метода, но и объект, к которому данный метод будет применяться. Имя объекта и имя метода разделяются точкой. Например, для выполнения метода CaicSum формы Sales необходимо выполнить команду Sales.CalcSumO.
Рис. 19.6. Диалоговое окно New Method
В табл. 19.5 и табл. 19.6 приведены события и методы, которые распознаются и используются Visual FoxPro, и их краткое описание.
Таблица. 19.5. События, распознаваемые Visual FoxPro
Событие | Возникает |
Activate | При активизации объектов FormSet (Набор форм), Form (Форма), Page (Вкладка формы) или при отображении объекта Toolbar (Панель управления) |
AfterBuilld | При перестроении проекта или приложения, а также при создании динамической библиотеки (dll) или выполняемого файла (ехе) на основе проекта |
AfterCloseTables | После закрытия таблиц или представлений данных |
AfterDock | После того, как фиксируется панель инструментов |
AfterRowColChange | При переходе в другую строку или другой столбец объекта Grid (Таблица) |
Bef oreDock | Имеет место перед фиксацией объекта ToolBar (Панель управления) |
BeforeOpenTables | Перед открытием таблиц и представлений, связанных со средой данных формы, набора срорм или отчета |
BeforeRowCoIChange | Перед тем, как пользователь изменяет активную строку или столбец объекта Grid (Таблица) |
Click | При нажатии и отпускании левой кнопки мыши |
CoramandTargetExec | При активизации программой-контейнером приложения типа Active Document (Активный документ) |
CoinmandTarget Query | При изменении программой-контейнером пользовательского интерфейса |
ContainerRelease | При закрытии программой-контейнером приложения типа Active Document (Активный документ) |
DblClick | При двойном нажатии и отпускании левой кнопки мыши |
Deactivate | Когда деакти визируется объект типа "форма" |
Deleted | Когда пользователь удаляет пометку записи на удаление или когда выдается команда DELETE |
Destroy | Когда освобождается объект |
DownClick | При нажатии кнопки со стрелкой, направленной вниз на объектах типа ComboBox (Раскрывающийся список), ListBox (Список) и Spinner (Счетчик) |
DragDrop | После завершения операции "перенести-и-оставить" |
DragOver | Когда элемент управления, переносимый с помощью мыши, накрывает объект назначения |
DropDown | В момент, когда после нажатия кнопки со стрелкой в элементе управления ComboBox (Раскрывающийся список) должен появиться список |
Error | При возникновении ошибки |
ErrorMessage | Используется для определения сообщения об ошибке, когда событие Valid (Корректный) возвращает значение False (Ложь) |
GotFocus | Когда объект получает фокус в результате действий пользователя или выполнения программного кода |
HideDoc | При переходе из активного документа |
Init | При создании объекта, когда объект еще не выведен на экран |
Interactive Change | При изменении значения элемента управления с помощью клавиатуры или мыши |
KeyPress | При нажатии и отпускании клавиши |
Load | Имеет место непосредственно перед созданием объекта |
LostFocus | Когда объект теряет фокус |
Message | Отображает сообщение в строке состояния, когда объект получает управление |
MiddleClick | При нажатии средней кнопки мыши (для трехкнопочной мыши) |
MouseDown | При нажатии кнопки мыши |
MouseMove | При перемещении указателя мыши по объекту |
MouseUp | При отпускании кнопки мыши |
MouseWheel | При вращении колесика мыши, если в мыши оно есть |
Moved | При перемещении объекта на новое место или когда значения свойства Тор (Верхняя позиция) или Left (Левая позиция) объекта-контейнера изменяются программным способом |
OLECompleteDrag | Когда данные помещены на новое место или отменена операция "перенести-и-оставить" |
OLEDragOver | Возникает в том случае, если свойство OLEDropMode имеет значение 1 и данные перенесены от источника к приемнику |
OLEGiveFeedBack | После каждого события OLEDragOver |
OLESetData | Возникает у источника данных при выполнении метода GetData, если нет данных в нужном формате |
OLEStartDrag | В начале переноса данных с помощью механизма "перенести-и-оставить" |
Paint | При перерисовывании формы или панели инструментов |
ProgrammaticChange | При изменении в коде значения элемента управления |
QueryAddFile | Перед добавлением файла в проект |
QueryModifyFile | Перед изменением файла в проекте |
QueryRemoveFile | Перед удалением файла из проекта |
QueryRunFile | Перед выполнением файла или предварительным просмотром отчета или почтовой этикетки |
QueryUnload | Перед выгрузкой объекта Form (Форма) |
RangeHigh | Возвращает наибольшее значение счетчика или число элементов списка и имеет место, когда элемент управления Spinner (Счетчик) или TextBox (Поле ввода) теряет фокус и когда элемент управления comboBox {Раскрывающийся список) или ListBox (Список) получает фокус |
RangeLow | Возвращает наименьшее значение счетчика или значение первого элемента списка и имеет место, когда элемент управления Spinner (Счетчик) или TextBox (Поле ввода) теряет фокус или когда элемент управления СошЬоВох (Раскрывающийся список) или ListBox (Список) получает фокус |
ReadActivate | При активизации новой формы в наборе форм |
ReadDeactivate | При деактивизации формы в наборе форм |
ReadShow | Когда выдана команда SHOW GETS в активном объекте FormSet (Набор форм) активизируется объект FormSet (Набор форм) |
ReadValid | Имеет место после деактивизации объекта FormSet (Группа форм) |
ReadWhen | Имеет место после загрузки объекта FormSet (Группа форм) |
Resize | При изменении размеров объекта |
RightClick | При нажатии и отпускании правой кнопки мыши |
Run | Имеет место, когда Active Document (Активный документ) готов к выполнению кода пользователя |
Scrolled | При прокрутке данных в объекте управления Grid (Таблица) |
ShowDoc | При переходе в активный документ |
Timer | Когда истекает интервал времени, заданный свойством Interval (Интервал) |
UIEnable | Имеет место для всех объектов, содержащихся внутри объекта Page (Вкладка формы), каждый раз, когда объект Page (Вкладка формы) активизируется или деактивизируется |
UnDock | При перемещении объекта ToolBar (Панель управления) с помощью мыши |
Unload | При освобождении объекта |
UpClick | При нажатии кнопки с направленной вверх стрелкой на объектах управления типа СотЬоВох (Раскрывающийся список), ListBox (Список) и spinner (Счетчик) |
Valid | Перед тем, как элемент управления теряет фокус |
When | Перед тем, как элемент управления получает фокус |
Таблица 19.6. Методы, используемые Visual FoxPro
Метод | Описание |
ActivateCell | Активизирует ячейку в элементе управления Grid (Таблица) |
AddColumn | Добавляет объект Column (Столбец) в элемент управления Grid (Таблица) |
Add I tern | Добавляет новый элемент списка в объект СотЬоВох (Раскрывающийся список) или ListBox (Список), предоставляв при этом возможность задать индекс элемента |
AddListltem | Добавляет новый элемент списка в объект СотЬоВох (Раскрывающийся список) или ListBox (Список), давая возможность задать идентификатор элемента |
AddObject | Добавляет объект в контейнер на этапе выполнения |
AddProperty | Добавляет новое свойство в объект |
AddToSCC | Добавляет файл в проект |
Box | Рисует прямоугольник в форме |
Build | Перестраивает проект или создает приложение (арр), динамическую библиотеку (dli) или выполняемый файл (ехе) из проекта |
Checkln | Запоминает изменения, осуществленные в выбранном файле проекта |
Checkout | Выбирает файл из проекта для изменения |
Circle | Рисует окружность или эллипс в форме |
Cleanup | Очищает таблицу проекта, удаляя записи с пометкой на удаление и сжимая Memo-поля |
Clear | Очищает содержимое элемента управления СотЬоВох (Раскрывающийся список) или ListBox (Список) |
ClearData | Очищает все данные и форматы данных в объекте Dataobject (Объект данных). Доступен только в режиме выполнения программы |
CloneObj ect | Создает копию объекта со всеми его свойствами, событиями и методами |
Close | Закрывает проект и очищает объекты ProjectHook (Проект) и Project (Проект) |
CloseTables | Закрывает таблицы и представления данных, связанные со средой |
Cls | Удаляет графику и текст из формы |
DataToClip | Копирует группу записей в текстовом виде в буфер обмена Windows |
DeleteColumn | Удаляет объект Column (Столбец) из элемента управления Grid (Таблица) |
Dock | Располагает объект ToolBar (Панель управления) у границы основного окна Visual FoxPro |
DoCrad | Выполняет команду Visual FoxPro для сервера приложения Visual FoxPro |
DoScroll | Моделирует работу пользователя с полосами прокрутки в объекте Grid (Таблица) |
DoVerb | Выполняет команду для заданного OLE-объекта |
Drag | Начинает, заканчивает или отменяет операцию переноса объекта с помощью мыши |
Draw | Перерисовывает объект формы |
Eval | Вычисляет выражение и возвращает результат |
GetData | Заполняет данные из объекта DataObject (Объект данных). Доступен только в режиме выполнения программы |
Get Format | Возвращает True (Истина), если заданный формат доступен для объекта DataObject (Объект данных). Доступен только в режиме выполнения программы |
GetLatestVersion | Определяет последнюю версию файла проекта и копирует файл с пометкой только для чтения на диск |
GoBack | Возникает при возврате назад в списке хронологии программы-контейнера |
GoForward | Возникает при переходе вперед в списке хронологии программы-контейнера |
Help | Открывает окно справки |
Hide | Скрывает объект Form (Форма), FormSet (Набор форм) или ToolBar (Панель управления), присваивая его свойству visible значение False (Ложь) |
IndexToItemID | Возвращает индекс элемента с указанным идентификатором для объектов типа ComboBox (Раскрывающийся список) и ListBox (Список) |
Item | Возвращает объектную ссылку на определенный файл, проект или сервер в файловом, проектном, серверном сборнике |
ItemlDToIndex | Возвращает индекс позиции элемента в списке данного элемента управления для объектов типа ComboBox (Раскрывающийся список) и ListBox (Список) |
Line | Рисует линию в форме |
Modify | Открывает файл проекта для редактирования в соответствующем конструкторе или редакторе |
Move | Перемещает объект |
NavigateTo | Active Document (Активный документ) перемещается в контейнере в определенное место |
OLEDrag | Начинает операцию "леренести-и-оставить" |
Point | Возвращает цвет в модели RGB (красный-зеленый-синий) для заданной точки формы |
Выдает в объекте Form (Форма) символьную строку, которую нужно напечатать | |
PSet | Устанавливает для точки формы или основного окна Visual FoxPro основной цвет символов |
Quit | Завершает работу Visual FoxPro |
ReadExpression | Возвращает выражение, введенное в качестве значения свойства в окне свойств |
ReadMethod | Возвращает текст заданного метода |
Refresh | Перерисовывает объект Form (Форма) или элемент управления, обновляя все значения |
Release | Освобождает объект FormSet (Набор форм) или Form (Форма) из памяти |
Remove | Удаляет файл из сборника файла и проекта |
RemoveFromSCC | Удаляет файл из проекта |
Remove I tern | Удаляет элемент из списка элемента управления типа ComboBox (Раскрывающийся список) или ListBox (Список) |
RemoveListltem | Удаляет элемент из списка элемента управления типа ComboBox (Раскрывающийся список) или ListBox (Список) |
RemoveObject | Удаляет заданный объект из объекта-контейнера на этапе выполнения |
Requery | Повторно опрашивает источник строк, к которому привязан элемент управления типа ListBox (Список) или ComboBox (Раскрывающийся список) |
RequestData | Создает массив, содержащий данные из таблицы Visual FoxPro |
Reset | Сбрасывает элемент управления Timer (Таймер) в нулевое состояние |
ResetToDefault | Восстанавливает принятые по умолчанию в Visual FoxPro значения свойств, событий или методов |
Run | Запускает файл проекта на выполнение или предварительный просмотр |
SaveAs | Сохраняет объект в виде файла с расширением SCX |
SaveAsClass | Сохраняет экземпляр объекта в качестве определения класса в библиотеке классов |
Set All | Присваивает установку некоторого свойства всем элементам управления данного объекта Container (Контейнер) или определенному классу таких элементов управления |
SetData | Помещает данные в DataObject (Объект данных). Доступен в режиме выполнения программы |
SetFocus | Устанавливает фокус в элементе управления |
SetFormat | Помещает формат данных в DataObject (Объект данных). Доступен в режиме выполнения программы |
SetMain | Делает текущий файл главным в проекте |
SetVar | Создает переменную и хранит ее значение |
SetViewPort | Определяет значения ViewPortLeft и viewPortTop для формы |
Show | Отображает объект Form (Форма) и определяет его тип — модальный или немодальный |
ShowWhatsThis | Отображает тему справочной системы, заданную свойством WhatsThisHelpID |
TextHeight | Возвращает высоту текстовой строки, используя единицу измерения, устанавливаемую свойством ScaleMode объекта Form (Форма) |
TextWidth | Возвращает ширину текстовой строки, используя единицу измерения, устанавливаемую свойством ScaleMode объекта Form (Форма) |
UndoCheckOut | Отменяет все изменения, осуществленные в выбранном файле, и оставляет его в проекте в неизмененном виде |
WhatsThisMode | Отображает курсор мыши в виде вопросительного знака и устанавливает режим whats This Help (Справка типа "что это?") |
WriteExpression | Записывает символьную строку в таблицу свойств |
WriteMethod | Записывает указанный текст в заданный метод |
ZOrder | Помещает заданный объект Form (Форма) или элемент управления в заданную позицию данного объекта по отношению к другим объектам |
51. Елементи управління. Оформлення форми.
52. Механізм розширення форм та елементів управління.
53. Модулі форм. Робота з формами та елементами управління мовними засобами.
54. Об’єктний та табличний способи доступу до даних.
55. Таблична модель БД.
56. Виконання запита та принципи обробки результату запита.
57. Принципи роботи з конструктором запитів.
58. Конструктор вихідних форм. Консоль звітів.
59. Інтелектуальні механізми підготовки звітності.
60. Виключні ситуації.