Veuillez essayer d'utiliser le sélecteur de modèle dans ce cas.
XAML page Ressources changements
<DataTemplate x:Key="T1">
<Rectangle Fill="Tomato" Width="50" Height="50"></Rectangle>
</DataTemplate>
<DataTemplate x:Key="T2">
<Rectangle Fill="Green" Width="50" Height="50"></Rectangle>
</DataTemplate>
<DataTemplate x:Key="T3">
<Rectangle Fill="Blue" Width="50" Height="50"></Rectangle>
</DataTemplate>
<gridbackgroundProblemSoHelpAttempt:MyTemplateSelector x:Key="MyTemplateSelector"
ADataTemplate="{StaticResource T1}"
BDataTemplate="{StaticResource T2}"
CDataTemplate="{StaticResource T3}"/>
Xaml changements ListView (s'il vous plaît noter que le SampleItems est un ObservableCollection d'objets SampleItem)
<ListView ItemsSource="{Binding SampleItems}" ItemTemplateSelector="{StaticResource MyTemplateSelector}"/>
Code MyTemplateSelector
public class MyTemplateSelector : DataTemplateSelector
{
public DataTemplate ADataTemplate { get; set; }
public DataTemplate BDataTemplate { get; set; }
public DataTemplate CDataTemplate { get; set; }
public override DataTemplate SelectTemplate(object item, DependencyObject container)
{
var si = item as SampleItem;
if (si == null) return null;
var key = si.ItemTemplateName;
switch (key)
{
case "A":
{
return ADataTemplate;
}
break;
case "B":
{
return BDataTemplate;
}
break;
case "C":
{
return CDataTemplate;
}
break;
default:
throw new ArgumentOutOfRangeException();
}
}
}
page DataContext
public class MainViewModel
{
public MainViewModel()
{
SampleItems = new ObservableCollection<SampleItem>
{
new SampleItem{ItemTemplateName = "A"},
new SampleItem{ItemTemplateName = "B"},
new SampleItem{ItemTemplateName = "C"},
};
}
public ObservableCollection<SampleItem> SampleItems { get; set; }
}
Cordialement,
Dans votre position actuelle 'ListView' vous devez utiliser un' 'DataTemplate' pour ItemTemplate', alors utilisez' {{StaticResource Binding T1}} ' par exemple. Votre sens de 'ItemTemplateName' n'est pas clair. – AnjumSKhan