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

TestProject.zip
0.40MB

▶ MainForm.cs

using System.Drawing;
using System.Drawing.Drawing2D;

using DevExpress.Data;
using DevExpress.Utils;
using DevExpress.Utils.Drawing;
using DevExpress.XtraEditors;
using DevExpress.XtraEditors.Controls;
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.CellSelect, // 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.OptionsView.ShowFooter = true;

            this.gridView.PaintStyleName = "Flat";

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

            GridColumnSummaryItem productNameSummaryItem  = new GridColumnSummaryItem();

            productNameSummaryItem.FieldName     = "ProductName";
            productNameSummaryItem.SummaryType   = SummaryItemType.Count;
            productNameSummaryItem.DisplayFormat = "건수 : {0:n0}";

            this.gridView.Columns["ProductName"].Summary.Add(productNameSummaryItem);

            GridColumnSummaryItem unitPriceSummaryItem  = new GridColumnSummaryItem();

            unitPriceSummaryItem.FieldName     = "UnitPrice";
            unitPriceSummaryItem.SummaryType   = SummaryItemType.Max;
            unitPriceSummaryItem.DisplayFormat = "최고액 : {0:c2}";

            this.gridView.Columns["UnitPrice"].Summary.Add(unitPriceSummaryItem);

            GridColumnSummaryItem unitsInStockSummaryItem  = new GridColumnSummaryItem();

            unitsInStockSummaryItem.FieldName     = "UnitsInStock";
            unitsInStockSummaryItem.SummaryType   = SummaryItemType.Average;
            unitsInStockSummaryItem.DisplayFormat = "평균 : {0:c2}";

            this.gridView.Columns["UnitsInStock"].Summary.Add(unitsInStockSummaryItem);

            this.gridView.BestFitColumns();

            this.gridView.CustomDrawFooterCell += gridView_CustomDrawFooterCell;
        }

        #endregion

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

        #region 그리드 뷰 바닥글 셀 커스텀 그리기 - gridView_CustomDrawFooterCell(sender, e)

        /// <summary>
        /// 그리드 뷰 바닥글 셀 커스텀 그리기
        /// </summary>
        /// <param name="sender">이벤트 발생자</param>
        /// <param name="e">이벤트 인자</param>
        private void gridView_CustomDrawFooterCell(object sender, FooterCellCustomDrawEventArgs e)
        {
            Brush brush = e.Cache.GetGradientBrush(e.Bounds, Color.Wheat, Color.FloralWhite, LinearGradientMode.Vertical);

            Rectangle rectangle = e.Bounds;

            BorderPainter painter = BorderHelper.GetPainter(BorderStyles.Style3D);

            AppearanceObject borderAppearance = new AppearanceObject(e.Appearance);

            borderAppearance.BorderColor = Color.DarkGray;

            painter.DrawObject(new BorderObjectInfoArgs(e.Cache, borderAppearance, rectangle));

            rectangle.Inflate(-1, -1);

            e.Cache.FillRectangle(brush, rectangle);

            rectangle.Inflate(-2, 0);

            e.Appearance.DrawString(e.Cache, e.Info.DisplayText, rectangle);

            e.Handled = true;
        }

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

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

[DEVEXPRESS/WINFORM] GridView 클래스 : CustomDrawGroupPanel 이벤트를 사용해 그룹 패널 커스텀 그리기  (0) 2020.04.25
[DEVEXPRESS/WINFORM] GridView 클래스 : CustomDrawRowIndicator 이벤트를 사용해 행 지시자 커스텀 그리기  (0) 2020.04.25
[DEVEXPRESS/WINFORM] GridView 클래스 : CustomDrawRowFooter/CustomDrawRowFooterCell 이벤트를 사용해 그룹 FOOTER 커스텀 그리기  (0) 2020.04.25
[DEVEXPRESS/WINFORM] CardView 클래스 : CustomDrawCardFieldValue 이벤트를 사용해 카드 필드 값 커스텀 그리기  (0) 2020.04.25
[DEVEXPRESS/WINFORM] GridView 클래스 : CustomDrawGroupRow 이벤트를 사용해 그룹 행 커스텀 그리기  (0) 2020.04.25
[DEVEXPRESS/WINFORM] GridView 클래스 : CustomDrawFooterCell 이벤트를 사용해 바닥글 셀 커스텀 그리기  (0) 2020.04.25
[DEVEXPRESS/WINFORM] GridView 클래스 : CustomDrawCell 이벤트를 사용해 셀 커스텀 그리기  (0) 2020.04.25
[DEVEXPRESS/WINFORM] CardView 클래스 : CustomDrawCardFieldCaption 이벤트를 사용해 카드 필드 제목 커스텀 그리기  (0) 2020.04.25
[DEVEXPRESS/WINFORM] CardView 클래스 : CustomDrawCardCaption 이벤트를 사용해 카드 제목 커스텀 그리기  (0) 2020.04.25
[DEVEXPRESS/WINFORM] GridView 클래스 : MouseWheel 이벤트를 사용해 수평 스크롤 하기  (0) 2020.04.25
[DEVEXPRESS/WINFORM] GridView 클래스 : GetSelectedRows 메소드를 사용해 선택 행 설정하기  (0) 2020.04.25
Posted by icodebroker

댓글을 달아 주세요