首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >滤波ICollectionView和

滤波ICollectionView和
EN

Stack Overflow用户
提问于 2017-02-13 03:06:53
回答 1查看 259关注 0票数 0

假设这个基类

代码语言:javascript
复制
public class Contrat_Paye_Item 
    {
        public int     CPI_TYPE { get; set; }
        public string  CPI_TEXT { get; set; }
        public decimal CPI_AMOUNT { get; set; }
    }

在我看来,Model从该类中列出了如下列表:

代码语言:javascript
复制
private ObservableCollection<Contrat_Paye_Item> listapayer;
public ObservableCollection<Contrat_Paye_Item> ListaPayer
{
    get
    {
        return listapayer;
    }
    set
    {
        listapayer = value;
        OnPropertyChanged("ListaPayer");
    }
}

在VM构造函数中,只需要一些testdata:

代码语言:javascript
复制
 listapayer.Add(new Contrat_Paye_Item()
                    {
                        CPI_TYPE = 0,
                        CPI_TEXT = "Loyer",
                        CPI_AMOUNT = 100
                    });


listapayer.Add(new Contrat_Paye_Item()
                    {
                        CPI_TYPE = 1,
                        CPI_TEXT = "charge 1",
                        CPI_AMOUNT = 200
                    });

listapayer.Add(new Contrat_Paye_Item()
                    {
                        CPI_TYPE = 1,
                        CPI_TEXT = "Charges 2",
                        CPI_AMOUNT = 300
                    });

所以完整的列表包含3个项目,总数是600

在我的视图模型中,我添加了一个子列表,其中只包含它们的CPI_TYPE =1的项,并将其绑定到一个列表框中,没有如下问题:

代码语言:javascript
复制
   public ICollectionView ListCharges
        {
            get
            {


                var sub= new CollectionViewSource { Source = listapayer }.View;
                sub.Filter = p => (p as Contrat_Paye_Item).CPI_TYPE == 1;
                return sub;
            }
        }

现在我要显示的是我的项目列表,其中一行包含子列表的金额项的总和。将其绑定到第二个列表框。

类似于:

loyer 100

收费500

任何想法,小费都是欢迎的。谢谢

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2017-02-13 03:39:29

在返回sub之前添加这样的内容如何:

代码语言:javascript
复制
        var d1 = (from a in sub.SourceCollection.OfType<Contrat_Paye_Item>() where a.CPI_TEXT == "Loyer" select a.CPI_AMOUNT).Sum();
        var d2 = (from a in sub.SourceCollection.OfType<Contrat_Paye_Item>() where a.CPI_TEXT.ToLower().StartsWith("charge") select a.CPI_AMOUNT).Sum();

        sub.AddNewItem(new Contrat_Paye_Item() { CPI_TEXT="Sum Loyer", CPI_AMOUNT = d1} );
        sub.CommitNew();
        sub.AddNewItem(new Contrat_Paye_Item() { CPI_TEXT = "Sum Charges", CPI_AMOUNT = d2 });
        sub.CommitNew();

//编辑

请注意,这是一种更灵活的可能性:

不要使用_CollectionViewSource _。相反,请使用以下内容作为ItemsSource的ListBox

代码语言:javascript
复制
     public ObservableCollection<Contrat_Paye_Item> ListCharges
    {
        get
        { 
            return new ObservableCollection<Contrat_Paye_Item>((from a in listapayer where a.CPI_TYPE == 1 select a));
        }
    }
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/42196058

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档