从 wpf 中的单独文件加载控件样式

本文关键字:加载 控件 样式 文件 单独 wpf | 更新日期: 2023-09-27 18:36:57

我在我的Windows.Resources中添加了以下样式

<Window.Resources>
    ...
    <!--A Style that extends the previous TextBlock Style-->
    <!--This is a "named style" with an x:Key of TitleText-->
    <Style BasedOn="{StaticResource {x:Type TextBlock}}"
       TargetType="TextBlock"
       x:Key="TitleText">
        <Setter Property="FontSize" Value="26"/>
        <Setter Property="Foreground">
            <Setter.Value>
                <LinearGradientBrush StartPoint="0.5,0" EndPoint="0.5,1">
                    <LinearGradientBrush.GradientStops>
                        <GradientStop Offset="0.0" Color="#90DDDD" />
                        <GradientStop Offset="1.0" Color="#5BFFFF" />
                    </LinearGradientBrush.GradientStops>
                </LinearGradientBrush>
            </Setter.Value>
        </Setter>
    </Style> 
    ...
</Window.Resources>

我的xaml代码中有很多这样的样式,我想将每个组件样式保存到一个额外的文件(而不是外部文件)中,例如,与TextBlocks相关的所有样式都应该在一个名为TextBlockStyles.xaml的文件中

我将如何在 wpf 中执行此操作?

如何在项目中链接样式?

提前致谢

从 wpf 中的单独文件加载控件样式

使用合并的资源字典

在你的app.xaml中,你会使用

<Application.Resources>
    <ResourceDictionary>
        <ResourceDictionary.MergedDictionaries>
            <ResourceDictionary 
                Source="/Your.Assembly.Name;component/TextBlockStyles.xaml"/>
            ... other dictionaries here
        </ResourceDictionary.MergedDictionaries>
    </ResourceDictionary>
</Application.Resources>

或直接进入用户控件将是

<UserControl.Resources>
    <ResourceDictionary>
        <ResourceDictionary.MergedDictionaries>
            <ResourceDictionary 
                Source="/Your.Assembly.Name;component/TextBlockStyles.xaml"/>
            ... other dictionaries here
        </ResourceDictionary.MergedDictionaries>
    </ResourceDictionary>
</UserControl.Resources>

如果文件位于同一程序集中且位于项目的根目录中,则可以Source="..."缩短为仅Source="TextBlockStyles.xaml",或者如果将资源字典放入文件夹 Styles 中,则可以Source="Styles'TextBlockStyles.xaml"

用例:您有一个名为 MyView.xaml 的用户控件,其中包含一个按钮。 你想要使用外部 XAML 文件设置按钮的样式。


MyView.xaml

<User Control ...namespaces...>
    <UserControl.Resources>
        <ResourceDictionary>
            ...converters...
            <ResourceDictionary.MergedDictionaries>
                <ResourceDictionary Source="MyButton.xaml"/>
            </ResourceDictionary.MergedDictionaries>
        </ResourceDictionary>
    </UserControl.Resources>
     ...the rest of the control...
</UserControl>

MyButton.xaml

<ResourceDictionary
    xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
    xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
    xmlns:local="using:MSDNSample">
    <Style x:Key="FooButton" TargetType="{x:Type Button}">
        <Setter Property="Background" Value="Pink" />
    </Style>
</ResourceDictionary>

回到MyView.xaml("控件的其余部分"):

<Button Style="{StaticResource FooButton}">
    Hello World
</Button>

解决方案资源管理器中,右键单击您的项目 选择添加 之后,单击资源字典...选择名称并添加到您的项目中。打开应用程序.xaml应用程序标记中添加此代码

<Application.Resources>
    <ResourceDictionary>
        <ResourceDictionary.MergedDictionaries>
            <ResourceDictionary Source="YourStyle.xaml" />
        </ResourceDictionary.MergedDictionaries>
    </ResourceDictionary>
</Application.Resources>

In YourStyle.xaml :

<ResourceDictionary xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
                xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
                xmlns:local="clr-namespace:APPNAME">
    <Style x:Key="ButtonStyle" TargetType="{x:Type Button}">
        <Setter Property="Background" Value="Pink" />
    </Style>
</ResourceDictionary>

您正在寻找动态资源。 最好的方法是在资源中加载和组合字典。 应用程序或控制页面上的任一选项。这是一个很好的示例。

http://blogs.msdn.com/b/wpfsdk/archive/2007/06/08/defining-and-using-shared-resources-in-a-custom-control-library.aspx

<ResourceDictionary>
  <ResourceDictionary.MergedDictionaries>
    <ResourceDictionary Source="Dictionary1.xaml"/>
  </ResourceDictionary.MergedDictionaries>
</ResourceDictionary>

这。Resources.MergedDictionaries.Add(Smyresourcedictionary);

简单地说

,转到要包含外部文件中的资源的窗口(例如:MaindWindow.xaml),并使用合并字典原则来引用该文件:

<Window x:Class="UseMergedResource.MainWindow"
        xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
        xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
        xmlns:d="http://schemas.microsoft.com/expression/blend/2008"
        xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"
        mc:Ignorable="d"
        Title="MainWindow"
        Height="600"
        Width="600">
  <Window.Resources>
    <!-- DECLARING MERGED DICTIONARY --> 
    <ResourceDictionary>
      <ResourceDictionary.MergedDictionaries>
        <ResourceDictionary Source='Merged/BrushResources.xaml' />
      </ResourceDictionary.MergedDictionaries>
    </ResourceDictionary>
    <!----------------------------------> 
  </Window.Resources>

  <StackPanel>
    <Rectangle Width='200'
               Height='100'
               Fill='{StaticResource PrimaryBrush}' /> <!-- USAGE HERE -->
  </StackPanel>
</Window>

从上面看Merged/BrushResources.xaml是资源文件的位置,它位于名为 Merged 的文件夹下。

现在,如果您想知道外部文件中的声明语法应该是什么,请检查以下内容:

<ResourceDictionary xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
                                        xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml">
    <!-- Location for application brushes -->
    <SolidColorBrush x:Key='BorderBrush'
                                     Color='Orange' />
    <SolidColorBrush x:Key='HighLightBrush'
                                     Color='LightBlue' />
    <SolidColorBrush x:Key='PrimaryBrush'
                                     Color='Pink' />
    <SolidColorBrush x:Key='AccentBrush'
                                     Color='Yellow' />
</ResourceDictionary>

如果要使资源通过所有应用程序(在所有窗口中可见)可用,请在App.xaml资源部分中声明。