Wpf 条件工具提示样式

Wpf 条件工具提示样式,wpf,mvvm,triggers,styles,Wpf,Mvvm,Triggers,Styles,我试图为我的文本框创建一个样式,并为其工具提示创建一个条件样式。 当TextBox属性Validation.HasErrors为true时,工具提示必须具有不同的样式 我不知道如何有条件地从父样式(文本框)定义更改子样式(工具提示) 在下面的代码中,始终应用工具提示样式 <Style x:Key="errorStyle" TargetType="{x:Type Control}"> <Style.Resources>

我试图为我的文本框创建一个样式,并为其工具提示创建一个条件样式。 当TextBox属性Validation.HasErrors为true时,工具提示必须具有不同的样式

我不知道如何有条件地从父样式(文本框)定义更改子样式(工具提示)

在下面的代码中,始终应用工具提示样式

<Style x:Key="errorStyle" TargetType="{x:Type Control}">
                <Style.Resources>
                    <Style TargetType="{x:Type ToolTip}">
                        <Setter Property="Background" Value="Red"/>
                        <Setter Property="Foreground" Value="White"/>
                    </Style>
                </Style.Resources>
                <Setter Property="Validation.ErrorTemplate">
                    <Setter.Value>
                        <ControlTemplate>
                            <DockPanel>
                                <Border BorderBrush="Red" BorderThickness="2" CornerRadius="2" Background="{x:Null}">
                                    <AdornedElementPlaceholder/>
                                </Border>
                            </DockPanel>
                        </ControlTemplate>
                    </Setter.Value>
                </Setter>
                <Style.Triggers>
                    <Trigger Property="Validation.HasError" Value="true">
                        <Setter Property="ToolTip" Value="{Binding RelativeSource={x:Static RelativeSource.Self},
                                Path=(Validation.Errors)[0].ErrorContent}"/>
                    </Trigger>

                </Style.Triggers>
</Style>
<Style TargetType="TextBox" BasedOn="{StaticResource errorStyle}" />

谢谢。

您可以使用工具提示的属性更改工具提示样式。
DataTrigger
将完成剩余的工作

这是一个关于我的意思的示例:

<ToolTip Content="Tooltip content...">
    <ToolTip.Style>
        <Style BasedOn="{StaticResource {x:Type ToolTip}}" TargetType="{x:Type ToolTip}">
            <Style.Triggers>
                <DataTrigger Binding="{Binding RelativeSource={RelativeSource Self},
                                               Path=PlacementTarget.(Validation.HasError)}"
                                Value="True">
                    <Setter Property="Background" Value="Red" />
                </DataTrigger>
            </Style.Triggers>
        </Style>
    </ToolTip.Style>
</ToolTip>


我希望它能帮助您

您必须分享一些小代码,以便更好地理解和帮助您。这很好。谢谢