// Главное окно.
public class MainWindow: Form {}
// Объект приложения.
public static class Program {
static void Main(string[] args) {
// He забудьте о 'using' для System.Windows.Forms!
Application.Run(new MainWindow);
}
}
}
В результате вы обеспечите поддержку одного из главных правил объектно-ориентированного программирования –
Исходный код. Проект MyFirstWindow размещён в подкаталоге, соответствующем главе 19.
Роль класса Application
Класс Application определяет множество статических членов, позволяющих управлять поведением различных низкоуровневых элементов приложения Windows Forms. Класс Application определяет набор событий, позволяющих реагировать, например, на завершение работы приложения или переход в состояние ожидания.
Кроме метода Run, этот класс предлагает и другие методы, о которых вам следует знать.
• DoEvents. Обеспечивает для приложения возможность в ходе выполнения операций, требующих много времени, обрабатывать сообщения, находящихся в это время в очереди сообщений.
• Exit. Завершает выполнение Windows-приложения и выгружает из памяти домен этого приложения.
• EnableVisualStyles. Настраивает приложение на поддержку визуальных стилей Windows XP. При активизации поддержки ХР-стилей указанный метод должен вызываться до загрузки главного окна с помощью Application.Run.
Кроме того, класс Application определяет ряд свойств, многие из которых доступны только для чтения. При анализе табл. 19.2 обратите внимание на то, что большинство свойств представляет характеристики "уровня приложения" (имя компании, номер версии и т.д.). С учетом ваших знаний об атрибутах уровня компоновочного блока (см. главу 12) многие из этих свойств должны быть для вас понятны.
Таблица 19.2. Основные свойства типа Application
Свойство | Описание |
---|---|
CompanyName | Содержит значение атрибута [AssemblyCompany] уровня компоновочного блока |
ExecutablePath | Содержит значение пути для файла, выполняемого в данный момент |
ProductName | Содержит значение атрибута [AssemblyProduct] уровня компоновочного блока |
ProductVersion | Содержит значение атрибута [AssemblyVersion] уровня компоновочного блока |
StartupPath | Содержит значение пути для выполняемого файла, запустившего данное приложение |
Наконец, класс Application определяет набор статических событий, и вот некоторые из них.
• ApplicationExit генерируется непосредственно перед тем, как данное приложение завершает работу.
• Idle генерируется тогда, когда цикл сообщений приложения заканчивает обработку текущего пакета сообщений и готовится к переходу в состояние ожидания (ввиду отсутствия сообщений для обработки).
• ThreadExit генерируется непосредственно перед тем, как завершает работу поток данного приложения.
Возможности класса Application
Для иллюстраций некоторых функциональных возможностей класса Application давайте расширим тип MainWindow, чтобы он мог выполнять следующее.
• Использовать значения некоторых атрибутов уровня компоновочного блока.
• Обрабатывать статическое событие ApplicationExit…
Первой нашей задачей является использование свойств класса Application для отображения атрибутов уровня компоновочного блока. Для начала добавьте в свой файл MainWindow.cs следующие атрибуты (обратите внимание на то, что здесь используется пространство имен System.Reflection).
using System;
using System.Windows.Forms;
using System.Reflection;
// Несколько атрибутов для данного компоновочного блока.
[аssembly:AssemblyCompany("Intertech Training")] [assembly: AssemblyProduct("Более совершенное окно")"] [assembly:AssemblyVersion("1.1.0.0")]
namespace MyWindowsApp {
…
}