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

728x90
반응형
728x170

TestProject.zip
다운로드

▶ MainForm.cs

using System;
using System.Data.OleDb;
using System.Drawing;
using System.Windows.Forms;

using DevExpress.Skins;
using DevExpress.Utils;
using DevExpress.Utils.Drawing;
using DevExpress.Utils.Menu;
using DevExpress.XtraEditors;
using DevExpress.XtraEditors.Controls;
using DevExpress.XtraVerticalGrid;
using DevExpress.XtraVerticalGrid.Events;

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

        #region Field

        /// <summary>
        /// 연결
        /// </summary>
        private OleDbConnection connection;

        /// <summary>
        /// 메뉴 항목
        /// </summary>
        private DXMenuItem menuItem;

        #endregion

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

        #region 생성자 - MainForm()

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

            this.connection = new OleDbConnection("Provider=Microsoft.Jet.OLEDB.4.0;Data Source=nwind.mdb");

            #region 룩업 에디터를 설정한다.

            this.lookUpEdit.Properties.PopupWidth    = 320;
            this.lookUpEdit.Properties.DisplayMember = "ProductID";

            #region 제품 ID 컬럼을 추가한다.

            LookUpColumnInfo productIDColumnInfo = new LookUpColumnInfo();

            productIDColumnInfo.Caption   = "제품 ID";
            productIDColumnInfo.FieldName = "ProductID";
            productIDColumnInfo.Width     = 100;

            this.lookUpEdit.Properties.Columns.Add(productIDColumnInfo);

            #endregion
            #region 제품명 컬럼을 추가한다.

            LookUpColumnInfo productNameColumnInfo = new LookUpColumnInfo();

            productNameColumnInfo.Caption   = "제품명";
            productNameColumnInfo.FieldName = "ProductName";
            productNameColumnInfo.Width     = 200;

            this.lookUpEdit.Properties.Columns.Add(productNameColumnInfo);

            this.lookUpEdit.Properties.DataSource = Product.GetProductList(this.connection);

            #endregion

            #endregion
            #region 메뉴 항목을 설정한다.

            this.menuItem = new DXMenuItem("Test Menu");

            #endregion
            #region 속성 그리드 컨트롤을 설정한다.

            this.propertyGridControl.ActiveViewType           = PropertyGridView.Office;
            this.propertyGridControl.OptionsView.ShowRowBrick = DefaultBoolean.True;

            #endregion
            #region 이벤트를 설정한다.

            this.lookUpEdit.Properties.EditValueChanged  += lookUpEdit_Properties_EditValueChanged;
            this.propertyGridControl.CustomDrawRowBrick  += propertyGridControl_CustomDrawRowBrick;
            this.propertyGridControl.RowBrickMenuShowing += propertyGridControl_RowBrickMenuShowing;
            this.menuItem.Click                          += menuItem_Click;

            #endregion
        }

        #endregion

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

        #region 룩업 에디터 속성 편집 값 변경시 처리하기 - lookUpEdit_Properties_EditValueChanged(sender, e)

        /// <summary>
        /// 룩업 에디터 속성 편집 값 변경시 처리하기
        /// </summary>
        /// <param name="sender">이벤트 발생자</param>
        /// <param name="e">이벤트 인자</param>
        private void lookUpEdit_Properties_EditValueChanged(object sender, EventArgs e)
        {
            this.propertyGridControl.SelectedObject = this.lookUpEdit.EditValue as Product;
        }

        #endregion
        #region 속성 그리드 컨트롤 행 BRICK 커스텀 그리기 - propertyGridControl_CustomDrawRowBrick(sender, e)

        /// <summary>
        /// 속성 그리드 컨트롤 행 BRICK 커스텀 그리기
        /// </summary>
        /// <param name="sender">이벤트 발생자</param>
        /// <param name="e">이벤트 인자</param>
        private void propertyGridControl_CustomDrawRowBrick(object sender, CustomDrawRowBrickEventArgs e)
        {
            e.Handled = true;

            Size size = new Size(7, 7);

            Rectangle rectangle = RectangleHelper.GetCenterBounds(e.RowBrickInfo.BrickArea, size);

            if(e.RowBrickInfo.State == ObjectState.Normal)
            {
                e.Cache.FillRectangle(Color.Transparent, rectangle);
            }

            if(e.RowBrickInfo.State == ObjectState.Hot)
            {
                e.Cache.FillRectangle(Color.Green, rectangle);
            }

            e.Cache.DrawRectangle(rectangle, Color.DarkGray, e.RowBrickInfo.BorderThickness);
        }

        #endregion
        #region 속성 그리드 컨트롤 행 BRICK 메뉴 표시시 처리하기 - propertyGridControl_RowBrickMenuShowing(sender, e)

        /// <summary>
        /// 속성 그리드 컨트롤 행 BRICK 메뉴 표시시 처리하기
        /// </summary>
        /// <param name="sender">이벤트 발생자</param>
        /// <param name="e">이벤트 인자</param>
        private void propertyGridControl_RowBrickMenuShowing(object sender, PopupMenuShowingEventArgs e)
        {
            e.Menu.Items.Add(this.menuItem);
        }

        #endregion
        #region 메뉴 항목 클릭시 처리하기 - menuItem_Click(sender, e)

        /// <summary>
        /// 메뉴 항목 클릭시 처리하기
        /// </summary>
        /// <param name="sender">이벤트 발생자</param>
        /// <param name="e">이벤트 인자</param>
        private void menuItem_Click(object sender, EventArgs e)
        {
            XtraMessageBox.Show
            (
                this,
                "Test Menu Clicked...",
                "INFORMATION",
                MessageBoxButtons.OK,
                MessageBoxIcon.Information
            );
        }

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

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

[DEVEXPRESS/WINFORM] PropertyGridControl 클래스 : CustomPropertyDescriptors 이벤트를 사용해 속성 정렬하기  (0) 2020.05.03
[DEVEXPRESS/WINFORM] PropertyGridControl 클래스 : CustomPropertyDescriptors 이벤트를 사용해 복수 객체 속성 편집하기  (0) 2020.05.03
[DEVEXPRESS/WINFORM] PropertyGridControl 클래스 : CustomPropertyDescriptors 이벤트를 사용해 객체 속성 필터링 설정하기  (0) 2020.05.02
[DEVEXPRESS/WINFORM] PropertyGridControl 클래스 : CustomRowCreated 이벤트를 사용해 행 생성시 커스텀 설정하기  (0) 2020.05.02
[DEVEXPRESS/WINFORM] PropertyGridControl 클래스 : TabPanelCustomize 이벤트를 사용해 탭 패널 커스텀 설정하기  (0) 2020.05.02
[DEVEXPRESS/WINFORM] PropertyGridControl 클래스 : BRICK 버튼 클릭하기  (0) 2020.05.02
[DEVEXPRESS/WINFORM] PropertyGridControl 클래스 : PopupMenuShowing 이벤트를 사용해 팝업 메뉴 표시시 처리하기  (0) 2020.05.02
[DEVEXPRESS/WINFORM] PropertyGridControl 클래스 : DataSourceChanged 이벤트를 사용해 자동 생성 행 커스텀 설정하기  (0) 2020.05.02
[DEVEXPRESS/WINFORM] PropertyGridControl 클래스 : CustomPropertyDescriptors 이벤트를 사용해 특정 행 숨기기  (0) 2020.05.02
[DEVEXPRESS/WINFORM] PropertyGridControl 클래스 : SelectedObject 속성을 사용해 검사 객체 설정하기  (0) 2020.05.02
[DEVEXPRESS/WINFORM] VGridControl 클래스 : ShowPrintPreview 메소드를 사용해 인쇄 미리보기 대화 상자 표시하기  (0) 2020.05.02
Posted by 사용자 icodebroker

댓글을 달아 주세요