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

728x90
반응형

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

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


TestProject.zip


MainForm.cs

 

 

using System.Windows.Forms;

 

using DevExpress.Utils;

using DevExpress.XtraEditors;

using DevExpress.XtraEditors.Repository;

using DevExpress.XtraGrid.Views.Grid;

 

namespace TestProject

{

    /// <summary>

    /// 메인 폼

    /// </summary>

    public partial class MainForm : XtraForm

    {

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

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

 

        #region Field

 

        /// <summary>

        /// 저장소 항목 진행 바

        /// </summary>

        private RepositoryItemProgressBar repositoryItemProgressBar;

 

        #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.gridControl.RepositoryItems.Add(this.repositoryItemProgressBar);

 

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

 

            this.repositoryItemProgressBar = new RepositoryItemProgressBar();

 

            this.repositoryItemProgressBar.Minimum = 0;

            this.repositoryItemProgressBar.Maximum = 200;

 

            this.gridView.Columns["UnitsInStock"].ColumnEdit = this.repositoryItemProgressBar;

 

            this.gridView.BestFitColumns();

 

            this.repositoryItemProgressBar.KeyPress += repositoryItemProgressBar_KeyPress;

        }

 

        #endregion

 

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

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

 

        #region 저장소 항목 진행 바 키 PRESS 처리하기 - repositoryItemProgressBar_KeyPress(sender, e)

 

        /// <summary>

        /// 저장소 항목 진행 바 키 PRESS 처리하기

        /// </summary>

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

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

        private void repositoryItemProgressBar_KeyPress(object sender, KeyPressEventArgs e)

        {

            int i = 0;

 

            if(this.gridView.ActiveEditor == null)

            {

                return;

            }

 

            if(e.KeyChar == '+')

            {

                i = (short)this.gridView.ActiveEditor.EditValue;

 

                if(i < 200)

                {

                    this.gridView.ActiveEditor.EditValue = (short)(i + 1);

                }

            }

 

            if(e.KeyChar == '-')

            {

                i = (short)this.gridView.ActiveEditor.EditValue;

 

                if(i > 0)

                {

                    this.gridView.ActiveEditor.EditValue = (short)(i - 1);

                }

            }

        }

 

        #endregion

    }

}

 

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

728x90
반응형

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

[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
[DEVEXPRESS/WINFORM] GridView 클래스 : GetFocusedDisplayText 메소드를 사용해 포커스 디스플레이 텍스트 구하기  (0) 2020.03.28
Posted by 사용자 icodebroker

댓글을 달아 주세요