What is the ThemeInfo attribute for?

12,033

Solution 1

ThemeInfo attribute specifies where the automatic theming mechanism should look for the theme dictionaries and the generic dictionary. Each option can be set to one of the following values:

  • None (default): Don’t look for a resource dictionary.
  • SourceAssembly: The dictionary is the current assembly.
  • ExternalAssembly: The dictionary is in a different assembly, which must be named <AssemblyName>.<ThemeName>.dll, where <AssemblyName> is the current assembly's name.

If the theme dictionaries specify styles for controls that are defined in external assemblies, for example, the WPF controls such as System.Windows.Controls.ProgressBar and System.Windows.Button, then you must use the ThemeDictionaryExtension to specify the application as the source for the theme dictionaries.

Solution 2

The WPF framework uses this attribute in control libraries as a convenient way to apply resources to controls.

Consider that Windows can be run with different UI themes (Aero is one such example). The WPF controls provided by Microsoft alter their appearance for different environment themes.

If your application requires this behaviour, then you can create different theme dictionaries the in the themes folder of your control library project.

Even if you don't need multi-theme support, it is convenient to put resources in the generic.xaml file so that they are accessible to controls in the assembly. Perhaps your element (control) is defined in a .cs file without a .xaml partial class, and you need somewhere to store the resources it needs, or (more likely) you have resources that will be shared between many WPF elements in the same project/assembly.

The attribute you're referring to here is metadata for the mapping of these resources.

Share:
12,033
Joe White
Author by

Joe White

Updated on June 14, 2022

Comments

  • Joe White
    Joe White almost 2 years

    Whenever I create a new WPF application or WPF user control library, the AssemblyInfo.cs file includes the following attribute:

    [assembly: ThemeInfo(
        ResourceDictionaryLocation.None, 
        //where theme specific resource dictionaries are located
        //(used if a resource is not found in the page, 
        // or application resource dictionaries)
        ResourceDictionaryLocation.SourceAssembly 
        //where the generic resource dictionary is located
        //(used if a resource is not found in the page, 
        // app, or any theme specific resource dictionaries)
    )]
    

    What is this ThemeInfo attribute for? Will I break anything if I remove it?