zoukankan      html  css  js  c++  java
  • WPF数据模板样式选择器

    在使用数据模板样式选择器时,不能设置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 ;
    }
    }
    }

     在创建完成数据模板样式选择器后,就可以在XAML中调用数据模板样式选择器了,代码如下:

    <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>
    一只喜欢烘焙的IT喵星人
  • 相关阅读:
    Lucene学习总结之一:全文检索的基本原理
    Solr学习和总结(线下1)
    HBase学习系列
    Hadoop家族系列文章
    SQL on Hadoop系统的最新进展(1)
    【转】redis数据库入门教程(全面详细)+面试问题
    Redis(1.3)Redis的基本特性(事务、多数据库)
    (5.15)mysql高可用系列——mysql mha实践
    Redis(1.2)Redis的数据结构与基本操作
    mysql函数使用报错
  • 原文地址:https://www.cnblogs.com/CherryGhost/p/2062387.html
Copyright © 2011-2022 走看看