12

TabControlWPF でダイアログ ボックスを実装しています。選択されたタブ (マウスダウン) の色は、デフォルトでは白です。選択したタブの色をホバーの色に変更したい (タブにカーソルを合わせると、タブの色が Office-blue-gradient に変わります。これが、選択したタブの色にしたいものです)マウスクリックで)。

どうやってやるの?

このコードは機能しません:

<Style x:Key="StyleTabControl" TargetType="{x:Type TabItem}">
    <Setter Property="Background" Value="#FFFDFDFD"/>
    <Style.Triggers>
        <Trigger Property="IsSelected "  Value="True">
            <Setter Property="Background" Value="SlateGray"></Setter>
        </Trigger>
    </Style.Triggers>
</Style>

注: トリガー プロパティの IsMouseCaptured イベントも試しました。それでも機能しません。

4

1 に答える 1

23

わかりました...何時間も試してみた結果、TabItem の選択動作がテンプレート レベルで定義されていることに気付きました。したがって、背景色を変更したい場合は、次のようにします。

<Window.Resources>
        <Style TargetType="{x:Type TabItem}">
            <Setter Property="Template">
                <Setter.Value>
                    <ControlTemplate TargetType="{x:Type TabItem}">
                        <Border>
                            <Grid>
                                <Grid>
                                    <Border x:Name="border" 
                                            CornerRadius="3,3,0,0"
                                            Background="WhiteSmoke"/>
                                </Grid>
                                    <ContentPresenter ContentSource="Header"
                                                      HorizontalAlignment="{TemplateBinding HorizontalContentAlignment}"
                                                      VerticalAlignment="{TemplateBinding VerticalContentAlignment}" />
                            </Grid>
                        </Border>
                        <ControlTemplate.Triggers>
                            <Trigger Property="IsMouseOver"
                                     Value="True">
                                <Setter TargetName="border"
                                        Property="Background"
                                        Value="LightGray" />
                            </Trigger>
                            <Trigger Property="IsSelected"
                                     Value="True">
                                <Setter TargetName="border"
                                        Property="Background"
                                        Value="LightGray" />
                            </Trigger>
                        </ControlTemplate.Triggers>
                    </ControlTemplate>
                </Setter.Value>
            </Setter>
        </Style>
    </Window.Resources>
于 2013-08-27T19:33:56.873 に答える