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

定義

スタイルやブラシなど、アプリケーション スコープ リソースのコレクションを取得または設定します。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

プロパティ値

0 個以上のアプリケーション スコープ リソースが格納された ResourceDictionary オブジェクト。A ResourceDictionary object that contains zero or more application-scope resources.

この例では、アプリケーション スコープのリソースと XAML を使用して、一貫性のある外観を作成する方法を示します。This example illustrates how to use XAML together with application-scope resources to create a consistent visual appearance. 最初の例はApp.xamlからの 2 番目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>

次の例は、コードと XAML で、アプリケーションのリソースを設定する方法を示します (、App.xaml ファイルで、 C# WPF プロジェクトまたは、Application.xaml ファイルを Visual Basic WPF プロジェクトで)。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>

次の例では、コードで、アプリケーションのリソースを取得する方法を示します。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)

注釈

Resources Windows とアプリケーションの要素間でリソースを共有するプロパティを使用できます。The Resources property can be used to share resources across the windows and elements of an application. さらに、Resourcesが次の順序で走査するリソースの検索パスにプロパティが含まれます。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. システムSystem

その結果、ユーザー インターフェイス (UI)user interface (UI)要素は、アプリケーション スコープのリソースにバインドできます。Consequently, ユーザー インターフェイス (UI)user interface (UI) elements can bind to application-scope resources. さらに、リソースを変更する場合、リソース システムによって、その要素の変更を反映するこれらのリソースにバインドされているプロパティが自動的に更新します。Additionally, if resources change, the resource system ensures that element properties which are bound to those resources are automatically updated to reflect the change.

アプリケーション スコープ リソースは、アプリケーション間で一貫性のあるテーマをサポートする簡単な方法を提供します。Application-scope resources provide a simple way to support a consistent theme across your application. テーマを簡単に作成することができますXAMLXAMLを使用して、Application.Resourcesタグ。You can easily create a theme in XAMLXAML by using the Application.Resources tag. ただし、アプリケーションは、多数のテーマ要素を含む場合がある、複数のテーマをサポートしている場合がありますいずれかを使用してそれらを管理しやすいResourceDictionary各テーマのインスタンス。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. 適切なリソースのプロパティを設定して、この方法で新しいテーマを適用できるResourceDictionaryします。In this way, a new theme can be applied by setting the Resources property to the appropriate ResourceDictionary.

使用するときに 2 つの考慮事項がありますResourcesします。There are two considerations to make when using Resources. まず、ディクショナリキーは、オブジェクトを設定およびプロパティの値 (文字列を使用する場合、キーが大文字であることに注意してください) を取得するときにまったく同じオブジェクト インスタンスを使用する必要があるためです。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). 2 つ目は、ディクショナリオブジェクトは、プロパティ値を取得するときに、目的の型に値を変換する必要があります。Second, the dictionary value is an object, so you will need to convert the value to the desired type when getting a property value.

Resources スレッド セーフであるは、任意のスレッドから使用できます。Resources is thread safe and is available from any thread.

適用対象