Application.Resources Application.Resources Application.Resources Application.Resources Property

Definition

Ruft eine Auflistung von Ressourcen für den Anwendungsbereich fest, z. B. Formate und Pinsel, oder legt diese fest.Gets or sets a collection of application-scope resources, such as styles and brushes.

public:
 property System::Windows::ResourceDictionary ^ Resources { System::Windows::ResourceDictionary ^ get(); void set(System::Windows::ResourceDictionary ^ value); };
[System.Windows.Markup.Ambient]
public System.Windows.ResourceDictionary Resources { get; set; }
member this.Resources : System.Windows.ResourceDictionary with get, set
Public Property Resources As ResourceDictionary

Eigenschaftswert

Ein ResourceDictionary-Objekt, das 0 (null) oder mehr Ressourcen für den Anwendungsbereich enthält.A ResourceDictionary object that contains zero or more application-scope resources.

Beispiele

In diesem Beispiel wird veranschaulicht, wie XAML mit Ressourcen im Anwendungsbereich verwendet wird, um eine konsistente visuelle Darstellung zu erstellen.This example illustrates how to use XAML together with application-scope resources to create a consistent visual appearance. Das erste Beispiel ist die Datei app. XAML; die zweite, von " MainWindow. XAML".The first example is from App.xaml; the second, from MainWindow.xaml.

<Application
    xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
    xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
    StartupUri="MainWindow.xaml"
    >

  <Application.Resources>
    <SolidColorBrush x:Key="BackgroundColor" Color="Yellow"></SolidColorBrush>
  </Application.Resources>

</Application>
<Window
    xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
    xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
    Title="ApplicationResourcesSnippetSample_XAML" 
    Height="300" 
    Width="300" 
    Background="{StaticResource BackgroundColor}"
    >
  <Grid>
    <!-- Additional XAML. -->
  </Grid>
</Window>

Im folgenden Beispiel wird gezeigt, wie eine Anwendungs Ressource im Code und in XAML (in der Datei "App. XAML C# " in einem WPF-Projekt oder in der Datei "Application. XAML" in einem Visual Basic WPF-Projekts) festgelegt wird.The following example shows how to set an application resource in code and XAML (in the App.xaml file in a C# WPF project or the Application.xaml file in a Visual Basic WPF project).

// Set an application-scope resource
Application.Current.Resources["ApplicationScopeResource"] = Brushes.White;
' Set an application-scope resource
Application.Current.Resources("ApplicationScopeResource") = Brushes.White
<Application
    xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
    xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
    x:Class="SDKSample.App"
    StartupUri="MainWindow.xaml" 
    Startup="App_Startup" 
    Exit="App_Exit">
    <Application.Resources>
        <SolidColorBrush x:Key="ApplicationScopeResource" Color="White"></SolidColorBrush>
    </Application.Resources>
</Application>

Im folgenden Beispiel wird gezeigt, wie Sie eine Anwendungs Ressource im Code erhalten.The following example shows how to get an application resource in code.

// Get an application-scope resource
Brush whiteBrush = (Brush)Application.Current.Resources["ApplicationScopeResource"];
' Get an application-scope resource
Dim whiteBrush As Brush = CType(Application.Current.Resources("ApplicationScopeResource"), Brush)

Hinweise

Die Resources -Eigenschaft kann verwendet werden, um Ressourcen für die Fenster und die Elemente einer Anwendung freizugeben.The Resources property can be used to share resources across the windows and elements of an application. Außerdem ist die Resources -Eigenschaft im Ressourcen Such Pfad enthalten, der in der folgenden Reihenfolge durchsucht wird:Additionally, the Resources property is included in the resource lookup path, which is traversed in the following order:

  1. ElementsElements

  2. WindowsWindows

  3. Application.Resources

  4. SystemSystem

Folglich können Benutzeroberfläche (User Interface, UI)user interface (UI) Elemente an Ressourcen im Anwendungsbereich gebunden werden.Consequently, Benutzeroberfläche (User Interface, UI)user interface (UI) elements can bind to application-scope resources. Wenn sich Ressourcen ändern, stellt das Ressourcensystem zudem sicher, dass die an diese Ressourcen gebundenen Element Eigenschaften automatisch aktualisiert werden, um die Änderung widerzuspiegeln.Additionally, if resources change, the resource system ensures that element properties which are bound to those resources are automatically updated to reflect the change.

Ressourcen im Anwendungsbereich stellen eine einfache Möglichkeit dar, ein konsistentes Design in der gesamten Anwendung zu unterstützen.Application-scope resources provide a simple way to support a consistent theme across your application. Mithilfe des XAMLXAML Application.Resources -Tags können Sie problemlos ein Design in erstellen.You can easily create a theme in XAMLXAML by using the Application.Resources tag. Wenn Ihre Anwendung jedoch mehrere Designs unterstützt, die möglicherweise eine große Anzahl von Designelementen enthalten, ist es möglicherweise einfacher, Sie mit ResourceDictionary einer Instanz für jedes Design zu verwalten.However, if your application supports multiple themes, which may contain a large number of theme elements, it might be easier to manage them using one ResourceDictionary instance for each theme. Auf diese Weise kann ein neues Design angewendet werden, indem die Resources-Eigenschaft auf die geeignete ResourceDictionaryfestgelegt wird.In this way, a new theme can be applied by setting the Resources property to the appropriate ResourceDictionary.

Bei der Verwendung Resourcesvon müssen zwei Aspekte berücksichtigt werden.There are two considerations to make when using Resources. Zuerst ist der Wörterbuch Schlüssel ein Objekt, sodass Sie genau dieselbe Objektinstanz verwenden müssen, wenn Sie einen Eigenschafts Wert festlegen und erhalten (Beachten Sie, dass beim Verwenden einer Zeichenfolge bei der Taste die Groß-/Kleinschreibung beachtet wird).First, the dictionary key is an object, so you need to use exactly the same object instance when both setting and getting a property value (note that the key is case-sensitive when using a string). Zweitens ist der Wörterbuch Wert ein Objekt, sodass Sie den Wert in den gewünschten Typ konvertieren müssen, wenn Sie einen Eigenschafts Wert erhalten.Second, the dictionary value is an object, so you will need to convert the value to the desired type when getting a property value.

Resourcesist Thread sicher und ist in jedem Thread verfügbar.Resources is thread safe and is available from any thread.

Gilt für: