我的窗口中有样式。资源:
<Style x:Key="Header" TargetType="GridViewColumnHeader">
<Setter Property="Content">
<Setter.Value>
<StackPanel Orientation="Horizontal">
<Label Width="80" HorizontalContentAlignment="Center" Content="{Binding RelativeSource={RelativeSource Mode=FindAncestor, AncestorType=GridViewColumnHeader, AncestorLevel=1}, Path=Tag}" />
<StackPanel Orientation="Vertical">
<Polygon Name="P_up" Points="0,5 10,5, 5,0" Stroke="Black" Fill="Black" Margin="3" Visibility="Visible"/>
<Polygon Name="P_down" Points="0,0 10,0, 5,5" Stroke="Black" Fill="Black" Margin="3" Visibility="Hidden"/>
</StackPanel>
</StackPanel>
</Setter.Value>
</Setter>
<EventSetter Event="Click" Handler="Header_Click"/>
</Style>
当我将样式设置为 ListView (GridViewColumnHeader)时,如下所示:
<ListView Height="300" x:Name="lv" ItemsSource="{Binding PLCs}">
<ListView.View>
<GridView>
<GridViewColumn Width="120">
<GridViewColumnHeader Name="myNewText" Tag="test" Style="{StaticResource Header}"/>
</GridViewColumn>
<GridViewColumn Width="120">
<GridViewColumnHeader Name="myNewText2" Tag="test2" Style="{StaticResource Header}"/>
</GridViewColumn>
<GridViewColumn Width="120">
<GridViewColumnHeader Tag="test32" Style="{StaticResource Header}"/>
</GridViewColumn>
</GridView>
</ListView.View>
</ListView>
与祖先 Tag 的绑定有效,并且显示 Polygon ,但仅对于 GridViewColumns 中的最后一个,第一个两个都保持空白。谁能告诉我我在做什么错?由于所有三列的代码都相同,因此我认为这将为我提供全部三列相同的结果。我猜想标签的 Content 绑定或 Style 的 TargetType 是不正确的。
感谢您的帮助。
答案 0 :(得分:3)
您应该使用ContentTemplate
属性:
<Setter Property="ContentTemplate">
<Setter.Value>
<DataTemplate>
<! -- ...place your stack panel here -->
</DataTemplate>
</Setter.Value>
</Setter>
这样做,您为每个列标题定义了一个模板。该模板将分别实例化每个列标题的内容。
如果使用Content
属性,则将与内容相同的堆栈面板设置为所有列标题。这行不通-只有最后一个赢。堆栈面板的父项将自动设置为最后一个标题。就像:
header1.Content = your_stack_panel;
your_stack_panel.Parent = header1;
header2.Content = your_stack_panel;
your_stack_panel.Parent = header2;
header3.Content = your_stack_panel;
your_stack_panel.Parent = header3;