2009-11-25 16 views
9

Ho un datatemplate contenente un'immagine che voglio nascondere se il valore di una proprietà in un ViewModel è true. Qualcuno può dirmi perché il xaml qui sotto non funziona?WPF Trigger binding alla proprietà MVVM

<Image x:Name="img" Source="..\Images\List_16.png" Margin="0,0,5,0"> 
    <Image.Style> 
    <Style> 
     <Style.Triggers> 
     <DataTrigger Binding="{Binding CurrentListHasPendingChanges}" Value="True"> 
      <Setter Property="Image.Visibility" Value="Hidden" /> 
     </DataTrigger> 
     <DataTrigger Binding="{Binding CurrentListHasPendingChanges}" Value="False"> 
      <Setter Property="Image.Visibility" Value="Visible" /> 
     </DataTrigger> 
     </Style.Triggers> 
    </Style> 
    </Image.Style> 
</Image> 

risposta

3

non è che

<Setter Property="Visibility" Value="Hidden" /> 

?

Suppongo che tu usi INotifyProptyChanged.

EDIT Ho fatto un po 'su Google e penso che sia necessario utilizzare una sorta di modello per far funzionare il trigger.

ad es .: http://social.msdn.microsoft.com/Forums/en-US/wpf/thread/ae2dbfb7-5dd6-4352-bfa1-53634289329d

http://www.thejoyofcode.com/Help_Why_cant_I_use_DataTriggers_with_controls_in_WPF.aspx

+0

Sì, faccio implementare INotifyPropertyChanged. Quando cambio il setter come sopra, ottengo il seguente errore di compilazione: Impossibile risolvere la 'Visibilità' della proprietà dello stile. Verificare che il tipo proprietario sia il TargetType dello stile o utilizzare la sintassi Class.Property per specificare la proprietà –

+0

Grazie per questi, li esaminerò a breve –

6

Provare a rimuovere parte "Immagine" dalla proprietà = "Image.Visibility" in modo da avere:

<Setter Property="Visibility" Value="Hidden"/> 

e aggiungere TargetType al vostro stile :

<Style TargetType="{x:Type Image}"> 
4

ho appena fatto qualcosa di simi lar usando un ContentControl.

<ContentControl Content="{Binding CurrentListHasPendingChanges}"> 
    <ContentControl.ContentTemplate> 
    <DataTemplate> 
     <Image x:Name="img" Source="..\Images\List_16.png" Margin="0,0,5,0" Visibility="Hidden" /> 
     <DataTemplate.Triggers> 
     <DataTrigger Binding="{Binding}" Value="False"> 
      <Setter Property="Image.Visibility" Value="Visible" /> 
     </DataTrigger> 
     </DataTemplate.Triggers> 
    </DataTemplate> 
    </ContentControl.ContentTemplate> 
</ContentControl> 

Da http://karlhulme.wordpress.com/2007/03/06/using-a-contentcontrol-and-datatemplate-to-indicate-new-andor-modified-data/

2

A mio parere non abbiamo bisogno di utilizzare trigger, con solo la rilegatura funziona bene. Per rendere vincolante ad un modello di proprietà, è possibile utilizzare BooleanToVisibilityConverter è dichiarato come segue:

<UserControl.Resources> 
    <BooleanToVisibilityConverter x:Key="BooleanToVisibilityConverter"/> 
</UserControl.Resources> 

E come usarlo è semplice, basta puntare alla chiave sopra indicato:

<Image HorizontalAlignment="Left" Height="16" VerticalAlignment="Center" Width="16" 
     Visibility="{Binding HasError, Converter={StaticResource BooleanToVisibilityConverter}}" 
     Source="/myPath;component/Resources/Images/image1.png"/> 

Il proprietà nel ViewModel:

private bool _hasError = false; 
    public bool HasError 
    { 
     get { return !string.IsNullOrEmpty(_messageError); } 
     set 
     { 
      _hasError = value;     
      this.NotifyOfPropertyChange(() => this.HasError); 
     } 
    }