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

728x90
반응형
728x170

TestProject.zip
다운로드

▶ MainForm.cs

using System;
using System.Collections.Generic;

using DevExpress.XtraEditors;
using DevExpress.XtraPivotGrid;

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

        #region Field

        /// <summary>
        /// 카테고리 딕셔너리
        /// </summary>
        private Dictionary<string, string> categoryDictionary;

        /// <summary>
        /// 제품 딕셔너리
        /// </summary>
        private Dictionary<string, string> productDictionary;

        #endregion

        //////////////////////////////////////////////////////////////////////////////////////////////////// Property
        ////////////////////////////////////////////////////////////////////////////////////////// Public

        #region 카테고리 딕셔너리 - CategoryDictionary

        /// <summary>
        /// 카테고리 딕셔너리
        /// </summary>
        private Dictionary<string, string> CategoryDictionary
        {
            get
            {
                if(this.categoryDictionary == null)
                {
                    this.categoryDictionary = new Dictionary<string, string>();
                }

                return this.categoryDictionary;
            }
        }

        #endregion
        #region 제품 딕셔너리 - ProductDictionary

        /// <summary>
        /// 제품 딕셔너리
        /// </summary>
        private Dictionary<string, string> ProductDictionary
        {
            get
            {
                if(this.productDictionary == null)
                {
                    this.productDictionary = new Dictionary<string, string>();
                }

                return this.productDictionary;
            }
        }

        #endregion

        //////////////////////////////////////////////////////////////////////////////////////////////////// Constructor
        ////////////////////////////////////////////////////////////////////////////////////////// Public

        #region 생성자 - MainForm()

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

            Load                                            += Form_Load;
            this.pivotGridControl.CustomChartDataSourceData += pivotGridControl_CustomChartDataSourceData;
        }

        #endregion

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

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

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

            this.pivotGridControl.OptionsChartDataSource.ProvideRowFieldValuesAsType    = typeof(string);
            this.pivotGridControl.OptionsChartDataSource.ProvideColumnFieldValuesAsType = typeof(string);
            this.pivotGridControl.OptionsChartDataSource.ProvideCellValuesAsType        = typeof(int);

            SetDictionary();

            this.chartControl.DataSource = this.pivotGridControl;

            this.categoryNameField.CollapseAll();

            this.categoryNameField.ExpandValue("Produce");
        }

        #endregion
        #region 피벗 그리드 컨트롤 차트 데이터 소스 데이터 커스텀 설정하기 - pivotGridControl_CustomChartDataSourceData(sender, e)

        /// <summary>
        /// 피벗 그리드 컨트롤 차트 데이터 소스 데이터 커스텀 설정하기
        /// </summary>
        /// <param name="sender">이벤트 발생자</param>
        /// <param name="e">이벤트 인자</param>
        private void pivotGridControl_CustomChartDataSourceData(object sender, PivotCustomChartDataSourceDataEventArgs e)
        {
            if(e.ItemType == PivotChartItemType.RowItem)
            {
                if(e.FieldValueInfo.Field == this.categoryNameField)
                {
                    e.Value = CategoryDictionary[e.FieldValueInfo.Value.ToString()];
                }
                else if(e.FieldValueInfo.Field == this.productNameField)
                {
                    string product  = ProductDictionary[e.FieldValueInfo.Value.ToString()];
                    string category = CategoryDictionary[e.FieldValueInfo.GetHigherLevelFieldValue(this.categoryNameField).ToString()];

                    e.Value = product + '[' + category + ']';
                }
            }

            if(e.ItemType == PivotChartItemType.ColumnItem)
            {
                if(e.FieldValueInfo.ValueType == PivotGridValueType.GrandTotal)
                {
                    e.Value = "Total Sales";
                }
            }

            if(e.ItemType == PivotChartItemType.CellItem)
            {
                e.Value = Math.Round(Convert.ToDecimal(e.CellInfo.Value), 0);
            }
        }

        #endregion

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

        #region 딕셔너리 설정하기 - SetDictionary()

        /// <summary>
        /// 딕셔너리 설정하기
        /// </summary>
        private void SetDictionary()
        {
            int categoryCounter = 1;

            foreach(object value in this.categoryNameField.GetUniqueValues())
            {
                CategoryDictionary.Add(value.ToString(), "C" + categoryCounter++);
            }

            int productCounter = 1;

            foreach(object value in this.productNameField.GetUniqueValues())
            {
                ProductDictionary.Add(value.ToString(), "P" + productCounter++);
            }
        }

        #endregion
    }
}
728x90
반응형
그리드형

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

[DEVEXPRESS/WINFORM] PivotGridControl 클래스 : CustomAppearance 이벤트를 사용해 셀 모양 커스텀 설정하기  (0) 2020.05.14
[DEVEXPRESS/WINFORM] PivotGridCells 클래스 : CopySelectionToClipboard 메소드를 사용해 선택 영역 클립보드 복사하기  (0) 2020.05.14
[DEVEXPRESS/WINFORM] PivotGridControl 클래스 : ShowPrintPreview 메소드를 사용해 인쇄 미리보기 대화 상자 표시하기  (0) 2020.05.14
[DEVEXPRESS/WINFORM] PivotXlsxExportOptions 클래스 : CustomizeCell 이벤트를 사용해 내보내기 엑셀 문서에서 셀 커스텀 설정하기  (0) 2020.05.14
[DEVEXPRESS/WINFORM] PivotGridControl 클래스 : ExportToXls 메소드를 사용해 엑셀 파일로 데이터 내보내기  (0) 2020.05.14
[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
Posted by 사용자 icodebroker

댓글을 달아 주세요