Application.Startup Olay

Tanım

nesnesinin Run() yöntemi Application çağrıldığında gerçekleşir.

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

Olay Türü

Örnekler

Aşağıdaki örnekte, tek başına bir uygulamadan komut satırı seçeneklerinin nasıl alınıp işlendiği gösterilmektedir. /StartMinimized komut satırı parametresi sağlandıysa, uygulama ana pencereyi simge durumuna küçültülmüş durumda açar.

<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 tarayıcı uygulamaları (XBAP'ler), ClickOnce dağıtımıyla başlatıldıkları için komut satırı bağımsız değişkenlerini alamaz ve işleyemez (bkz. WPF Uygulaması Dağıtma (WPF)). Ancak, bunları başlatmak için kullanılan URL'lerden sorgu dizesi parametrelerini alabilir ve işleyebilirler.

Açıklamalar

Tipik bir Windows Presentation Foundation uygulaması başlatıldığında çeşitli başlatma görevleri gerçekleştirebilir, örneğin:

  • Komut satırı parametreleri işleniyor.

  • Ana pencere açılıyor.

  • Uygulama kapsamı kaynaklarını başlatma.

  • Uygulama kapsamı özelliklerini başlatma.

Ana pencereyi ve uygulama kapsamı kaynaklarını bildirimli olarak belirtmek için sırasıyla XAML (StartupUri ve Resources) kullanabilirsiniz. Ancak bazen uygulamanızın kaynakları veya ana penceresi yalnızca çalışma zamanında program aracılığıyla belirlenebilir. Ayrıca, uygulama kapsamı özellikleri ve komut satırı parametreleri yalnızca program aracılığıyla kullanılabilir. Programlı başlatma, aşağıdakiler Startup de dahil olmak üzere olayı işleyerek gerçekleştirilebilir:

  • Olay işleyicisine Startup geçirilen sınıfın özelliğinden ArgsStartupEventArgs kullanılabilen komut satırı parametrelerini alma ve işleme.

  • özelliğini kullanarak Resources uygulama kapsamı kaynaklarını başlatın.

  • özelliğini kullanarak Properties uygulama kapsamı özelliklerini başlatın.

  • Bir (veya daha fazla) pencere örneği oluşturma ve gösterme.

Not

Komut satırı parametreleri, nesnesinin statik GetCommandLineArgs yöntemi Environment çağrılarak da elde edilebilir. Ancak, GetCommandLineArgs yürütmek için tam güven gerektirir.

XAML kullanarak ayarlarsanızStartupUri, oluşturulan ana pencere olay işleninceye kadar nesnenin Application özelliğinden veya Windows özelliğinden MainWindowStartup kullanılamaz. Başlatma sırasında ana pencereye erişmeniz gerekiyorsa, olay işleyicinizden Startup el ile yeni bir pencere nesnesi oluşturmanız gerekir.

Not

Uygulamanız bir kimlik bilgisi ilkesi belirtmek için kullanıyorsa CredentialPolicy oluşturulduktan sonra Startup ayarlamanız CredentialPolicy gerekir; aksi takdirde WPF, olay oluşturulduktan hemen sonra bunu varsayılan iç ilkeye Startup ayarlar.

Olay işleyicisine Startup geçirilen komut satırı bağımsız değişkenleri, XAML tarayıcı uygulamasına (XBAP) geçirilen URL sorgu dizesi parametreleriyle aynı değildir.

Şunlara uygulanır

Ayrıca bkz.