I start with the Windows 8 C# XAML user and custom controls sample and moved the files
Themes/Generic.xaml
BasicCustomControl.cs
BasicUserControl.xaml
BasicUserControl.xaml.cs
ImageWithLabelControl.cs
to a Metro Class Library named Controls
, reference it in the UserAndCustomControls
project and correct the local:...
references to xmlns:local="using:Controls"
. This works great.
BUT if create a resource dictionary "Style.xaml"
in the class library with
<ResourceDictionary
xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
xmlns:local="using:Controls">
<Color x:Key="ColorBackground">Red</Color>
</ResourceDictionary>
and include in the ScenarioList.xaml
file
<Page.Resources>
<ResourceDictionary>
<ResourceDictionary.MergedDictionaries>
<ResourceDictionary Source="/Controls;component/Style.xaml" />
</ResourceDictionary.MergedDictionaries>
</ResourceDictionary>
</Page.Resources>
i'm get an runtime error
XamlParseException
Failed to assign to property 'Windows.UI.Xaml.ResourceDictionary.Source'.
if I try apply the color to the Grid
<Grid>
<Grid.Background>
<SolidColorBrush Color="{StaticResource ColorBackground}" />
</Grid.Background>
<ListBox x:Name="Scenarios" ...
[...]
</Grid>
[Q] The question is, how do I correctly declare, reference and use external style in Metro application? My idea is create reusable controls and common styles delivered as a single dll file.
navits points the answer.
If you have a dll named "CustomControl" with a ResourceDictionary named "Styles.xaml" contained a folder named "Themes".
For C# projects the App.xaml should contain :
<ResourceDictionary>
<ResourceDictionary.MergedDictionaries>
<ResourceDictionary Source="ms-appx:///CustomControls/Themes/Styles.xaml"/>
</ResourceDictionary.MergedDictionaries>
</ResourceDictionary>
With the Themes
folder in the Source path, for C# projects.
and
For VB.Net projects the App.xaml should contain :
<ResourceDictionary>
<ResourceDictionary.MergedDictionaries>
<ResourceDictionary Source="ms-appx:///CustomControls/Styles.xaml"/>
</ResourceDictionary.MergedDictionaries>
</ResourceDictionary>
Without the Themes
folder in Source path, for VB.Net projects.