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

TestProject.zip
다운로드

▶ MainWindow.xaml

<Window x:Class="DS.Test.WPF.UI.Developer.Grid.CustomDataGrouping.MainWindow"
    xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
    xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
    xmlns:dxg="http://schemas.devexpress.com/winfx/2008/xaml/grid"
    Width="800"
    Height="600"
    Title="GridControl 클래스 : 커스텀 데이터 그룹핑 사용하기"
    FontFamily="나눔고딕코딩"
    FontSize="16">
    <Grid>
        <dxg:GridControl Name="gridControl"
            CustomColumnDisplayText="gridControl_CustomColumnDisplayText"
            CustomColumnGroup="gridControl_CustomColumnGroup">
            <dxg:GridControl.Columns>
                <dxg:GridColumn FieldName="ProductID"                   />
                <dxg:GridColumn FieldName="ProductName"                 />
                <dxg:GridColumn FieldName="QuantityPerUnit"             />
                <dxg:GridColumn FieldName="UnitPrice" SortMode="Custom" />
                <dxg:GridColumn FieldName="UnitsInStock"                />
            </dxg:GridControl.Columns>
            <dxg:GridControl.View>
                <dxg:TableView Name="tableView" />
            </dxg:GridControl.View>
        </dxg:GridControl>
    </Grid>
</Window>

 

728x90

 

▶ MainWindow.xaml.cs

using System;
using System.Collections;
using System.Windows;

using DevExpress.Xpf.Grid;

namespace DS.Test.WPF.UI.Developer.Grid.CustomDataGrouping
{
    /// <summary>
    /// 메인 윈도우
    /// </summary>
    public partial class MainWindow : Window
    {
        //////////////////////////////////////////////////////////////////////////////////////////////////// Constructor
        ////////////////////////////////////////////////////////////////////////////////////////// Public

        #region 생성자 - MainWindow()

        /// <summary>
        /// 생성자
        /// </summary>
        public MainWindow()
        {
            InitializeComponent();

            this.gridControl.ItemsSource = new nwindDataSetTableAdapters.ProductsTableAdapter().GetData();
        }

        #endregion

        //////////////////////////////////////////////////////////////////////////////////////////////////// Method
        ////////////////////////////////////////////////////////////////////////////////////////// Private
        //////////////////////////////////////////////////////////////////////////////// Event

        #region 그리드 컨트롤 커스텀 컬럼 디스플레이 텍스트 처리하기 - gridControl_CustomColumnDisplayText(sender, e)

        /// <summary>
        /// 그리드 컨트롤 커스텀 컬럼 디스플레이 텍스트 처리하기
        /// </summary>
        /// <param name="sender">이벤트 발생자</param>
        /// <param name="e">이벤트 인자</param>
        private void gridControl_CustomColumnDisplayText(object sender, CustomColumnDisplayTextEventArgs e)
        {
            if(e.Column == null)
            {
                return;
            }

            if(e.Column.FieldName == "UnitPrice")
            {
                string interval = GetInterval(this.gridControl.GetGroupRowValue(e.RowHandle));

                e.DisplayText = interval;
            }
        }

        #endregion
        #region 그리드 컨트롤 커스텀 컬럼 그룹 처리하기 - gridControl_CustomColumnGroup(sender, e)

        /// <summary>
        /// 그리드 컨트롤 커스텀 컬럼 그룹 처리하기
        /// </summary>
        /// <param name="sender">이벤트 발생자</param>
        /// <param name="e">이벤트 인자</param>
        private void gridControl_CustomColumnGroup(object sender, CustomColumnSortEventArgs e)
        {
            if(e.Column != null & e.Column.FieldName == "UnitPrice")
            {
                double x = Math.Floor(Convert.ToDouble(e.Value1) / 10);
                double y = Math.Floor(Convert.ToDouble(e.Value2) / 10);

                int result = Comparer.Default.Compare(x, y);

                if(x > 9 && y > 9)
                {
                    result = 0;
                }

                e.Result = result;

                e.Handled = true;
            }
        }

        #endregion

        //////////////////////////////////////////////////////////////////////////////// Function

        #region 간격 구하기 - GetInterval(value)

        /// <summary>
        /// 간격 구하기
        /// </summary>
        /// <param name="value">값</param>
        /// <returns>간격</returns>
        private static string GetInterval(object value)
        {
            double doubleValue = Math.Floor(Convert.ToDouble(value) / 10);

            string result;

            if(doubleValue > 9)
            {
                result = string.Format(">= {0:c} ", 100);
            }
            else
            {
                result = string.Format("{0:c} - {1:c}", doubleValue * 10, (doubleValue + 1) * 10);
            }

            return result;
        }

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

댓글을 달아 주세요