gpt4 book ai didi

c# - 无法解析样式、ResourceDictionary、UserControl

转载 作者:太空宇宙 更新时间:2023-11-03 12:28:30 26 4
gpt4 key购买 nike

这是迄今为止我在从事 WPF 工作的一年中遇到的最令人困惑的问题。该问题有两个组成部分,对于使用 WPF 时间较长的人来说可能更能说明问题:

  1. UserControl 中,我的 ResourceDictionary 元素提示它需要一个 Key 属性。
  2. 当我定义 Key 属性并尝试在设计时从 XAML 访问样式时,Intellisense(和编译器)不知道我导入的 ResourceDictionary 中定义的样式>.
  3. 我正在尝试将样式应用于 MenuItem 上的 .ItemTemplate

这是我的资源的 UserControl XAML 声明,请注意 x:Key 属性

<UserControl.Resources>
<ResourceDictionary x:Key="HeaderViewStyles">
<ResourceDictionary.MergedDictionaries>
<ResourceDictionary Source="../../Styles/Controls/HeaderViewStyles.xaml"/>
</ResourceDictionary.MergedDictionaries>
</ResourceDictionary>
</UserControl.Resources>

这里是 ResourceDictionary 的部分实现,定义了我希望在 MenuItem 上使用的样式。

x:Class="Styles.Controls.HeaderViewStyles">

<Style x:Key="DarkMenuItem" TargetType="{x:Type MenuItem}">
<Setter Property="Foreground" Value="{Binding Path=Foreground, RelativeSource={RelativeSource AncestorType={x:Type Menu}}}"/>
<Setter Property="Template">
<Setter.Value>
<ControlTemplate TargetType="{x:Type MenuItem}">

<!---

可能是上面的样式本身有问题;但是,我感兴趣的是为什么我无法在设计时访问样式

这是我应用样式的尝试(发布以获取完整信息):

     <Menu>
<MenuItem ItemsSource="{Binding ContextMenuItemViewModels}">
<MenuItem.Icon>
<Image Source="../../Resources/menu.png"/>
</MenuItem.Icon>
<MenuItem.ItemTemplate>
<DataTemplate DataType="{x:Type controlViewModels:ContextMenuItemViewModel}">
<MenuItem Style="{DynamicResource DarkMenuItem}"
Header="{Binding MenuHeaderText}"
Command="{Binding MenuItemClickedCommand}"/>
</DataTemplate>
</MenuItem.ItemTemplate>
</MenuItem>
</Menu>

我确信这是多种因素的结合;但是,我显然缺乏一些知识。我错过了什么或没有做什么?我尝试了各种组合,但仍然无法选择风格。

编辑

对于那些想要了解更多信息的人,这是我的控件 XAML:

<UserControl x:Class="Views.Controls.HeaderView"
xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
xmlns:controlViewModels="clr-namespace:ViewModels.Controls"
xmlns:controlViews="clr-namespace:Views.Controls"
xmlns:converters="clr-namespace:Converters"
VerticalContentAlignment="Stretch"
Background="#4C4C4C">

<UserControl.Resources>
<converters:SyncStateToVisibilityConverter x:Key="SyncStateToVisibilityConverter"/>
<ResourceDictionary x:Key="HeaderViewStyles">
<ResourceDictionary.MergedDictionaries>
<ResourceDictionary Source="../../Styles/Controls/HeaderViewStyles.xaml"/>
</ResourceDictionary.MergedDictionaries>
</ResourceDictionary>
</UserControl.Resources>

<Grid>
<Grid.RowDefinitions>
<RowDefinition Height="*"/>
<RowDefinition Height="6"/>
</Grid.RowDefinitions>
<Grid.ColumnDefinitions>
<ColumnDefinition Width="60"/>
<ColumnDefinition Width="*"/>
<ColumnDefinition Width="110"/>
</Grid.ColumnDefinitions>

<Button Background="#4C4C4C" Margin="20,0,0,0"
VerticalAlignment="Center"
Command="{Binding StatusButtonClickedCommand}">
<Image >
<Image.Style>
<Style TargetType="{x:Type Image}">
<Style.Triggers>
<Trigger Property="IsMouseOver" Value="False">
<Setter Property="Source" Value="{Binding StatusIconLocation}"/>
</Trigger>
<Trigger Property="IsMouseOver" Value="True">
<Setter Property="Source" Value="{Binding StatusIconLocationHover}"/>
</Trigger>
</Style.Triggers>
</Style>
</Image.Style>
</Image>
</Button>

<StackPanel Grid.Column="1" Grid.ColumnSpan="2" Orientation="Vertical">
<TextBlock></TextBlock>
<TextBlock></TextBlock>
</StackPanel>

<Menu>
<MenuItem ItemsSource="{Binding ContextMenuItemViewModels}">
<MenuItem.Icon>
<Image Source="../../Resources/menu.png"/>
</MenuItem.Icon>
<MenuItem.ItemTemplate>
<DataTemplate DataType="{x:Type controlViewModels:ContextMenuItemViewModel}">
<MenuItem Style="{DynamicResource DarkMenuItem}"
Header="{Binding MenuHeaderText}"
Command="{Binding MenuItemClickedCommand}"/>
</DataTemplate>
</MenuItem.ItemTemplate>
</MenuItem>
</Menu>

<ProgressBar Grid.Row="1"
Grid.ColumnSpan="3"
Value="{Binding PercentageSynced}"
Visibility="{Binding CurrentSyncSystemStatus,
Converter={StaticResource SyncStateToVisibilityConverter},
ConverterParameter=Syncing,
FallbackValue=Collapsed}"/>
</Grid>

最佳答案

您需要将您的转换器移动到资源字典中,并删除 x:Key,如下所示:

<UserControl.Resources>
<ResourceDictionary>
<ResourceDictionary.MergedDictionaries>
<ResourceDictionary Source="../../Styles/Controls/HeaderViewStyles.xaml"/>
</ResourceDictionary.MergedDictionaries>
<converters:SyncStateToVisibilityConverter x:Key="SyncStateToVisibilityConverter"/>
</ResourceDictionary>
</UserControl.Resources>

如果您将没有键的 ResourceDictionary 作为 UserControl.Resources 的根 - 这意味着:

userControl.Resources = new ResourceDictionary();

因此,您必须将所有其他资源都放在内部该字典中,而不是外部。

您原来的 xaml(带有 x:Key)大致是这样的:

userControl.Resources.Add("SyncStateToVisibilityConverter", new YourConverter());
userControl.Resources.Add("HeaderViewStyles", new ResourceDictionary(...));

所以,并不是您所期望的那样。

关于c# - 无法解析样式、ResourceDictionary、UserControl,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/43680626/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com