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

■ RepositoryItemButtonEdit 클래스 : 내장 에디터 사용하기

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


TestProject.zip


MainForm.cs

 

 

using System.ComponentModel;

using System.Windows.Forms;

 

using DevExpress.Data;

using DevExpress.Utils;

using DevExpress.XtraEditors;

using DevExpress.XtraEditors.Controls;

using DevExpress.XtraEditors.Repository;

using DevExpress.XtraGrid.Columns;

using DevExpress.XtraGrid.Views.Grid;

 

namespace TestProject

{

    /// <summary>

    /// 메인 폼

    /// </summary>

    public partial class MainForm : XtraForm

    {

        //////////////////////////////////////////////////////////////////////////////////////////////////// Field

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

 

        #region Field

 

        /// <summary>

        /// 저장소 항목 버튼 에디터

        /// </summary>

        private RepositoryItemButtonEdit repositoryItemButtonEdit;

 

        #endregion

 

        //////////////////////////////////////////////////////////////////////////////////////////////////// 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

                true                            // Editable

            );

 

            this.gridView.OptionsBehavior.AutoPopulateColumns = true;

            this.gridView.OptionsBehavior.EditingMode         = GridEditingMode.EditFormInplace;

            this.gridView.OptionsEditForm.ShowOnDoubleClick   = DefaultBoolean.False;

            this.gridView.OptionsEditForm.ShowOnEnterKey      = DefaultBoolean.False;

            this.gridView.OptionsEditForm.ShowOnF2Key         = DefaultBoolean.False;

 

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

 

            this.gridView.BestFitColumns();

 

            #region 저장소 항목 버튼 에디터를 설정한다.

 

            this.repositoryItemButtonEdit = new RepositoryItemButtonEdit

            {

                Name          = "repositoryItemButtonEdit",

                AutoHeight    = false,

                TextEditStyle = TextEditStyles.HideTextEditor

            };

 

            this.repositoryItemButtonEdit.Buttons.Clear();

 

            this.repositoryItemButtonEdit.Buttons.AddRange

            (

                new EditorButton[]

                {

                    new EditorButton

                    (

                        ButtonPredefines.Glyph,

                        "Edit",

                        -1,

                        true,

                        true,

                        false,

                        ImageLocation.MiddleLeft,

                        Properties.Resources.edit

                    ),

                    new EditorButton

                    (

                        ButtonPredefines.Glyph,

                        "Delete",

                        -1,

                        true,

                        true,

                        false,

                        ImageLocation.MiddleLeft,

                        Properties.Resources.delete

                    )

                }

            );

 

            #endregion

            #region 명령 컬럼을 설정한다.

 

            GridColumn commandColumn = this.gridView.Columns.AddField("Command");

 

            commandColumn.UnboundType             = UnboundColumnType.Object;

            commandColumn.Visible                 = true;

            commandColumn.Width                   = 150;

            commandColumn.OptionsEditForm.Visible = DefaultBoolean.False;

 

            #endregion

 

            this.gridView.ShowingEditor               += gridView_ShowingEditor;

            this.gridView.CustomRowCellEdit           += gridView_CustomRowCellEdit;

            this.gridView.CustomRowCellEditForEditing += gridView_CustomRowCellEditForEditing;

            this.repositoryItemButtonEdit.ButtonClick += repositoryItemButtonEdit_ButtonClick;

        }

 

        #endregion

 

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

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

 

        #region 그리드 뷰 에디터 표시시 처리하기 - gridView_ShowingEditor(sender, e)

 

        /// <summary>

        /// 그리드 뷰 에디터 표시시 처리하기

        /// </summary>

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

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

        private void gridView_ShowingEditor(object sender, CancelEventArgs e)

        {

            GridView gridView = sender as GridView;

 

            e.Cancel = gridView.FocusedColumn.FieldName != "Command";

        }

 

        #endregion

        #region 그리드 뷰 커스텀 행/셀 편집시 처리하기 - gridView_CustomRowCellEdit(sender, e)

 

        /// <summary>

        /// 그리드 뷰 커스텀 행/셀 편집시 처리하기

        /// </summary>

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

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

        private void gridView_CustomRowCellEdit(object sender, CustomRowCellEditEventArgs e)

        {

            GridView gridView = sender as GridView;

 

            if(e.RowHandle == gridView.FocusedRowHandle && e.Column.FieldName == "Command")

            {

                e.RepositoryItem = this.repositoryItemButtonEdit;

            }

        }

 

        #endregion

        #region 그리드 뷰 편집용 커스텀 행/셀 편집시 처리하기 - gridView_CustomRowCellEditForEditing(sender, e)

 

        /// <summary>

        /// 그리드 뷰 편집용 커스텀 행/셀 편집시 처리하기

        /// </summary>

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

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

        private void gridView_CustomRowCellEditForEditing(object sender, CustomRowCellEditEventArgs e)

        {

            GridView gridView = sender as GridView;

 

            if(e.RowHandle == gridView.FocusedRowHandle && e.Column.FieldName == "Command")

            {

                e.RepositoryItem = this.repositoryItemButtonEdit;

            }

        }

 

        #endregion

        #region 저장소 항목 버튼 에디터 버튼 클릭시 처리하기 - repositoryItemButtonEdit_ButtonClick(sender, e)

 

        /// <summary>

        /// 저장소 항목 버튼 에디터 버튼 클릭시 처리하기

        /// </summary>

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

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

        private void repositoryItemButtonEdit_ButtonClick(object sender, ButtonPressedEventArgs e)

        {

            switch(e.Button.Caption)

            {

                case "Edit" :

 

                    this.gridView.CloseEditor();

                    this.gridView.ShowEditForm();

 

                    break;

 

                case "Delete" :

 

                    this.gridControl.BeginInvoke

                    (

                        new MethodInvoker(() => { this.gridView.DeleteRow(this.gridView.FocusedRowHandle); })

                    );

 

                    break;

            }

        }

 

        #endregion

    }

}

 

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

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

[DEVEXPRESS/WINFORM] GridView 클래스 : ActiveEditor 속성을 사용해 활성 에디터 읽기 전용 설정하기  (0) 2020.03.28
[DEVEXPRESS/WINFORM] GridView 클래스 : ShowingEditor 이벤트를 사용해 특정 행 편집 방지하기  (0) 2020.03.28
[DEVEXPRESS/WINFORM] GridView 클래스 : EditingValue 속성을 사용해 편집시 내장 에디터 값 설정하기  (0) 2020.03.28
[DEVEXPRESS/WINFORM] GridView 클래스 : CustomRowCellEditForEditing 이벤트를 사용해 편집시 내장 에디터 동적 설정하기  (0) 2020.03.28
[DEVEXPRESS/WINFORM] GridView 클래스 : CustomRowCellEdit 이벤트를 사용해 내장 에디터 동적 설정하기  (0) 2020.03.28
[DEVEXPRESS/WINFORM] RepositoryItemButtonEdit 클래스 : 내장 에디터 사용하기  (0) 2020.03.28
[DEVEXPRESS/WINFORM] RepositoryItemProgressBar 클래스 : 내장 에디터 사용하기  (0) 2020.03.28
[DEVEXPRESS/WINFORM] GridView 클래스 : CellValueChanged 이벤트를 사용해 다른 셀 값에 근거해 셀 값 변경하기  (0) 2020.03.28
[DEVEXPRESS/WINFORM] GridView 클래스 : PostEditor 메소드를 사용해 에디터 값 강제로 업데이트 하기  (0) 2020.03.28
[DEVEXPRESS/WINFORM] GridView 클래스 : SetFocusedValue 메소드를 사용해 포커스 값 설정하기  (0) 2020.03.28
[DEVEXPRESS/WINFORM] GridView 클래스 : SetRowCellValue 메소드를 사용해 행/셀 값 설정하기  (0) 2020.03.28
Posted by 사용자 icodebroker

댓글을 달아 주세요