Смешивание триггера данных с обычным триггером в элементе управления элементами

У меня есть один набор триггеров для моего 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>
Другие вопросы по тегам