첨부 실행 코드는 나눔고딕코딩 폰트를 사용합니다.
유용한 소스 코드가 있으면 icodebroker@naver.com으로 보내주시면 감사합니다.
블로그 자료는 자유롭게 사용하세요.

■ GridView 클래스 : GetGroupSummaryValues 메소드를 사용해 그룹 SUMMARY 값 구하기

------------------------------------------------------------------------------------------------------------------------


TestProject.zip


MainForm.cs

 

 

using System;

using System.Collections;

using System.Drawing;

 

using DevExpress.Data;

using DevExpress.Utils;

using DevExpress.XtraEditors;

using DevExpress.XtraGrid;

using DevExpress.XtraGrid.Views.Grid;

 

namespace TestProject

{

    /// <summary>

    /// 메인 폼

    /// </summary>

    public partial class MainForm : XtraForm

    {

        //////////////////////////////////////////////////////////////////////////////////////////////////// Constructor

        ////////////////////////////////////////////////////////////////////////////////////////// Public

 

        #region 생성자 - MainForm()

 

        /// <summary>

        /// 생성자

        /// </summary>

        public MainForm()

        {

            InitializeComponent();

 

            this.gridView.InitializeView

            (

                true,                          // Multi Select

                GridMultiSelectMode.RowSelect, // Grid Multi Select Mode

                DrawFocusRectStyle.CellFocus,  // Draw Focus Rect Style

                true,                          // Show Indicator

                true,                          // Show Column Headers

                true,                          // Allow Column Moving

                true,                          // Allow Column Resizing

                true,                          // Allow Filter

                true,                          // Allow Sort

                false,                         // Allow Cell Merge

                EditorShowMode.Default,        // Editor Show Mode

                false                          // Editable

            );

 

            this.gridView.OptionsBehavior.AutoPopulateColumns = true;

 

            this.gridView.OptionsBehavior.AutoExpandAllGroups = true;

 

            this.gridView.OptionsView.ShowGroupPanel = true;

 

            this.gridView.OptionsView.ShowGroupedColumns = true;

 

            this.gridView.OptionsView.GroupFooterShowMode = GroupFooterShowMode.VisibleAlways;

 

            this.gridControl.DataSource = new nwindDataSetTableAdapters.OrdersTableAdapter().GetData();

 

            this.gridView.Columns["OrderDate"].GroupIndex = 0;

 

            #region 그리드 그룹 SUMMARY 항목을 추가한다.

 

            GridGroupSummaryItem gridGroupSummaryItem = new GridGroupSummaryItem();

 

            gridGroupSummaryItem.FieldName               = "OrderDate";

            gridGroupSummaryItem.SummaryType             = SummaryItemType.Count;

            gridGroupSummaryItem.ShowInGroupColumnFooter = gridView.Columns["OrderDate"];

            gridGroupSummaryItem.DisplayFormat           = "{0:n0}";

 

            this.gridView.GroupSummary.Add(gridGroupSummaryItem);

 

            #endregion

 

            this.gridView.BestFitColumns();

 

            this.gridView.RowStyle += gridView_RowStyle;

        }

 

        #endregion

 

        //////////////////////////////////////////////////////////////////////////////////////////////////// Method

        ////////////////////////////////////////////////////////////////////////////////////////// Private

 

        #region 그리드 뷰 행 스타일 처리하기 - gridView_RowStyle(sender, e)

 

        /// <summary>

        /// 그리드 뷰 행 스타일 처리하기

        /// </summary>

        /// <param name="sender">이벤트 발생자</param>

        /// <param name="e">이벤트 인자</param>

        private void gridView_RowStyle(object sender, RowStyleEventArgs e)

        {

            GridView gridView = sender as GridView;

 

            if(e.RowHandle >= 0 || gridView.GroupCount == 0)

            {

                return;

            }

 

            Hashtable hashTable = gridView.GetGroupSummaryValues(e.RowHandle);

 

            GridSummaryItem gridSummaryItem = gridView.GroupSummary[0];

 

            int childCount = Convert.ToInt32(hashTable[gridSummaryItem]);

 

            if(childCount > 3)

            {

                e.Appearance.BackColor = Color.FromArgb(70, Color.Red);

            }

        }

 

        #endregion

    }

}

 

------------------------------------------------------------------------------------------------------------------------

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

[DEVEXPRESS/WINFORM] GridView 클래스 : MasterRowGetChildList 이벤트를 사용해 상세 내역 동적 로드하기  (0) 2020.04.05
[DEVEXPRESS/WINFORM] GridView 클래스 : 객체 데이터 소스를 사용해 마스터-상세 관계 설정하기  (0) 2020.04.04
[DEVEXPRESS/WINFORM] GridView 클래스 : MasterRowExpanded 이벤트를 사용해 마스터 행 확장시 처리하기  (0) 2020.04.04
[DEVEXPRESS/WINFORM] GridView 클래스 : 마스터-상세 관계 설정하기  (0) 2020.04.04
[DEVEXPRESS/WINFORM] GridView 클래스 : UpdateTotalSummary 메소드를 사용해 전체 SUMMARY 업데이트 하기  (0) 2020.04.04
[DEVEXPRESS/WINFORM] GridView 클래스 : GetGroupSummaryValues 메소드를 사용해 그룹 SUMMARY 값 구하기  (0) 2020.04.04
[DEVEXPRESS/WINFORM] GridView 클래스 : GetRowSummaryItem 메소드를 사용해 SUMMARY 항목 구하기  (0) 2020.04.03
[DEVEXPRESS/WINFORM] GridView 클래스 : CustomSummaryCalculate 이벤트를 사용해 그룹 SUMMARY 커스텀 계산하기  (0) 2020.04.03
[DEVEXPRESS/WINFORM] GridColumnSummaryItem 클래스 : 전체 SUMMARY 표시하기  (0) 2020.04.03
[DEVEXPRESS/WINFORM] OptionsColumnFilter 클래스 : PopupExcelFilterGrouping 속성을 사용해 팝업 엑셀 필터 그룹 사용하기  (0) 2020.04.02
[DEVEXPRESS/WINFORM] GridView 클래스 : ShowFilterPopupDate 이벤트를 사용해 필터 팝업 엑셀 일자 표시하기  (0) 2020.04.02
Posted by 사용자 icodebroker
TAG

댓글을 달아 주세요