Condividi tramite


MultiDataTrigger.Setters Proprietà

Definizione

Ottiene un insieme di oggetti Setter che descrivono i valori della proprietà da applicare quando tutte le condizioni di MultiDataTrigger sono soddisfatte.

public:
 property System::Windows::SetterBaseCollection ^ Setters { System::Windows::SetterBaseCollection ^ get(); };
public System.Windows.SetterBaseCollection Setters { get; }
member this.Setters : System.Windows.SetterBaseCollection
Public ReadOnly Property Setters As SetterBaseCollection

Valore della proprietà

SetterBaseCollection

Raccolta di oggetti Setter. Il valore predefinito è una raccolta vuota.

Esempio

Nell'esempio seguente la ItemsSource proprietà di ListBox è associata a Places, un ObservableCollection<T> oggetto di Place oggetti . Place gli oggetti hanno proprietà Name e State. La definizione di Place e Places non viene visualizzata.

Ogni ListBoxItem oggetto ListBox visualizza un Place oggetto . Nell'esempio Style viene applicato a ogni ListBoxItemoggetto . Gli Condition elementi di MultiDataTrigger specificano che se e Name State dell'elemento Place di dati sono Portland e OR rispettivamente, lo sfondo del corrispondente ListBoxItem viene impostato su Cyan.

Si noti che <MultiDataTrigger.Setters> è implicito.

<Window.Resources>
  <c:Places x:Key="PlacesData"/>

  <Style TargetType="ListBoxItem">
    <Style.Triggers>
      <DataTrigger Binding="{Binding Path=State}" Value="WA">
        <Setter Property="Foreground" Value="Red" />
      </DataTrigger>	
      <MultiDataTrigger>
        <MultiDataTrigger.Conditions>
          <Condition Binding="{Binding Path=Name}" Value="Portland" />
          <Condition Binding="{Binding Path=State}" Value="OR" />
        </MultiDataTrigger.Conditions>
        <Setter Property="Background" Value="Cyan" />
      </MultiDataTrigger>
    </Style.Triggers>
  </Style>

  <DataTemplate DataType="{x:Type c:Place}">
    <Canvas Width="160" Height="20">
      <TextBlock FontSize="12"
             Width="130" Canvas.Left="0" Text="{Binding Path=Name}"/>
      <TextBlock FontSize="12" Width="30"
                 Canvas.Left="130" Text="{Binding Path=State}"/>
    </Canvas>
  </DataTemplate>
</Window.Resources>

<StackPanel>
  <TextBlock FontSize="18" Margin="5" FontWeight="Bold"
    HorizontalAlignment="Center">Data Trigger Sample</TextBlock>
  <ListBox Width="180" HorizontalAlignment="Center" Background="Honeydew"
    ItemsSource="{Binding Source={StaticResource PlacesData}}"/>
</StackPanel>

Commenti

MultiDataTrigger consente di avviare le azioni usando le EnterActions proprietà o ExitActions o di impostare i valori delle proprietà usando Setter oggetti quando i dati associati soddisfano un set di condizioni.

Se sono presenti due Setter oggetti nella stessa raccolta setter o in raccolte setter diverse che impostano la stessa proprietà, viene utilizzato l'oggetto Setter dichiarato per ultimo.

L'aggiunta di un Setter elemento figlio a un MultiDataTrigger oggetto lo aggiunge in modo implicito all'oggetto SetterBaseCollection per l'oggetto MultiDataTrigger . EventSettergli oggetti non sono supportati; supporta EventSetter solo Style.Setters gli oggetti .

Utilizzo della sintassi XAML per elementi proprietà

<object>  
    zeroOrMoreSetters  
</object>  

Valori XAML

zeroOrMoreSetters
Zero o più Setter oggetti.

Si applica a

Vedi anche