첨부 실행 코드는 나눔고딕코딩 폰트를 사용합니다.
본 블로그는 광고를 포함하고 있습니다.
광고 클릭에서 발생하는 수익금은 모두 블로그 콘텐츠 향상을 위해 쓰여집니다.

728x90
반응형
728x170

TestProject.zip
다운로드

▶ MainForm.cs

using System;
using System.Globalization;

using DevExpress.XtraEditors;
using DevExpress.XtraPivotGrid;

namespace TestProject
{
    /// <summary>
    /// 메인 폼
    /// </summary>
    public partial class MainForm : XtraForm
    {
        //////////////////////////////////////////////////////////////////////////////////////////////////// Constructor
        ////////////////////////////////////////////////////////////////////////////////////////// Public

        #region 생성자 - MainForm()

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

            this.Load                                   += Form_Load;
            this.radioGroup.SelectedIndexChanged        += radioGroup_SelectedIndexChanged;
            this.pivotGridControl.CustomFieldValueCells += pivotGridControl_CustomFieldValueCells;
            this.pivotGridControl.FieldValueDisplayText += pivotGridControl_FieldValueDisplayText;
        }

        #endregion

        //////////////////////////////////////////////////////////////////////////////////////////////////// Method
        ////////////////////////////////////////////////////////////////////////////////////////// Private

        #region 폼 로드시 처리하기 - Form_Load(sender, e)

        /// <summary>
        /// 폼 로드시 처리하기
        /// </summary>
        /// <param name="sender">이벤트 발생자</param>
        /// <param name="e">이벤트 인자</param>
        private void Form_Load(object sender, EventArgs e)
        {
            ControlHelper.Initialize(this.pivotGridControl);

            this.pivotGridControl.DataSource = ControlHelper.GetDataTable();

            this.pivotGridControl.BestFit();
        }

        #endregion
        #region 라디오 그룹 선택 인덱스 변경시 처리하기 - radioGroup_SelectedIndexChanged(sender, e)

        /// <summary>
        /// 라디오 그룹 선택 인덱스 변경시 처리하기
        /// </summary>
        /// <param name="sender">이벤트 발생자</param>
        /// <param name="e">이벤트 인자</param>
        private void radioGroup_SelectedIndexChanged(object sender, EventArgs e)
        {
            this.pivotGridControl.LayoutChanged();
        }        

        #endregion
        #region 피벗 그리드 컨트롤 필드 값 셀 커스텀 설정하기 - pivotGridControl_CustomFieldValueCells(sender, e)

        /// <summary>
        /// 피벗 그리드 컨트롤 필드 값 셀 커스텀 설정하기
        /// </summary>
        /// <param name="sender">이벤트 발생자</param>
        /// <param name="e">이벤트 인자</param>
        private void pivotGridControl_CustomFieldValueCells(object sender, PivotCustomFieldValueCellsEventArgs e)
        {
            PivotGridControl pivotGridControl = sender as PivotGridControl;

            if(pivotGridControl.DataSource == null)
            {
                return;
            }

            if(this.radioGroup.SelectedIndex == 0)
            {
                return;
            }

            for(int i = e.GetCellCount(false) - 1; i >= 0; i--)
            {
                FieldValueCell cell = e.GetCell(false, i);

                if(cell == null)
                {
                    continue;
                }

                if(object.Equals(cell.Value, "Employee B") && cell.ValueType != PivotGridValueType.Total)
                {
                    e.Remove(cell);
                }
            }
        }

        #endregion
        #region 피벗 그리드 컨트롤 필드 값 디스플레이 텍스트 설정하기 - pivotGridControl_FieldValueDisplayText(sender, e)

        /// <summary>
        /// 피벗 그리드 컨트롤 필드 값 디스플레이 텍스트 설정하기
        /// </summary>
        /// <param name="sender">이벤트 발생자</param>
        /// <param name="e">이벤트 인자</param>
        private void pivotGridControl_FieldValueDisplayText(object sender, PivotFieldDisplayTextEventArgs e)
        {
            PivotGridControl pivotGridControl = sender as PivotGridControl;

            if(e.Field == pivotGridControl.Fields[ControlHelper.Month])
            {
                e.DisplayText = CultureInfo.CurrentCulture.DateTimeFormat.GetMonthName((int)e.Value);
            }
        }

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

'DevExpress > WinForm' 카테고리의 다른 글

[DEVEXPRESS/WINFORM] PivotGridControl 클래스 : CustomChartDataSourceData 이벤트를 사용해 차트 데이터 소스 데이터 커스텀 설정하기  (0) 2020.05.13
[DEVEXPRESS/WINFORM] PivotGridControl 클래스 : 차트를 사용해 피벗 그리드 데이터 시각화하기  (0) 2020.05.13
[DEVEXPRESS/WINFORM] PivotGridControl 클래스 : CustomCellValue 이벤트를 사용해 총계 숨기기  (0) 2020.05.13
[DEVEXPRESS/WINFORM] PivotGridControl 클래스 : ValueFormat/CellFormat 속성을 사용해 값 포맷하기  (0) 2020.05.13
[DEVEXPRESS/WINFORM] PivotGridControl 클래스 : SaveLayoutToStream/RestoreLayoutFromStream 메소드를 사용해 레이아웃 저장하기/복구하기  (0) 2020.05.13
[DEVEXPRESS/WINFORM] PivotGridControl 클래스 : CustomFieldValueCells 이벤트를 사용해 특정 행과 컬럼 숨기기  (0) 2020.05.11
[DEVEXPRESS/WINFORM] PivotGridControl 클래스 : ShowingCustomizationForm 이벤트를 사용해 피벗 그리드 컨트롤 옆에 Customization 폼 표시하기  (0) 2020.05.11
[DEVEXPRESS/WINFORM] PivotGridControl 클래스 : CustomFieldValueCells 이벤트를 사용해 필드 값 셀 분리하기  (0) 2020.05.11
[DEVEXPRESS/WINFORM] PivotGridControl 클래스 : EditValueChanged 이벤트를 사용해 셀 값 편집하기  (0) 2020.05.10
[DEVEXPRESS/WINFORM] PivotGridControl 클래스 : CreateDrillDownDataSourceAsync 메소드를 사용해 비동기 기본 데이터 소스 생성하기  (0) 2020.05.09
[DEVEXPRESS/WINFORM] PivotGridControl 클래스 : CustomFilterPopupItems 이벤트를 사용해 필터 드롭 다운 항목 정렬 커스텀 설정하기  (0) 2020.05.09
Posted by 사용자 icodebroker

댓글을 달아 주세요