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 Microsoft.VisualBasic
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.

  • Создание экземпляра и отображение один (или более) windows.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. Тем не менее GetCommandLineArgs требует полного доверия для выполнения.However, GetCommandLineArgs requires full trust to execute.

Если задать StartupUri с помощью 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. Если вам нужен доступ в главное окно во время запуска, необходимо вручную создать новый объект окна из вашей 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 задание политики учетных данных, необходимо задать CredentialPolicy после Startup вызывается; в противном случае — значение 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).

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

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