2010-07-29 52 views
4

补充我有被合并到我的主题下面的ResourceDictionary/Generic.xaml文件WPF ResourceDictionary的项目已经使用ComponentResourceKey

<DataTemplate DataType="{x:Type model:RequirementResourceRelation}" x:Key="{x:Static local:Resources.RequirementResourceRelationListTemplateKey}"> 
    <Grid> 
     <Grid.ColumnDefinitions> 
      <ColumnDefinition Width="Auto" /> 
      <ColumnDefinition Width="Auto" /> 
      <ColumnDefinition Width="Auto" /> 
     </Grid.ColumnDefinitions> 
     <TextBlock MinWidth="35" HorizontalAlignment="Left" Padding="3,0" Text="{Binding Resource.Name, TargetNullValue=Loading...}" /> 
     <TextBlock Grid.Column="1" Text="-" /> 
     <TextBlock Grid.Column="2" MinWidth="35" HorizontalAlignment="Left" Padding="3,0" Text="{Binding Path=RelationType, TargetNullValue=Loading...}" TextWrapping="NoWrap" TextTrimming="CharacterEllipsis" /> 
    </Grid> 
</DataTemplate> 

<DataTemplate DataType="{x:Type model:RequirementResourceRelation}" x:Key="{x:Static local:Resources.RequirementResourceRelationListTemplate2Key}"> 
    <Grid> 
     <Grid.ColumnDefinitions> 
      <ColumnDefinition Width="Auto" /> 
      <ColumnDefinition Width="Auto" /> 
      <ColumnDefinition Width="Auto" /> 
     </Grid.ColumnDefinitions> 
     <TextBlock MinWidth="35" HorizontalAlignment="Left" Padding="3,0" Text="{Binding Requirement.Name, TargetNullValue=Loading...}" /> 
     <TextBlock Grid.Column="1" Text="-" /> 
     <TextBlock Grid.Column="2" MinWidth="35" HorizontalAlignment="Left" Padding="3,0" Text="{Binding Path=RelationType, TargetNullValue=Loading...}" TextWrapping="NoWrap" TextTrimming="CharacterEllipsis" /> 
    </Grid> 
</DataTemplate> 

我试图为相同的数据类型与创建两个不同的数据模板不同的ComponentResourceKey。正如你可以看到其中一个键附加了一个2。

在我的本地:资源类我有以下是我正在使用的ComponentResourceKey。

public static ComponentResourceKey RequirementResourceRelationListTemplateKey { 
     get { 
      return new ComponentResourceKey(typeof(Resources), "RequirementResourceRelationListTemplate"); 
     } 
    } 

    public static ComponentResourceKey RequirementResourceRelationListTemplate2Key { 
     get { 
      return new ComponentResourceKey(typeof(Resources), "RequirementResourceRelationListTemplate2"); 
     } 
    } 

这个作品,如果我只在那里的DataTemplates之一,但一旦我添加了第二个,我得到的是说,一个例外:

Item has already been added. Key in dictionary: 'DataTemplateKey(HR.TrackingTool.Model.RequirementResourceRelation)' Key being added: 'DataTemplateKey(HR.TrackingTool.Model.RequirementResourceRelation)' 
    at System.Collections.Hashtable.Insert(Object key, Object nvalue, Boolean add) 
    at System.Collections.Hashtable.Add(Object key, Object value) 
    at System.Windows.ResourceDictionary.SetKeys(IList`1 keyCollection, IServiceProvider serviceProvider) 
    at System.Windows.ResourceDictionary.SetDeferrableContent(DeferrableContent deferrableContent) 
    at System.Windows.Baml2006.WpfSharedBamlSchemaContext.<Create_BamlProperty_ResourceDictionary_DeferrableContent>b__168(Object target, Object value) 
    at System.Windows.Baml2006.WpfKnownMemberInvoker.SetValue(Object instance, Object value) 
    at MS.Internal.Xaml.Runtime.ClrObjectRuntime.SetValue(XamlMember member, Object obj, Object value) 
    at MS.Internal.Xaml.Runtime.ClrObjectRuntime.SetValue(Object inst, XamlMember property, Object value) 

看来,资源字典忽略的关键时添加一个DataTemplate。 ResourceDictionary在使用ComponentRelationKey时是否忽略关键属性?

任何解决此异常的方法?

谢谢,劳尔

回答

4

如果通过键引用您的DataTemplate,你就不能离开了数据类型规格? 没有 DataType =“{x:Type model:RequirementResourceRelation}” (这显然是添加项目的关键)您的x:Key应该被用作关键字。

+1

令人敬畏的工作。我已经将此作为bug提交给Microsoft。 https://connect.microsoft.com/VisualStudio/feedback/details/581761/resource-dictionary-ignores-componentresourcekey-when-adding-a-datatemplate?wa=wsignin1.0 – HaxElit 2010-08-02 14:18:27

+1

此错误仍然有效。难以置信!!我将TextBlock的两种样式添加到应用程序资源字典中。陷入这个错误。完全令人沮丧。我想用我的键盘粉碎我的屏幕。微软吹。期。 – 2013-11-19 10:13:53

+0

这就是说,[这](http://stackoverflow.com/questions/2040804/xaml-mergeddictionaries-throwing-xmlparseexception-item-has-already-been-adde)为我解决了它。我失去了太多的头发。 – 2013-11-19 10:19:32

1

DataTemplate(s)移动到另一个控件的<Resources>元素中。

的Silverlight这只是正常工作:

<ResourceDictionary  
      xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation" 
      xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml" 
       > 
    <!--Template 1--> 
    <DataTemplate DataType="VMType" x:Key="Template1"> 
     ... 
    </DataTemplate> 
    <!--Template 2--> 
    <DataTemplate DataType="VMType" x:Key="Template2"> 
     ... 
    </DataTemplate> 
    <!--Control Style, references the two templates above--> 
    <Style TargetType="ControlType"> 
     <Setter Property="Template"> 
      <Setter.Value> 
       <ControlTemplate TargetType="ControlType"> 
        <Grid Background="White" Margin="0">   
         ... 
        </Grid> 
       </ControlTemplate> 
      </Setter.Value> 
     </Setter> 
    </Style> 
</ResourceDictionary> 

WPF,我不得不搬到控制里面的3个模板:

<ResourceDictionary  
      xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation" 
      xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml" 
       > 
    <Style TargetType="ControlType"> 
     <Setter Property="Template"> 
      <Setter.Value> 
       <ControlTemplate TargetType="ControlType"> 
        <Grid Background="White" Margin="0">   
         <!--MOVED HERE INSTEAD OF THE ROOT-->    
         <Grid.Resources> 
          <!--Template 1--> 
          <DataTemplate DataType="VMType" x:Key="Template1"> 
           ... 
          </DataTemplate> 
          <!--Template 2--> 
          <DataTemplate DataType="VMType" x:Key="Template2"> 
           ... 
          </DataTemplate> 
         </Grid.Resources> 
         ... 
        </Grid> 
       </ControlTemplate> 
      </Setter.Value> 
     </Setter> 
    </Style> 
</ResourceDictionary> 

现在工作在两个WPF和Silverlight没有错误。

8

显然这个问题正如所述,有点。风格声明的顺序很重要。

当两种样式对于相同的TargetType所述第一属性是所述的TargetType例如

<Style TargetType="{x:Type TextBlock}" x:Key="_defaultRuleTextBlockStyle"> 
<Style TargetType="{x:Type TextBlock}" x:Key="_tinySourceCodeTextBlockStyle"> 

然后你得到的错误。它似乎忽略Key:属性,并且如前所述使用TargetType值作为字典键,例如“{X:类型的TextBlock}”

当两个样式相同的TargetType的的第一个元素是X:重点,那么你不这样做,如下图所示。

<Style x:Key="_defaultRuleTextBlockStyle" TargetType="{x:Type TextBlock}"> 
<Style x:Key="_tinySourceCodeTextBlockStyle" TargetType="{x:Type TextBlock}"> 

如果你把垃圾移到我猜的没关系。对智者来说,总是从x:钥匙开始,但这是一个非常愚蠢的错误。

+0

在IMO的最佳答案。如果我坚持了一段时间,怀疑我对WPF的理解。没有意识到XAML中参数的顺序曾经有所不同,但显然它确实如此。 – apc 2016-06-13 10:37:08

+1

我永远无法自己弄清楚这一点。做得好! – Steztric 2017-03-06 21:20:32

相关问题