MultiDataTrigger.Setters Proprietà
Definizione
Importante
Alcune informazioni sono relative alla release non definitiva del prodotto, che potrebbe subire modifiche significative prima della release definitiva. Microsoft non riconosce alcuna garanzia, espressa o implicita, in merito alle informazioni qui fornite.
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à
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.