Смешивание триггера данных с обычным триггером в элементе управления элементами
У меня есть один набор триггеров для моего ItemsControl, который работает отлично:
<DataTemplate.Triggers>
<Trigger Property="ItemsControl.AlternationIndex" Value="1">
<Setter Property="Background" Value="LightGray" TargetName="Foobar"></Setter>
</Trigger>
</DataTemplate.Triggers>
Моя проблема в том, что иногда мне приходится вставлять "специальную строку" в список.
Я использую следующий триггер, который работает для управления элементами управления в шаблоне:
<Style TargetType="TextBlock">
<Style.Triggers>
<DataTrigger Binding="{Binding isHeaderLine}" Value="true">
<Setter Property="Visibility" Value="Visible"/>
</DataTrigger>
</Style.Triggers>
</Style>
Этот работает хорошо, и я получаю именно то, что хочу отображать.
Теперь мой вопрос заключается в том, что я хочу объединить их, чтобы специальная строка получала белый фон независимо от того, какое это значение в AlternationIndex.
Можно ли это сделать?
Вот полный код:
<ItemsControl Margin="0 0 0 30" Name="CtrlOrderDetails" AlternationCount="2">
<ItemsControl.ItemTemplate>
<DataTemplate>
<Grid x:Name="Foobar">
<TextBlock Text="{Binding ProdcutName}" Margin="0 5 0 5" FontSize="16">
<TextBlock.Style>
<Style TargetType="TextBlock">
<Style.Triggers>
<DataTrigger Binding="{Binding isHeaderLine}" Value="true">
<Setter Property="Visibility" Value="Collapsed"/>
</DataTrigger>
</Style.Triggers>
</Style>
</TextBlock.Style>
</TextBlock>
<TextBlock Text="{Binding headerText}">
<TextBlock.Style>
<Style TargetType="TextBlock">
<Setter Property="FontWeight" Value="Bold"></Setter>
<Setter Property="FontSize" Value="16"></Setter>
<Setter Property="Foreground" Value="Blue"></Setter>
<Setter Property="Visibility" Value="Collapsed"/>
<Setter Property="Margin" Value="0 10 0 5 "/>
<Style.Triggers>
<DataTrigger Binding="{Binding isHeaderLine}" Value="true">
<Setter Property="Visibility" Value="Visible"/>
</DataTrigger>
</Style.Triggers>
</Style>
</TextBlock.Style>
</TextBlock>
</Grid>
<DataTemplate.Triggers>
<Trigger Property="ItemsControl.AlternationIndex" Value="1">
<Setter Property="Background" Value="LightGray" TargetName="Foobar"></Setter>
</Trigger>
</DataTemplate.Triggers>
</DataTemplate>
</ItemsControl.ItemTemplate>
<ItemsControl>
1 ответ
Решение
Попробуйте использовать тот же DataTrigger из стиля в DataTemplate, но с установщиком для фона
<DataTemplate.Triggers>
<Trigger Property="ItemsControl.AlternationIndex" Value="1">
<Setter Property="Background" Value="LightGray" TargetName="Foobar"/>
</Trigger>
<DataTrigger Binding="{Binding isHeaderLine}" Value="true">
<Setter Property="Background" Value="White" TargetName="Foobar"/>
</DataTrigger>
</DataTemplate.Triggers>