Связь и интернет Архив Программирование
   
Сделать стартовойСделать закладку            
   ПОИСК  
   
Главная / Pascal и Delphi / Иллюстрированный самоучитель по Delphi 6 / Часть III. Компоненты и программы / Глобальные объекты и настройка программ /
8  Perl
8  PHP
8  JavaScript
8  HTML
8  DHTML
8  XML
8  CSS
8  C / C++
8  Pascal и Delphi
8  Турбо Ассемблер
8  MySQL
8  CASE-технологии
8  Алгоритмы
8  Python
8  Обратная связь
8  Гостевая книга
Новости о мире


Application - Программирование от RIN.RU
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 Message: TMessage): Boolean of object procedure HookMainWindow(Hook: TWindowHook); Регистрирует функцию для перехвата сообщений Windows
function MessageBox(Text, Caption: PChar; Flags: Longint): Integer; Создает и показывает диалоговое
окно с текстом и кнопками: Text - сообщение в окне; Caption - заголовок окна. Назначение Flags и возвращаемое значение см. ниже
procedure Minimize; Минимизирует программу до пиктограммы
procedure NormalizeTopMosts; Приостанавливает действие стиля fsTopMost для всех окон программы
procedure NormalizeAllTopMosts;Распространяет действие NormalizeTopMosts на главное окно программы
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Пользователь должен закрыть это окно перед тем, как продолжить работу с окном, его породившим; однако он может переходить в другие окна и работать с ними. Этот признак берется по умолчанию, если не определены ни bSystemModal, ни inbTaskModal
mbDefButton1Кнопкой по умолчанию является
кнопка 1
mbDefButton2Кнопкой по умолчанию является кнопка 2
mbDefButton3Кнопкой по умолчанию является кнопка 3
mbDefButton4Кнопкой по умолчанию является кнопка 4
mbHelpВставляется кнопка Help
mbIconAftenskВ окно вставляется пиктограмма в виде строчной буквы i в кружке
mblconExclcimationВ окно вставляется пиктограмма в виде знака восклицания
mbIconHandВ окно вставляется пиктограмма в виде знака
mblconlnformationСтоп То же,что и mbIconAsterisk
mb IconQuestionВ окно вставляется пиктограмма
в виде знака вопроса
mbIconStopTo же, ЧТО И 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 Была нажата кнопка Abort
idCancelБыла нажата кнопка cancel
idlgnore Была нажата кнопка ignore
idOk Была нажата кнопка ok
idNo Была нажата кнопка No
idRetryБыла нажата кнопка Retry
idYes Была нажата кнопка 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: TShowHintEvent; Возникает при необходимости отобразить окно с ярлычком оперативной подсказки



Событие 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 - время показа ярлычка в миллисекундах.



 8  Комментарии к статье  8 8  Обсудить в чате

 
  
  
    Copyright ©  RIN 2003 - 2004      * Обратная связь
Внедрение 1 с документооборот