У меня есть ListView
с ItemContainerStyle
, определенным так:
<ListView Width="auto"
SelectionMode="Single"
ItemContainerStyle="{StaticResource ItemContStyle}"
....
Затем в baseListViewStyle
я определил несколько базовых стилей, которые будут применяться к моим ListView
с, включая триггер Style
:
<Style x:Key="baseListViewStyle" TargetType="ListViewItem">
<Setter Property="Height" Value="20" />
<Setter Property="HorizontalContentAlignment" Value="Stretch"/>
<Style.Triggers>
<Trigger Property="IsMouseOver" Value="True">
<Setter Property="Foreground" Value="Red" />
</Trigger>
</Style.Triggers>
</Style>
Trigger
здесь выделяет строку, когда мышь находится над ней. Ницца.
У меня также есть DataTrigger
на ListViewItem
:
<Style.Triggers>
<DataTrigger Binding="{Binding IsTestTrue}" Value="True">
<DataTrigger.EnterActions>
<BeginStoryboard Storyboard="{StaticResource SomeFunkyAnimation}" />
</DataTrigger.EnterActions>
</DataTrigger>
Если проверка верна, то проигрывается приятная небольшая анимация затухания. Это все работает, за исключением того, что когда я наведу курсор мыши на строку, в которой «test is true», анимация останавливается и отображается стиль мыши.
Есть идеи, как мне переопределить этот стиль в моем DataTrigger
?
ТИА
Обновление:
SomeFunkyAnimation
анимирует цвет фона. XAML для этого здесь:
<Style x:Key="ItemContStyle" TargetType="{x:Type ListViewItem}" BasedOn="{StaticResource baseListViewStyle}">
<Style.Resources>
<Storyboard x:Key="SomeFunkyAnimation" FillBehavior="Stop">
<ColorAnimation Storyboard.TargetProperty="Background.Color" RepeatBehavior="Forever" From="Red" To="Pink" Duration="0:0:3"/>
</Storyboard>
</Style.Resources>
Триггер MouseOver
определен в baseListViewStyle
. DataTrigger
определяется в ItemContStyle
.
Я попытался удалить триггер в стиле MouseOver
, но это не сработало, так как я считаю, что в Listview
уже определен стиль MouseOver
по умолчанию, поэтому он отменяет мою DataTrigger
анимацию.