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

728x90
반응형
728x170

TestProject.zip
다운로드

▶ MainForm.cs

using System;
using System.IO;

using DevExpress.Utils;
using DevExpress.XtraEditors;

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

        #region Field

        /// <summary>
        /// 레이아웃 스트림
        /// </summary>
        private MemoryStream layoutStream = new MemoryStream();

        /// <summary>
        /// 접힌 상태 스트림
        /// </summary>
        private MemoryStream collapsedStateStream = new MemoryStream();

        #endregion

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

        #region 생성자 - MainForm()

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

            this.clearButton.Enabled = false;

            Load                   += Form_Load;
            this.saveButton.Click  += saveButton_Click;
            this.loadButton.Click  += loadButton_Click;
            this.clearButton.Click += clearButton_Click;
        }

        #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)
        {
            this.excelDataSource.FileName = "SalesPerson.xlsx";

            this.excelDataSource.Fill();

            this.pivotGridControl.DataSource = this.excelDataSource;
        }

        #endregion
        #region Save 버튼 클릭시 처리하기 - saveButton_Click(sender, e)

        /// <summary>
        /// Save 버튼 클릭시 처리하기
        /// </summary>
        /// <param name="sender">이벤트 발생자</param>
        /// <param name="e">이벤트 인자</param>
        private void saveButton_Click(object sender, EventArgs e)
        {
            if(this.pivotGridControl.Fields.Count > 0)
            {
                this.layoutStream.Dispose();

                this.layoutStream = new MemoryStream();

                this.pivotGridControl.SaveLayoutToStream(this.layoutStream, OptionsLayoutBase.FullLayout);

                this.collapsedStateStream.Dispose();

                this.collapsedStateStream = new MemoryStream();

                this.pivotGridControl.SaveCollapsedStateToStream(this.collapsedStateStream);

                this.clearButton.Enabled = true;
            }
        }

        #endregion
        #region Load 버튼 클릭시 처리하기 - loadButton_Click(sender, e)

        /// <summary>
        /// Load 버튼 클릭시 처리하기
        /// </summary>
        /// <param name="sender">이벤트 발생자</param>
        /// <param name="e">이벤트 인자</param>
        private void loadButton_Click(object sender, EventArgs e)
        {
            if(this.layoutStream.Length > 0 && this.collapsedStateStream.Length > 0)
            {
                this.layoutStream.Seek(0, SeekOrigin.Begin);

                this.pivotGridControl.RestoreLayoutFromStream(this.layoutStream, OptionsLayoutBase.FullLayout);

                this.collapsedStateStream.Seek(0, SeekOrigin.Begin);

                this.pivotGridControl.LoadCollapsedStateFromStream(this.collapsedStateStream);
            }
        }

        #endregion
        #region Clear 버튼 클릭시 처리하기 - clearButton_Click(sender, e)

        /// <summary>
        /// Clear 버튼 클릭시 처리하기
        /// </summary>
        /// <param name="sender">이벤트 발생자</param>
        /// <param name="e">이벤트 인자</param>
        private void clearButton_Click(object sender, EventArgs e)
        {
            if(this.layoutStream.Length > 0 && this.collapsedStateStream.Length > 0)
            {
                this.pivotGridControl.Fields.Clear();
            }
        }

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

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

[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
[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
Posted by 사용자 icodebroker

댓글을 달아 주세요