Application.Startup Application.Startup Application.Startup Application.Startup Event

Определение

Происходит при вызове метода Run() объекта Application.Occurs when the Run() method of the Application object is called.

public:
 event System::Windows::StartupEventHandler ^ Startup;
public event System.Windows.StartupEventHandler Startup;
member this.Startup : System.Windows.StartupEventHandler 
Public Custom Event Startup As StartupEventHandler 

Примеры

В следующем примере показано, как получить и обработать параметры командной строки из автономного приложения.The following example shows how to acquire and process command-line options from a standalone application. Если указан параметр командной строки /StartMinimized , приложение открывает главное окно в режиме с минимальным состоянием.If the /StartMinimized command-line parameter was provided, the application opens the main window in a minimized state.

<Application
  xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
  xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
  x:Class="SDKSample.App"
  Startup="App_Startup" />
using System.Windows;

namespace SDKSample
{
    public partial class App : Application
    {
        void App_Startup(object sender, StartupEventArgs e)
        {
            // Application is running
            // Process command line args
            bool startMinimized = false;
            for (int i = 0; i != e.Args.Length; ++i)
            {
                if (e.Args[i] == "/StartMinimized")
                {
                    startMinimized = true;
                }
            }

            // Create main application window, starting minimized if specified
            MainWindow mainWindow = new MainWindow();
            if (startMinimized)
            {
                mainWindow.WindowState = WindowState.Minimized;
            }
            mainWindow.Show();
        }
    }
}

Imports System.Windows

Namespace SDKSample
	Partial Public Class App
		Inherits Application
		Private Sub App_Startup(ByVal sender As Object, ByVal e As StartupEventArgs)
			' Application is running
			' Process command line args
			Dim startMinimized As Boolean = False
			Dim i As Integer = 0
			Do While i <> e.Args.Length
				If e.Args(i) = "/StartMinimized" Then
					startMinimized = True
				End If
				i += 1
			Loop

			' Create main application window, starting minimized if specified
			Dim mainWindow As New MainWindow()
			If startMinimized Then
				mainWindow.WindowState = WindowState.Minimized
			End If
			mainWindow.Show()
		End Sub
	End Class
End Namespace

XAML-приложения браузера (XBAP)XAML browser applications (XBAPs)не удается получить и обработать аргументы командной строки, так как они запускаются с ClickOnceClickOnce развертыванием (см. раздел развертывание WPF-приложения (WPF)).cannot retrieve and process command-line arguments because they are launched with ClickOnceClickOnce deployment (see Deploying a WPF Application (WPF)). Однако они могут извлекать и обрабатывать строковые параметры запроса из URL-адресов, которые используются для их запуска.However, they can retrieve and process query string parameters from the URLs that are used to launch them.

Комментарии

Типичное Windows Presentation Foundation приложение может выполнять разнообразные задачи инициализации при запуске, в том числе:A typical Windows Presentation Foundation application may perform a variety of initialization tasks when it starts up, including:

  • Обработка параметров командной строки.Processing command-line parameters.

  • Открытие главного окна.Opening the main window.

  • Инициализация ресурсов области приложения.Initializing application-scope resources.

  • Инициализация свойств области приложения.Initializing application-scope properties.

Можно декларативно указать основное окно и ресурсы области приложения с помощью XAMLXAML (StartupUri и Resourcesсоответственно).You can declaratively specify the main window and application-scope resources using XAMLXAML (StartupUri and Resources, respectively). Однако иногда ресурсы или главное окно приложения можно определить только программно во время выполнения.Sometimes, however, the resources or main window of your application can only be determined programmatically at run time. Кроме того, свойства области приложения и параметры командной строки можно использовать только программно.Additionally, application-scope properties and command-line parameters can only be used programmatically. Программную инициализацию можно выполнить, обрабатывая Startup событие, включая следующие:Programmatic initialization can be performed by handling the Startup event, including the following:

  • Получение и обработка параметров командной строки, доступных из Args свойства StartupEventArgs класса Startup , который передается в обработчик событий.Acquire and process command-line parameters, which are available from the Args property of the StartupEventArgs class that is passed to the Startup event handler.

  • Инициализируйте ресурсы области приложения с помощью Resources свойства.Initialize application-scope resources by using the Resources property.

  • Инициализируйте свойства области приложения с помощью Properties свойства.Initialize application-scope properties by using the Properties property.

  • Создание экземпляра и отображение одного (или нескольких) окон.Instantiate and show one (or more) windows.

Примечание

Параметры командной строки также можно получить, вызвав статический GetCommandLineArgs метод Environment объекта.Command-line parameters can also be acquired by calling the static GetCommandLineArgs method of the Environment object. Однако для выполнения требуется полное доверие. GetCommandLineArgsHowever, GetCommandLineArgs requires full trust to execute.

Если StartupUri задать параметр using XAMLXAML, то главное окно, которое создается, MainWindow не будет доступно Windows ни в свойстве, ни в свойстве Application объекта, пока Startup не будет обработано событие.If you set StartupUri using XAMLXAML, the main window that is created is not available from either the MainWindow property or the Windows property of the Application object until after the Startup event is processed. Если во время запуска требуется доступ к главному окну, необходимо вручную создать новый объект Window из Startup обработчика событий.If you need access to the main window during startup, you need to manually create a new window object from your Startup event handler.

Примечание

Если приложение CredentialPolicy использует для указания политики учетных данных, необходимо задать Startup CredentialPolicy параметр After. в противном WPFWPF случае присваивает его внутренней политике по умолчанию непосредственно после Startup возникновения события.If your application uses CredentialPolicy to specify a credential policy, you need to set CredentialPolicy after Startup is raised; otherwise, WPFWPF sets it to a default internal policy directly after the Startup event has been raised.

Аргументы командной строки, передаваемые Startup в обработчик событий, не совпадают URL-адресURL с параметрами строки запроса Приложение обозревателя XAML (XBAP)XAML browser application (XBAP), передаваемыми в.The command-line arguments that are passed to the Startup event handler are not the same as the URL-адресURL query string parameters that are passed to an Приложение обозревателя XAML (XBAP)XAML browser application (XBAP).

Применяется к

Дополнительно