DevExpress中关于GridControl控件的一些常用属性设置方法

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using DevExpress.XtraGrid.Columns;
using DevExpress.XtraGrid.Views.Grid;
using DevExpress.XtraEditors.Repository;
using DevExpress.Utils;

namespace Tools
{
    public static class DevGridControl
    {
        /// 
        /// 设置GridView的最合适列宽
        /// 
        /// 
        public static void BestFitColumns(GridView gridView)
        {
            gridView.BeginUpdate();
            gridView.BestFitMaxRowCount = 1000;
            gridView.OptionsView.ColumnAutoWidth = false;
            int iWidth = 0;
            foreach (GridColumn pGridColumn in gridView.Columns)
            {
                if (pGridColumn.Visible == false) continue;

                pGridColumn.OptionsColumn.FixedWidth = false;
                pGridColumn.OptionsColumn.AllowSize = true;
                pGridColumn.BestFit();

                iWidth += pGridColumn.Width;
            }
            if (gridView.GridControl != null)
            {
                if (iWidth < gridView.GridControl.Width)
                {
                    gridView.OptionsView.ColumnAutoWidth = true;
                    gridView.BestFitColumns();
                }
            }
            gridView.EndUpdate();
        }
        /// 
        /// 设置GridView的基本属性,去掉右键弹出菜单,不能拖动列等属性
        /// 
        /// Grid控件
        public static void SetGridViewOptions(GridView gridView)
        {
            gridView.OptionsView.EnableAppearanceOddRow = false;
            gridView.OptionsSelection.EnableAppearanceFocusedCell = false;
            gridView.OptionsCustomization.AllowColumnMoving = false;
            gridView.OptionsCustomization.AllowGroup = false;
            gridView.OptionsCustomization.AllowFilter = false;
            gridView.OptionsCustomization.AllowSort = false;
            gridView.OptionsMenu.EnableColumnMenu = false;
            gridView.OptionsMenu.EnableFooterMenu = false;
            gridView.OptionsMenu.EnableGroupPanelMenu = false;
            gridView.OptionsView.ShowGroupPanel = false;//不显示分组
            gridView.OptionsView.EnableAppearanceEvenRow = true;
        }
        /// 
        /// 根据列名设置列隐藏
        /// 
        /// Grid控件
        /// 列名
        public static void SetGridViewColumnVisible(GridView gridView, string columnName)
        {
            SetGridViewColumnVisible(gridView, columnName, false);
        }
        /// 
        /// 根据列名设置列是否隐藏
        /// 
        /// Grid控件
        /// 列名
        /// 列是否隐藏
        public static void SetGridViewColumnVisible(GridView gridView, string columnName, bool isVisible)
        {
            gridView.Columns[columnName].Visible = isVisible;
        }
        /// 
        /// 根据列名设置列不可编辑
        /// 
        /// Grid控件
        /// 列名
        public static void SetGridViewColumnEdit(GridView gridView, string columnName)
        {
            SetGridViewColumnEdit(gridView, columnName, false);
        }
        /// 
        /// 设置所有列不可编辑
        /// 
        /// Grid控件
        public static void SetGridViewColumnEdit(GridView gridView)
        {
            if (gridView != null)
                if (gridView.Columns != null)
                    foreach (GridColumn item in gridView.Columns)
                        item.OptionsColumn.AllowEdit = false;
        }
        /// 
        /// 根据列名设置列是否可编辑
        /// 
        /// Grid控件
        /// 列名
        /// 列是否可以编辑
        public static void SetGridViewColumnEdit(GridView gridView, string columnName, bool isEdit)
        {
            gridView.Columns[columnName].OptionsColumn.AllowEdit = isEdit;
        }
        /// 
        /// 根据列名构建Grid中下拉列表
        /// 
        /// Grid控件
        /// 列名
        /// 下拉列表数据源
        /// 显示数据
        /// 实际需要的数据
        /// 数据行数
        /// 选择空显示内容
        public static RepositoryItemLookUpEdit SetGridViewColumnLookUpEdit(GridView gridView, string ColumnName, object dataSC, string DisplayMember, string ValueMember, int SCrows, string nullText = "")
        {
            try
            {
                RepositoryItemLookUpEdit repositoryItemLookUpEdit1 = new RepositoryItemLookUpEdit();
                #region 下拉列表设置
                repositoryItemLookUpEdit1.AutoHeight = false;
                //    repositoryItemLookUpEdit1.Buttons.AddRange(new DevExpress.XtraEditors.Controls.EditorButton[] {
                //new DevExpress.XtraEditors.Controls.EditorButton(DevExpress.XtraEditors.Controls.ButtonPredefines.Combo)});
                repositoryItemLookUpEdit1.Columns.AddRange(new DevExpress.XtraEditors.Controls.LookUpColumnInfo[] {
            new DevExpress.XtraEditors.Controls.LookUpColumnInfo(DisplayMember, DisplayMember)});
                repositoryItemLookUpEdit1.Name = "repositoryItemLookUpEdit1";
                repositoryItemLookUpEdit1.PopupFormMinSize = new System.Drawing.Size(22, 0);
                repositoryItemLookUpEdit1.ShowFooter = false;
                repositoryItemLookUpEdit1.NullText = nullText;
                repositoryItemLookUpEdit1.ShowHeader = false;
                repositoryItemLookUpEdit1.DataSource = dataSC;
                repositoryItemLookUpEdit1.DisplayMember = DisplayMember;
                repositoryItemLookUpEdit1.ValueMember = ValueMember;
                if (SCrows < 7)
                    repositoryItemLookUpEdit1.DropDownRows = SCrows;
                #endregion
                if (!string.IsNullOrEmpty(ColumnName))
                    gridView.Columns[ColumnName].ColumnEdit = repositoryItemLookUpEdit1;
                return repositoryItemLookUpEdit1;
            }
            catch (Exception ex)
            {
                Log.Write(ex);
            }
            return null;
        }
        /// 
        /// 根据列名和控件,构建linkButton
        /// 
        /// 表格控件
        /// 列
        /// 
        public static RepositoryItemHyperLinkEdit SetGridViewColumnLinkBtn(GridView gridView, string ColumnName)
        {
            try
            {
                RepositoryItemHyperLinkEdit repositoryItemLookUpEdit1 = new RepositoryItemHyperLinkEdit();
                repositoryItemLookUpEdit1.AutoHeight = false;
                repositoryItemLookUpEdit1.Name = "repositoryItemLookUpEdit1";
                if (!string.IsNullOrEmpty(ColumnName))
                    gridView.Columns[ColumnName].ColumnEdit = repositoryItemLookUpEdit1;
                return repositoryItemLookUpEdit1;
            }
            catch (Exception ex)
            {
                Log.Write(ex);
                return null;
            }
        }

        /// 
        /// 根据列名更新数据源
        /// 
        /// Grid控件
        /// 列名
        /// 下拉列表数据源
        /// 数据行数
        public static void SerGirdViewLoookUpEditSc(GridView gridView, string ColumnName, object dataSC, int SCrows)
        {
            if (gridView.Columns[ColumnName].ColumnEdit is RepositoryItemLookUpEdit)
            {
                ((RepositoryItemLookUpEdit)gridView.Columns[ColumnName].ColumnEdit).DataSource = dataSC;
                if (SCrows < 7)
                    ((RepositoryItemLookUpEdit)gridView.Columns[ColumnName].ColumnEdit).DropDownRows = SCrows;
            }
        }

        /// 
        /// 向GridView添加列
        /// 
        /// 
        /// 显示名称与绑定字段字典
        public static void AddGridViewColumns(GridView gridView, Dictionary nameAndFieldDic)
        {
            foreach (var item in nameAndFieldDic)
            {
                GridColumn gc = new GridColumn();
                gc.Caption = item.Key;
                gc.FieldName = item.Value;
                gc.Name = "gridColumn" + item;
                gc.Visible = true;
                //gc.VisibleIndex = _visibleIndex++;
                gc.OptionsColumn.AllowSort = DevExpress.Utils.DefaultBoolean.False;
                gc.OptionsColumn.AllowMove = false;
                gc.OptionsColumn.AllowEdit = false;
                gridView.Columns.Add(gc);
            }
        }

        /// 
        /// 向GridView添加列
        /// 
        /// 
        /// 列名数组
        public static void AddGridViewColumns(GridView gridView, string[] columnNames)
        {
            foreach (var item in columnNames)
            {
                GridColumn gc = new GridColumn();
                gc.Caption = item;
                gc.FieldName = item;
                gc.Name = "gridColumn" + item;
                gc.Visible = true;
                //gc.VisibleIndex = _visibleIndex++;
                gc.OptionsColumn.AllowSort = DevExpress.Utils.DefaultBoolean.False;
                gc.OptionsColumn.AllowMove = false;
                gc.OptionsColumn.AllowEdit = false;
                gridView.Columns.Add(gc);
            }
        }
        /// 
        /// 根据列名设置列的标题和单元的水平对齐方式
        /// 
        /// 
        /// 
        /// 列单元水平对齐方式
        /// 列标题水平对齐方式
        public static void SetGridViewColumnHAlignment(GridView gridView, string columnName, HorzAlignment cellHorzAlignment,HorzAlignment headerHorzAlignment)
        {
            gridView.Columns[columnName].AppearanceCell.TextOptions.HAlignment = cellHorzAlignment;
            gridView.Columns[columnName].AppearanceHeader.TextOptions.HAlignment = headerHorzAlignment;
        }
        /// 
        /// 设置所有列的标题和单元的水平对齐方式
        /// 
        /// 
        /// 列单元水平对齐方式
        /// 列标题水平对齐方式
        public static void SetGridViewHAlignment(GridView gridView,HorzAlignment cellHorzAlignment, HorzAlignment headerHorzAlignment)
        {
            if (gridView != null)
            {
                if (gridView.Columns != null)
                {
                    foreach (GridColumn item in gridView.Columns)
                    {
                        item.AppearanceCell.TextOptions.HAlignment = cellHorzAlignment;
                        item.AppearanceHeader.TextOptions.HAlignment = headerHorzAlignment;
                    }
                }
            }

        }
    }
}


你可能感兴趣的:(C#,.NET,DevExpress)