첨부 소스 코드는 나눔고딕코딩 폰트를 사용합니다.
728x90
반응형
728x170

▶ XAML

<Grid>
    <dxg:GridControl x:Name="gridControl">
        <dxg:GridControl.Columns>
            <dxg:GridColumn
                FieldName="UserName"
                Header="User Name" />
            <dxg:GridColumn
                FieldName="RegistrationDate"
                Header="Registration Date" />
        </dxg:GridControl.Columns>
        <dxg:GridControl.View>
            <dxg:TableView
                AutoWidth="True"
                ShowFilterPopup="tableView_ShowFilterPopup" />
        </dxg:GridControl.View>
    </dxg:GridControl>
</Grid>

 

728x90

 

▶ C#

using System;
using System.Collections.Generic;

using DevExpress.Data.Filtering;
using DevExpress.Xpf.Grid;

#region 테이블 뷰 필터 팝업 보여주기 처리하기 - tableView_ShowFilterPopup(sender, e)

/// <summary>
/// 테이블 뷰 필터 팝업 보여주기 처리하기
/// </summary>
/// <param name="sender">이벤트 발생자</param>
/// <param name="e">이벤트 인자</param>
private void tableView_ShowFilterPopup(object sender, FilterPopupEventArgs e)
{
    if(e.Column.FieldName != "RegistrationDate")
    {
        return;
    }

    List<object> list = new List<object>();

    list.Add
    (
        new CustomComboBoxItem()
        {
            DisplayValue = "(All)",
            EditValue    = new CustomComboBoxItem()
        }
    );

    list.Add
    (
        new CustomComboBoxItem()
        {
            DisplayValue = "Registered in 2008",
            EditValue    = CriteriaOperator.Parse
            (
                string.Format
                (
                    "[RegistrationDate] >= #{0}# AND [RegistrationDate] < #{1}#",
                    new DateTime(2008, 1, 1).ToString("yyyy-MM-dd"),
                    new DateTime(2009, 1, 1).ToString("yyyy-MM-dd")
                )
            )
        }
    );

    list.Add
    (
        new CustomComboBoxItem()
        {
            DisplayValue = "Registered in 2009",
            EditValue    = CriteriaOperator.Parse
            (
                string.Format
                (
                    "[RegistrationDate] >= #{0}# AND [RegistrationDate] < #{1}#",
                    new DateTime(2009, 1, 1).ToString("yyyy-MM-dd"),
                    new DateTime(2010, 1, 1).ToString("yyyy-MM-dd")
                )
            )
        }
    );

    e.ComboBoxEdit.ItemsSource = list;
}

#endregion

 

728x90
반응형
그리드형(광고전용)
Posted by icodebroker

댓글을 달아 주세요