2009-11-25 12 views
9

Tengo una plantilla de datos que contiene una imagen que quiero ocultar si el valor de una propiedad en un ViewModel es verdadero. ¿Alguien puede decirme por qué el xaml a continuación no funciona?WPF Activación de desencadenador a la propiedad 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> 

Respuesta

3

no es que

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

?

Supongo que utiliza INotifyProptyChanged.

EDIT Hice algunos Google y creo que necesita utilizar algún tipo de plantilla para que el gatillo funcione.

ej .: 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í, implemento INotifyPropertyChanged. Cuando cambio el setter como se indicó anteriormente, aparece el siguiente error de compilación: No se puede resolver la propiedad de estilo 'Visibilidad'. Verifique que el tipo propietario sea el TargetType del estilo o use la sintaxis Class.Property para especificar la propiedad –

+0

Gracias por estos, los revisaré en breve. –

6

Prueba a eliminar parte "Imagen" de la propiedad = "Image.Visibility" por lo que tendrá:

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

y añadir TargetType a su estilo :

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

Acabo de hacer algo simi lar usando 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> 

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

2

En mi opinión, no necesitamos utilizar disparadores, con sólo la unión funciona bien. Para que la unión a un modelo de propiedad, se puede utilizar BooleanToVisibilityConverter se declara como sigue:

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

Y cómo usarlo es sencillo, basta con señalar que la clave se ha señalado anteriormente:

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

El propiedad en ViewModel:

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