在使用数据模板样式选择器时,不能设置ItemContainerStyle的属性值,如果设置了该值,那么数据模板样式选择器会失去作用。
在使用数据模板样式选择器时,首先要创建数据模板样式选择器对象,此对象要重写StyleSelector基类的SelectStyle方法,并在方法中返回相应的样式,CS代码如下:
public
class
ListViewItemStyleselector:StyleSelector
{
public Style Style1 { get ; set ; } // 这个可以换成背景色,边框色等等
public Style Style2 { get ; set ; }
public override Style SelectStyle( object item, System.Windows.DependencyObject container)
{
ListView listView = ItemsControlFromItemContainer(container) as ListView;
int index = listView.ItemContainerGenerator.IndexFromContainer(container);
if (index % 2 == 0 )
{
return Style1 ;
}
else
{
return Style2 ;
}
}
}
{
public Style Style1 { get ; set ; } // 这个可以换成背景色,边框色等等
public Style Style2 { get ; set ; }
public override Style SelectStyle( object item, System.Windows.DependencyObject container)
{
ListView listView = ItemsControlFromItemContainer(container) as ListView;
int index = listView.ItemContainerGenerator.IndexFromContainer(container);
if (index % 2 == 0 )
{
return Style1 ;
}
else
{
return Style2 ;
}
}
}
在创建完成数据模板样式选择器后,就可以在XAML中调用数据模板样式选择器了,代码如下:
<
ListView.ItemContainerStyleSelector
>
< local:styleselector Style1 =" {StaticResource style1} " Style2 =" {StaticResource style2} " >
</ local:styleselector >
</ ListView.ItemContainerStyleSelector >
< local:styleselector Style1 =" {StaticResource style1} " Style2 =" {StaticResource style2} " >
</ local:styleselector >
</ ListView.ItemContainerStyleSelector >
示例中的两个样式XAML代码如下:
View Code
<
Style
x:Key
="style1"
>
< Setter Property ="Control.Padding" Value ="0" />
< Setter Property ="Control.Background" Value ="Chocolate" />
< Style.Triggers >
< Trigger Property ="ListBoxItem.IsSelected" Value ="True" >
< Setter Property ="ListBoxItem.Background" Value ="YellowGreen" />
</ Trigger >
</ Style.Triggers >
</ Style >
< Style x:Key ="style2" >
< Setter Property ="Control.Padding" Value ="0" />
< Setter Property ="Control.Background" Value ="Green" />
< Style.Triggers >
< Trigger Property ="ListBoxItem.IsSelected" Value ="True" >
< Setter Property ="ListBoxItem.Background" Value ="YellowGreen" />
</ Trigger >
</ Style.Triggers >
</ Style >
< Setter Property ="Control.Padding" Value ="0" />
< Setter Property ="Control.Background" Value ="Chocolate" />
< Style.Triggers >
< Trigger Property ="ListBoxItem.IsSelected" Value ="True" >
< Setter Property ="ListBoxItem.Background" Value ="YellowGreen" />
</ Trigger >
</ Style.Triggers >
</ Style >
< Style x:Key ="style2" >
< Setter Property ="Control.Padding" Value ="0" />
< Setter Property ="Control.Background" Value ="Green" />
< Style.Triggers >
< Trigger Property ="ListBoxItem.IsSelected" Value ="True" >
< Setter Property ="ListBoxItem.Background" Value ="YellowGreen" />
</ Trigger >
</ Style.Triggers >
</ Style >