C# WPF:在TabItem标头中绑定

C# WPF:在TabItem标头中绑定,c#,wpf,tabitem,C#,Wpf,Tabitem,当修改TabItem的内容(绑定数据)时,我希望在tab item标题“*”(星形)中显示。 我有以下风格的TabItem: <TabControl.Resources> <Style TargetType="{x:Type TabItem}"> <Setter Property="Template"> <Setter.Value> <ControlTemplat

当修改TabItem的内容(绑定数据)时,我希望在tab item标题“*”(星形)中显示。 我有以下风格的TabItem:

<TabControl.Resources>
    <Style TargetType="{x:Type TabItem}">
        <Setter Property="Template">
            <Setter.Value>
                <ControlTemplate TargetType="{x:Type TabItem}">
                    <Grid>
                        <Border Name="_border" 
                                Margin="0,0,0,0" 
                                Padding="0 0 5 0" 
                                Background="Transparent" 
                                BorderBrush="Black" 
                                BorderThickness="0,0,0,0" 
                                CornerRadius="1">
                            <StackPanel Orientation="Horizontal" Margin="10 2 0 2">
                                <TextBlock Foreground="Black" Name="_header">
                                    <ContentPresenter VerticalAlignment="Center" 
                                                      HorizontalAlignment="Center"
                                                      ContentSource="Header" 
                                                      RecognizesAccessKey="True">
                                    </ContentPresenter>
                                </TextBlock>
                                <Button Name="_close"
                                        Visibility="Hidden"
                                        Style="{StaticResource _closeButtonStyle}" 
                                        CommandParameter="{Binding RelativeSource={RelativeSource AncestorType={x:Type TabItem}}}"
                                        Click="CloseTab_Click"
                                        BorderThickness="0"
                                        Margin="10 0 0 0"
                                        Width="16"
                                        Height="16">
                                    <Image Source="Images/delete_icon16_white.png"
                                           Width="10"
                                           Height="10"
                                           Cursor="Hand"/>
                                </Button>
                            </StackPanel>
                        </Border>
                    </Grid>
                    <ControlTemplate.Triggers>
                        <Trigger Property="IsSelected" Value="True">
                            <Setter TargetName="_header" Property="Foreground" Value="White"/>
                            <Setter TargetName="_close" Property="Visibility" Value="Visible"/>
                            <Setter TargetName="_border" Property="Background">
                                <Setter.Value>
                                    <SolidColorBrush Color="{DynamicResource {x:Static SystemColors.HighlightColorKey}}"/>
                                </Setter.Value>
                            </Setter>
                        </Trigger>
                        <MultiTrigger>
                            <MultiTrigger.Conditions>
                                <Condition Property="IsMouseOver" Value="True"/>
                                <Condition Property="IsSelected" Value="False"/>
                            </MultiTrigger.Conditions>
                            <Setter TargetName="_header" Property="Foreground" Value="White"/>
                            <Setter TargetName="_close" Property="Visibility" Value="Visible"/>
                            <Setter TargetName="_border" Property="Background">
                                <Setter.Value>
                                    <SolidColorBrush Color="{DynamicResource {x:Static SystemColors.MenuHighlightColorKey}}"/>
                                </Setter.Value>
                            </Setter>
                        </MultiTrigger>
                    </ControlTemplate.Triggers>
                </ControlTemplate>
            </Setter.Value>
        </Setter>
    </Style>
</TabControl.Resources>

当绑定数据的属性IsModified设置为true时,如何添加到提到的“*”样式中


感谢您的回复

在标题上创建一个Text=“*”文本块

然后使用IsModified属性和booleanToVisibility转换器绑定其可见性

编辑: 绑定可见性

Visibility="{Binding IsModified, Converter={StaticResource booleanToVisibilityConverter}}"
在您的资源文件中

<BooleanToVisibilityConverter x:Key="booleanToVisibilityConverter"/>

编辑2:不知道你是否需要这些信息,只是为了这个案子。对HeaderTemplate的探讨

<Setter Property="HeaderTemplate">
    <Setter.Value>
      <DataTemplate>
        <StackPanel>
          <TextBlock Text="{Binding Content}" />
          <TextBlock Text="*" Visibility="{Binding IsModified, Converter={StaticResource booleanToVisibilityConverter}}"/>
        </StackPanel>
      </DataTemplate>
    </Setter.Value>


这是个好建议。。。想向用户展示如何做到这一点吗?这是一个线索,这样OP就可以找到答案,可见性的绑定我认为应该是:可见性=“{binding IsModified,Converter={StaticResource booleanToVisibilityConverter}”想想更大的图景……不仅仅是这个用户在寻找这个问题的答案。而且,你的答案越有用,你从StackOverflow社区获得的声誉就越高。你是对的。下次我会在开头写完整的答案。我是wpf的新手,我不想用错误的方式回答。希望我的版本是正确的。javi我已经试过了,但是没有用。我意识到问题出在哪里,所以现在我正在重构我的代码。。。无论如何,你的建议是正确的。