20.1. APPLICATION
Объект Application относится к классу TAppiication и инкапсулирует важнейшие свойства и методы программы как таковой. Он создается автоматически и доступен любой программе. Объект не помещен в палитру компонентов, поэтому его свойства недоступны на этапе конструирования, но становятся доступны при прогоне программы[ Некоторые свойства программы (в том числе ее пиктограмма, сведения о версии и используемом языке) могут устанавливаться с помощью менеджера проекта (опция project | Options и страница Application). ].
Application является посредником между программой и операционной системой. В частности, с его помощью осуществляется диспетчеризация сообщений Windows, реализуется контекстно-чувствительная справочная служба, он обрабатывает клавиши-акселераторы, исключительные ситуации и т. д.
Ниже описываются некоторые свойства Application для приложения Windows (для приложения Linux объект Application несколько отличается). Опущенные свойства предназначены в основном для прямого обращения к API-функциям Windows.
property Active: Boolean; |
Содержит True, если любое окно программы имеет фокус ввода |
property BiDiMode: TBiDiMode; |
Определяет свойство bidiMode (см. п. 17.12) для программы в целом |
property CurrentHelpFile: Strings; |
Определяет имя текущего справочного файла |
property ExeName: Strings; |
Содержит полное имя (с маршрутом доступа) исполняемого файла программы |
property HelpFile: String; |
Определяет имя файла справочной службы |
property Hint: String; |
Содержит длинную часть оперативной подсказки |
property HintColor: TColor;
|
Определяет цвет фона ярлычка оперативной подсказки |
property HintHidePause: Integers;
|
Определяет паузу (в миллисекундах) от момента появления ярлычка до его исчезновения |
property HintPause: Integer;
|
Определяет паузу (в миллисекундах) от момента остановки указателя мыши до появления ярлычка |
property HintShortPause: Integers; |
Определяет паузу (в миллисекундах) появления ярлычка при переходе с одного компонента на другой |
property Icon: TIcon; |
Определяет пиктограмму программы |
property MainForm: TForm; |
Определяет главное окно программы |
property ShowHint: Boolean; |
Разрешает/запрещает показ ярлычков для всех окон программы |
property ShowMainForm: Boolean;
|
Разрешает/запрещает показ главного окна в момент старта программы |
property Terminated: Boolean; |
Содержит True, если программа должна прекратить работу. Используется в приложениях с интенсивным счетом для контроля необходимости прекращения дальнейшей работы |
property Title: String; |
Определяет текст под пиктограммой минимизированной программы |
property UpdateFormatSettings: Boolean; |
Если содержит True, программа автоматически будет учитывать новые форматные установки Windows (например, новый разделитель целой и дробной частей числа) при их изменении в момент работы программы. |
property UpdateMetricSet;Boolean; |
Если содержит True, программа автоматически будет учитывать новые метрические установки Windows (например, новый системный шрифт) при их изменении в момент работы программы |
Методы Application:
procedure BringToFront; |
Помещает окно, которое было активным в последний раз, поверх остальных окон |
procedure HandleException(Sender: TObject) ; |
Осуществляет умалчиваемую обработку исключительных ситуаций. Используется при разработке новых компонентов |
function HelpCommand(Command: Word; Data: Longint): Boolean; |
Посылает справочной службе команду Command и параметр Data |
procedure HandleMessage; |
Приостанавливает работу программы до тех пор, пока не будут обработаны все сообщения, после чего создает событие Onidle |
procedure CreateForm(FormClass: TFormClass; var Reference) ; |
Создает объект-окно: вызывает конструктор класса TFormClass и связывает его значение с переменной Reference |
procedure CancelHint; |
Запрещает показ ярлычков оперативной подсказки |
function HelpContext(Context: THelpContext): Boolean; |
Вызывает раздел context справочной службы и возвращает True, если такой раздел существует |
function HelpJump(const JumpID: String): Boolean; |
Вызывает раздел справочной службы по его имени JumpID и возвращает True, если такой раздел существует |
procedure Hide Hint; |
Убирает текущий ярлычок оперативной подсказки |
TWindowHook = function(var Mes sage: TMessage): Boolean of object procedure HookMainWindow(Hook: TWindowHook); |
Регистрирует функцию для перехвата сообщений Windows |
function MessageBox(Text, Cap tion: PChar; Flags: Longint): Integer; |
Создает и показывает диалоговое окно с текстом и кнопками: Text - сообщение в окне; Caption - заголовок окна. Назначение Flags и возвращаемое значение см. ниже |
procedure Minimize; |
Минимизирует программу до пиктограммы |
procedure NormalizeTopMosts; |
Приостанавливает действие стиля fsTopMost для всех окон программы |
procedure NormalizeAllTopMosts;
|
Распространяет действие NormalizeTop Mosts на главное окно программы |
procedure ProcessMessages;
|
То же, что HandleMessage, но не создает событие OnIdle |
procedure Restore;
|
Восстанавливает первоначальные размеры всех окон программы до ее минимизации |
procedure RestoreTopMosts;
|
Восстанавливает действие стиля fsTopMost для всех окон программы |
procedure Run; |
Запускает цикл получения и обработки Windows-сообщений |
procedure ShowException(EiException) ; |
Реализует умалчиваемую обработку исключительных ситуаций |
procedure Terminate; |
Завершает работу программы |
procedure UnhookMainWindow(Hook:TWindowHook); |
Удаляет перехватчик сообщений, ранее установленный методом ookMainWindow. Параметр Hook - имя той же функции перехвата, что и при обращении к HookMainWindow |
С помощью методов HandleException и ProcessMessages программа может временно приостановить свою работу до тех пор, пока не будут обработаны все предназначенные ей сообщения Windows. Это бывает необходимо для обновления видимых компонентов в процессе отображения длительного по времени цикла работы. Если, например, программа изменит текст метки или состояние компонента progressBar, сообщение об этом поступит в очередь сообщений и останется в ней, пока не закончится текущая работа. Вызов HandleException или ProcessMessages в этом случае позволит метке или ProgressBar действительно обновить свой вид и отобразить новую фазу процесса. Разница между методами HandieException И ProcessMessages состоит в том, что первый после очистки очереди сообщений вызывает обработчик фонового события OnIdie, а второй не делает этого. Назначение события onidie см. после описания событий объекта Application.
С помощью метода HookMainWindow можно зарегистрировать функцию Hook, которая будет получать все адресованные программе сообщения windows. По моим наблюдениям, эта функция получает
Сообщение Message параллельно c главной оконной функцией Application. ProcessMessage или после нее, т. к. ни изменение сообщения, ни возвращаемый функцией Hook результат никак не влияют на поведение программы. Как следует из встроенной справочной службы, в качестве функции Hook должна регистрироваться оконная функция диалогового окна, созданного не с помощью Delphi. Если вы решите использовать HookMainWindow для наблюдения за посылаемыми программе сообщениями, не забудьте перед завершением программы отключить регистрацию Hook методом unHookMainwin-dow, в противном случае завершение работы программы будет сопровождаться сообщением об ошибке. Для целей перехвата сообщений и их возможного изменения следует использовать обработчик Application. OnMessage, который вызывается из оконной функции Программы Application. ProcessMessage до вызова методов Trans-lateMessage И DispatchMessage, реализующих стандартную обработку сообщений. В Delphi 5 (и 6) появилось дополнительное удобное средство перехвата сообщений - компонент TApplicationEvents (см. п. 18.2.14).
Функция MessageBox дает удобное средство вывода на экран небольшого -сообщения. Параметр Flags может быть произвольной комбинацией следующих значений:
mbA bort Retry Ignore |
В окно вставляются кнопки Abort, Retry, Ignore |
mbApplModal |
Пользователь должен закрыть это окно перед тем, как продолжить работу с окном, его породившим; однако он может переходить в другие окна и работать с ними. Этот признак берется по умолчанию, если не определены ни mbSystemModal, ни inbTaskModal |
mbDefButton1 |
Кнопкой по умолчанию является кнопка 1 |
mbDefButton2 |
Кнопкой по умолчанию является кнопка 2 |
mbDefButton3 |
Кнопкой по умолчанию является кнопка 3 |
mbDefButton4 |
Кнопкой по умолчанию является кнопка 4 |
mbHelp |
Вставляется кнопка Help |
mbIconAftensk |
В окно вставляется пиктограмма в виде строчной буквы i в кружке |
mblconExclcimation |
В окно вставляется пиктограмма в виде знака восклицания |
mbIconHand |
В окно вставляется пиктограмма в виде знака |
mblconlnformation |
Стоп То же,что и mbIconAsterisk |
mb IconQuestion |
В окно вставляется пиктограмма в виде знака вопроса |
mbIconStop |
To же, ЧТО И mbIconHand |
mb0k |
В окно вставляется кнопка Ok |
mbOkCancel |
В окно вставляются кнопки Ok и Cancel |
mbRetry Cancel |
В окно вставляются кнопки Retry и Cancel |
mbSy stem Modal |
Все программы приостанавливают свою работу, пока пользователь не закроет это окно |
mbTaskModal |
Приостанавливается работа во всех окнах данной программы до тех пор, пока пользователь не закроет это окно |
mbYesNo mb Yes No Cancel |
В окно вставляются кнопки Yes, ыо В окно вставляются кнопки Yes, No, Cancel |
Например:
Application.MessageBox('Текст в окне', 'Заголовок окна', mb_IconQuestion+mb_YesNo) ;
Функция MessageBox возвращает такие значения:
idAbort idCancel idlgnore idOk |
Была нажата кнопка Abort Была нажата кнопка cancel Была нажата кнопка ignore Была нажата кнопка ok |
idNo idRetry idYes |
Была нажата кнопка No Была нажата кнопка Retry Была нажата кнопка Yes |
Примечание
Альтернативой MessageBox является глобальная функция MessageDIg, объявленная в модуле Dialogs:
function MessageDIg(const.Msg: String;AType: TMsgDIgType; AButtons: TMsgDIgButtons;HelpCtx:- Longint): Word;
Эта? функция имеет шараметр; HelpCtx, с помощью которого создаваемое ею окно можно легко связать с Help-службой. В отличие от MessageBox заголовок окна MessageDIg не может изменяться программистом - он опредёляётся типом окна, задаваемым параметром AType (возможные значения: mtWarning - пиктограмма в виде знака: Восклицания, заголовок Warning; mtError - пиктограмма в виде знака Стоп заголовок Error; mtlnformation:-- пиктограмма в виде:
Буквы i, заголовок information; mtConfirmation - пиктограмма в виде знака вопроса, заголовок Confirm; mtCustom - нет пиктограммы, заголовок содержит имя исполняемого файла программы) Набор кнопок задаётся в виде конструктора множества и может включать: mbYes-—кнопка Хез (результат, возвращаемый функцией при нажатии на эту кнопку - nu-Yes); mbNo -кнопка. No (mrNo); mbOk - кнопка OK (mrOk); mbCancel - кнопка ; Cancel (mrCancel);
mbHelp -кнопка Help (после нажатия на эту кнопку окно не закрывается); mbAbort - кнопка Abort (mrAbort); mbIgnore- кнопка Ignore (mrlgnore); mbAll —кнопка All .(mbА11). В отличие от MessageBox раскрытие окна MessageDIg не сопровождается системным звуком.
Для объекта Application определены следующие события:
property OnActivate: TNotifyEvent; |
Возникает, когда программа получает фокус ввода |
property OnDeactivate: TNotifyEvent; |
Возникает, когда программа теряет фокус ввода |
TExceptionEvent = procedure (Sender: TObject; E: Exception) of object; property OnException: TException Event; |
Обработчик этого события реализует умалчиваемую обработку исключительных ситуаций
|
THelpEvent = function (Command: Word; Data: Longint; var CallHelp: Boolean): Boolean of ob ject; property OnHeip: THelpEvent; |
Возникает при каждом обращении к справочной службе
|
property OnHint: TNotifyEvent;
|
Возникает при необходимости отобразить длинную часть оперативной подсказки |
TIdleEvent = procedure (Sender: TObject; var Done: Boolean) of object; property Onldle: TIdleEvent; |
Обработчик этого события реализует фоновую работу (см. ниже пояснения) |
TMessageEvent = procedure (var Msg: TMsg; var Handled: Boolean) of object; property OnMessage: TMessageEvent; |
Возникает при получении программой сообщения Windows. С помощью обработчика этого события можно обработать не сколько или все сообщения до того, как их получит активная форма |
property OnMinimize: TNotifyEvent; |
Возникает при минимизации программы
|
property OnRestore: TNotifyEvent;
|
Возникает при восстановлении программой первоначальных размеров после ее минимизации |
property OnShowHint: TShowHintE vent; |
Возникает при необходимости отобразить окно с ярлычком оперативной подсказки |
Событие OnIdie возникает всякий раз, когда программа обнаруживает, что ее очередь сообщений пуста. Обработчик этого события может незаметно для пользователя выполнить вспомогательную работу, например, проверить орфографическую правильность только что введенного слова или собрать и обработать статистические данные. Важно помнить, что выполняемая в обработчике работа не может занимать много времени, иначе программа перестанет реагировать на запросы пользователя. Если фоновая работа отнимает много времени, ее следует разбить на сравнительно небольшие фрагменты или периодически вызывать в ней метод HandieMessage. Обработчик в параметре Done сообщает о необходимости продолжить фоновую работу (Done = False) или 0 ее завершении (Done = True). В первом случае программа просмотрит очередь сообщений и после ее очистки вернет управление обработчику OnIdie. Во втором случае программа будет ожидать поступления новых сообщений.
Примечание
Событие Onidie введено в Delphi 1 для совместимости с Windows З.х в которой не было многопоточности; Если вы работаете с Windows 32 и вам действительно нужно сделать некоторую фоновую работу, имеет смысл поручить ее выполнение отдельному потоку команд(см.га. 14)
Для события ОnShowHint определены такие типы:
type
THintInfo = record
HintControl: TControl;
HintPos: TPoint;
HintMaxWidth: Integer;
HintColor: TColor;
CursorRect: TRect;
CursorPos: TPoint;
ReshowTimeout: Integer;
HideTimeout: Integer;
HintStr: String;
end;
TShowHintEvent =
procedure ( var HintStr: String;
var CanShow: Boolean;
var Hintlnfo: THintInfo)
of object;
В параметре HintStr обработчик получает текст, который должен содержать ярлычок, а в параметре Hintlnfo - дополнительную информацию, в том числе: HintControl - элемент, для которого выводится ярлычок; HintPos - координаты верхнего левого угла ярлычка; HintMaxWidth - максимальная ширина окна; HintColor - цвет окна; CursorRect - прямоугольник, в котором должен оставаться указатель мыши, чтобы появился ярлычок; CursorPos - текущее положение указателя мыши; ReshowTimeout - задержка в миллисекундах от момента возникновения события до появления ярлычка;
HideTimeout - время показа ярлычка в миллисекундах.