GridControl常用属性
- 格式:docx
- 大小:58.11 KB
- 文档页数:15
gridcontrol绑定数据源的方法以gridcontrol绑定数据源的方法为标题,写一篇文章。
一、引言在软件开发中,常常需要使用表格展示和编辑大量的数据。
而gridcontrol是一种常见的控件,可以方便地实现数据的展示和编辑。
本文将介绍如何使用gridcontrol控件来绑定数据源,以便快速、高效地展示和编辑数据。
二、准备工作在开始使用gridcontrol之前,需要进行一些准备工作。
首先,需要在项目中引入DevExpress的相关库文件,以便使用gridcontrol 控件。
其次,需要准备好数据源,可以是数据库中的数据表,也可以是其他的数据集合。
三、绑定数据源1. 创建gridcontrol控件在窗体或用户控件中创建一个gridcontrol控件。
可以通过拖拽的方式将gridcontrol控件添加到窗体中,也可以在代码中动态创建gridcontrol控件。
2. 创建数据源对象在代码中创建数据源对象,并将数据源对象与gridcontrol控件进行绑定。
数据源对象可以是DataTable、DataSet、List等类型的对象。
3. 绑定数据源使用gridcontrol控件的DataSource属性,将数据源对象与gridcontrol控件进行绑定。
具体代码如下所示:gridControl1.DataSource = 数据源对象;四、设置列信息绑定数据源之后,需要设置gridcontrol控件的列信息,以便正确地展示和编辑数据。
可以通过代码或者设计器来设置列信息。
1. 通过代码设置列信息可以使用gridcontrol控件的Columns属性,通过代码来设置列信息。
可以设置列的显示名称、宽度、数据类型等。
具体代码如下所示:gridView1.Columns[0].Caption = "列名";gridView1.Columns[0].Width = 100;gridView1.Columns[0].ColumnEdit = new RepositoryItemTextEdit();2. 通过设计器设置列信息可以使用设计器来设置列信息。
gridcontrol设计器中format rules的用法-回复GridControl是DevExpress控件库中的一款用于显示和编辑数据的强大工具。
它提供了丰富的功能和灵活的配置选项,其中之一就是Format Rules(格式规则)。
Format Rules允许您根据特定的条件来自定义GridControl中的单元格外观,以便更好地展示数据。
本文将详细介绍GridControl设计器中Format Rules的用法,并逐步回答相关问题。
第一步:什么是Format Rules?Format Rules是一种在GridControl中自定义单元格格式和外观的机制。
它基于条件来改变单元格的背景颜色、字体颜色、字体样式等,以使数据在GridControl中更直观和易于阅读。
第二步:如何在GridControl设计器中添加Format Rules?1. 打开GridControl设计器。
您可以在Visual Studio中打开你的项目,选择GridControl所在的窗体或界面。
2. 在GridControl设计器中,选择要添加Format Rules的GridControl。
3. 在属性窗口中找到“FormatRules”选项。
您可以点击“…”按钮编辑Format Rules集合。
第三步:如何创建一个Format Rule?1. 在Format Rules集合中,点击“Add”按钮,将会弹出一个Format Rule 设计器。
2. 在设计器中,您可以定义Format Rule的名称、触发条件和应用样式。
- 名称:为Format Rule命名,以便于管理和识别。
- 触发条件:定义Format Rule触发的条件,例如:单元格的值等于某个特定值、大于/小于某个值、在指定范围内等等。
- 应用样式:定义Format Rule触发后,所应用的样式,例如:更改单元格的背景颜色、字体颜色、加粗等。
第四步:如何编辑和管理Format Rules?1. 在Format Rules集合中,选中要编辑或管理的Format Rule。
c#devExpress控件comboBoxEdit,gridControl1,label。
⼀、comboBoxEdit:下拉框属性添加项:Properties->items⼆、gridControlgridControl与Gridview的区别:前者是容器,后者为视图2)gridView属性this.gridView.IsEmpty:判断gridview是否有⾏数据。
事件FocusedRowChanged:⾏选择焦点变化时发⽣的事件,可⽤于两个gridview查询关联等。
RowCellStyle:改变⾏颜⾊private void gridViewMain_RowCellStyle(object sender, DevExpress.XtraGrid.Views.Grid.RowCellStyleEventArgs e){ DevExpress.XtraGrid.Views.Grid.GridView view = sender as DevExpress.XtraGrid.Views.Grid.GridView; if (e.RowHandle >= 0) { string category = view.GetRowCellDisplayText(e.RowHandle, view.Columns["FEEDBACK"]); if (category == "未确认接收") { e.Appearance.BackColor = Color.Firebrick;//设置⾏颜⾊ e.Appearance.BackColor2 = Color.Firebrick;//设置⾏底⾊颜⾊ e.Appearance.ForeColor = Color.White;//字体颜⾊ } }}与DataTable关联DataTable dtSelect = (DataTable)this.ucGrid_main.DataSource;//获取ucGrid_main数据源,DataTable 是显⽰界⾯ucGrid_main上已查询的数据,不是数据库的数据3)DevExpress GridView ⾃定义⾏⾼//设置GridView⾏⾼private void gridView1_CalcRowHeight(object sender, DevExpress.XtraGrid.Views.Grid.RowHeightEventArgs e){if (e.RowHandle >= 0)e.RowHeight = 35;---------------------作者:呼噜噜哟来源:CSDN原⽂:https:///u011176794/article/details/79894198版权声明:本⽂为博主原创⽂章,转载请附上博⽂链接!设置隔⾏默认颜⾊grdMain.OptionsView.EnableAppearanceEvenRow = true;grdMain.OptionsView.EnableAppearanceOddRow = true;1:去除 GridView 头上的 "Drag a column header here to group by that column"--> 点击 Run Designer -> 找到:OptionView -> 将 ShowGroupPanel :设置为 false ;DevExpress GridView控件设置默认选中的⾏颜⾊1、选择GridView ,Appearance->FocusedRow->BackColor 设置背景颜⾊2、选择GridView ,Appearance->FocusedRow->Font->ForeColor 设置字体颜⾊C# DataGridView控件清空数据完美解决⽅法想要满⾜保持原有的列,就是重新绑定之前的DataTable,然后清除DataTable中的数据,如下:DataTable dt = (DataTable)dataGridView1.DataSource;dt.Rows.Clear();dataGridView1.DataSource = dt;获取或设置是否可以合并具有相同值的相邻单元格当前的列。
ALV_GRID_CONTROL详解⼀.ALV介绍 (2)⼆.ALV GRID CONTROL (ALV⽹格控制器) (2)三.ALV GRID CONTROL 实例 (2)四、ALV GRID相关的⼏个控制结构 (3)1.字段⽬录[Field catalog] (3)2.布局控制[layout] (5)3.打印和排序,过滤控制 (6)五.编写简单的ALV程序. (6)⾸先ALV的显⽰需要有⼏个先决条件. (7)第⼀步:创建个SCREEN,在屏幕上创建个容器,CONTAINER.定义变量 (7)第⼆步: 创建ALV这个对象,它的⽗组件是那个容器. (7)第三步,获取要显⽰数据的字段⽬录. (10)第四步,设置布局 (11)第五步,排除不需要的标准按钮 (11)⽅法: (12)功能⼀:在第⼀次显⽰以后,修改字段⽬录和布局. (12)功能⼆:设置排序条件 (12)功能三:设置过滤(和排序类似) (13)功能四:选择⽅式 (13)功能五:颜⾊设置 (14)功能六:插⼊超链接 (16)功能七:把字段设置为下拉 (17)基于事件的附加功能 (18)定义事件处理类. (19)类的实现的⼀些概要代码 (20)把事件管理类注册到ALV GRID的实例事 (21)1.热点事件(单击事件) (22)2.双击事件 (22)3.添加⾃定义的按钮和响应命令 (23)4.覆盖标准的功能. (25)5.设置单元格的风格 (25)6. 控制数据变化 (27)⼀.ALV介绍The ALV Grid Control (ALV = S A P L ist V iewer)是⼀个显⽰列表的灵活的⼯具,它提供了基本功能的列表操作,也可以通过⾃定义来进⾏增强,因此可以允许你可以在⼤型的应⽤程序中使⽤.SAP提⽰: 在SAP的开发项⽬中,ALV GRID也可以作为修改和创建数据的⼀种⼯具,然⽽,⽬前这个功能只在实验计划中使⽤,还没有向客户发布.下⾯是⼀个ALV GRID的图⽚:它包括3⼤部分,⼯具栏,标题,⽤于显⽰数据的⽹格控制器.如果有必要,⽤户可以隐藏标题和⼯具栏.ALV家族包含3种ALV⼯具:简易的,两层ALV,分等级连续的列表和树形结构的ALV.⼆.ALV GRID CONTROL (ALV⽹格控制器)ALV GRID CONTROL使⽤了控制器技术以实现艺术性的屏幕显⽰,象所有的控制器⼀样,ALV GRID CONTROL通过系统中的⼀个全局的类提供了⽅法,以响应它的动作.使⽤了ABAP的对象以后,列表是通过ALV的⼀个实例(INSTANCE)来显⽰的,程序员可以使⽤ABAP对象的事件管理. 三.ALV GRID CONTROL 实例ALV GRID实例的定义,参照CL_GUI_ALV_GRID类data ALV_GRID1 type ref to cl_gui_alv_grid.ALV GRID继承结构:四、ALV GRID相关的⼏个控制结构1.字段⽬录 [Field catalog]字段⽬录是⽤来控制ALV显⽰的⽹格中每个字段的属性的,⽐如字段的顺序,对齐⽅式,可编辑状态,颜⾊,等等.常⽤的控制字段如下:(下⾯的⽰例将说明这些字段的使⽤,参考STRUCTURE LVC_S_FCAT)2.布局控制[layout]布局是⽤来控制整个ALV的⼀个布局,⽐如ALV的标题,是否可编辑,⾏颜⾊,列颜⾊.参照ALV的控制结构[LVC_S_LAYO],以后的例⼦我将详细介绍如何设置⾏颜⾊和列颜⾊. 详细的结构说明3.打印和排序,过滤控制打印的参数控制请参考结构[LVC_S_PRNT]排序的参数控制请参考结构[LVC_S_SORT]过滤的参数控制请参考结构[LVC_S_FILT]这⾥不再⼀⼀解释,进⼊中⽂版本,⾥⾯应该也有解释的,虽然⼀些不是很清楚.五.编写简单的ALV程序.⾸先这⾥就不详细介绍DIALOG的⽤法了.OO的ALV GRID必须存在于⼀个容器当中,就是FUNCTION的ALV,其实也是⼀样的,底层也是使⽤CL_GUI_ALV_GRID 这个类的.⾸先ALV的显⽰需要有⼏个先决条件.1,字段⽬录,这个是必须的,如果没有这个参数,参考⼀个数据字典也是可以的,就是参数I_STRUCTURE_NAME.2.存放数据的内表,最好内表的结构和字段⽬录是⼀致的,否则可能会出现⼀些⽆法预知的错误,当然你说我⾮要不⼀样,那也不⼀定会出现错误.我建议是最好⼀样的.这2个是必须的,布局的话,应该是可以不设置的,使⽤默认的就可以了.第⼀步:创建个SCREEN,在屏幕上创建个容器,CONTAINER.定义变量.DATA: wcl_container TYPE REF TO cl_gui_custom_container,wcl_alv TYPE REF TO cl_gui_alv_grid .*--- 存放字段⽬录的内表DATA gt_fieldcat TYPE lvc_t_fcat .*--- 布局结构DATA gs_layout TYPE lvc_s_layo .*----声明需要显⽰的内表(以SFLIGHT为例)DATA BEGIN OF gt_list OCCURS0 .INCLUDE STRUCTURE sflight .DATA END OF gt_list .第⼆步: 创建ALV这个对象,它的⽗组件是那个容器.在PBO中写⼊如下代码:PROCESS BEFORE OUTPUT .MODULE display_alv .创建DISPLAY_ALV的MODULE后,写下如下代码:MODULE display_alv OUTPUT .PERFORM display_alv .ENDMODULE . "display_alv OUTPUT在FORM DISPLAY_ALV中,判断ALV实例是否存在,如果不存在,则创建:FORM display_alv .IF wcl_alv IS INITIAL .CREATE OBJECT: wcl_containerEXPORTINGcontainer_name = 'ALV_CON'.CREATE OBJECT wcl_alvEXPORTINGi_parent = wcl_container.*-----准备获取字段⽬录PERFORM prepare_field_catalog CHANGING gt_fieldcat .*-----设置布局PERFORM prepare_layout CHANGING gs_layout .*-----显⽰alvCALL METHOD gr_alvgrid->set_table_for_first_display EXPORTING * I_BUFFER_ACTIVE =* I_CONSISTENCY_CHECK =* I_STRUCTURE_NAME =* IS_VARIANT =* I_SAVE =* I_DEFAULT = 'X'is_layout = gs_layout* IS_PRINT =* IT_SPECIAL_GROUPS =* IT_TOOLBAR_EXCLUDING =* IT_HYPERLINK =CHANGINGit_outtab = gt_list[]it_fieldcatalog = gt_fieldcat* IT_SORT =* IT_FILTER =EXCEPTIONSinvalid_parameter_combination = 1program_error = 2too_many_lines = 3OTHERS = 4 .ELSE .*----刷新alvCALL METHOD gr_alvgrid->refresh_table_display* EXPORTING* IS_STABLE =* I_SOFT_REFRESH =EXCEPTIONSfinished = 1OTHERS = 2 .IF sy-subrc <> 0.*--异常处理ENDIF.ENDIF .ENDFORM. "display_alv⽅法"set_table_for_first_display"的参数说明⽅法"REFRESH_TABLE_DISPLAY"的参数说明第三步,获取要显⽰数据的字段⽬录.有两种⽅式.1.⼿动创建FORM prepare_field_catalog CHANGING pt_fieldcat TYPE lvc_t_fcat . DATA ls_fcat type lvc_s_fcat .ls_fcat-fieldname = 'CARRID' .ls_fcat-inttype = 'C' .ls_fcat-outputlen = '3' .ls_fcat-coltext = 'Carrier ID' .ls_fcat-seltext = 'Carrier ID' .APPEND ls_fcat to pt_fieldcat .CLEAR ls_fcat .ls_fcat-fieldname = 'CONNID' .ls_fcat-ref_table = 'SFLIGHT' .ls_fcat-ref_table = 'CONNID' .ls_fcat-outputlen = '3' .ls_fcat-coltext = 'Connection ID' .ls_fcat-seltext = 'Connection ID' .APPEND ls_fcat to pt_fieldcat .ENDFORM .2.半⾃动的创建FORM prepare_field_catalog CHANGING pt_fieldcat TYPE lvc_t_fcat . DATA ls_fcat type lvc_s_fcat .CALL FUNCTION'LVC_FIELDCATALOG_MERGE'EXPORTINGi_structure_name = 'SFLIGHT'CHANGINGct_fieldcat = pt_fieldcat[]EXCEPTIONSinconsistent_interface = 1program_error = 2OTHERS = 3.IF sy-subrc <> 0.*--Exception handlingENDIF.LOOP AT pt_fieldcat INTO ls_fcat .CASE pt_fieldcat-fieldname .WHEN'CARRID' .ls_fcat-outpulen = '10' .ls_fcat-coltext = 'Airline Carrier ID' .MODIFY pt_fieldcat FROM ls_fcat .WHEN'PAYMENTSUM' .ls_fcat-no_out = 'X' .MODIFY pt_fieldcat FROM ls_fcat .ENDCASE .ENDLOOP .ENDFORM . "prepare_field_catalog第四步,设置布局FORM prepare_layout CHANGING ps_layout TYPE lvc_s_layo.ps_layout-zebra = 'X' .ps_layout-grid_title = 'Flights' .ps_layout-smalltitle = 'X' .ENDFORM. " prepare_layout第五步,排除不需要的标准按钮(可选,这个是第⼀种⽅法,还有另外⼀种,在添加⾃定义的按钮的时候介绍)在你的ALV上,如果你想排除⼀些你不想要的标准按钮,你可以把需要排除的按钮填⼊到表UI_FUNCTIONS中,然后传给set_table_for_first_display⽅法的参数"IT_TOOLBAR_EXCLUDING".这些按钮的功能码⼀般都可以通过查看类cl_gui_alv_grid的常量属性中获取到,或者⾃⼰加个断点,在after_user_command事件中.如果你要隐藏全部的⼯具条,你可以把layout中的no_toolbar设置为"X".FORM exclude_tb_functions CHANGING pt_exclude TYPE ui_functions .DATA ls_exclude TYPE ui_func.ls_exclude = cl_gui_alv_grid=>mc_fc_maximum .APPEND ls_exclude TO pt_exclude.ls_exclude = cl_gui_alv_grid=>mc_fc_minimum .APPEND ls_exclude TO pt_exclude.ls_exclude = cl_gui_alv_grid=>mc_fc_subtot .APPEND ls_exclude TO pt_exclude.ls_exclude = cl_gui_alv_grid=>mc_fc_sum .APPEND ls_exclude TO pt_exclude.ls_exclude = cl_gui_alv_grid=>mc_fc_average .APPEND ls_exclude TO pt_exclude.ls_exclude = cl_gui_alv_grid=>mc_mb_sum .APPEND ls_exclude TO pt_exclude.ls_exclude = cl_gui_alv_grid=>mc_mb_subtot .ENDFORM .⽅法:按照上⾯的步骤,⼀个ALV的DEMO基本可以创建了.下⾯我们将讲述⼀些功能.功能⼀:在第⼀次显⽰以后,修改字段⽬录和布局.在运⾏的时候,很有可能需要在显⽰之后,需要设置⼀个新的布局或者字段⽬录.有下⾯这些⽅法去实现.字段⽬录: get_frontend_fieldcatalogset_frontend_fieldcatalog布局:get_frontend_layoutset_frontend_layout使⽤这些⽅法,你在执⾏的任何时候,可以获取这些内容,然后修改他们.DATA ls_fcat TYPE lvc_s_fcat .DATA lt_fcat TYPE lvc_t_fcat .DATA ls_layout TYPE lvc_s_layo .CALL METHOD gr_alvgrid->get_frontend_fieldcatalogIMPORTINGet_fieldcatalog = lt_fcat[].LOOP AT lt_fcat INTO ls_fcat .IF ls_fcat-fieldname = 'PAYMENTSUM' .ls_fcat-no_out = space .MODIFY lt_fcat FROM ls_fcat .ENDIF .ENDLOOP .CALL METHOD gr_alvgrid->set_frontend_fieldcatalogEXPORTINGit_fieldcatalog = lt_fcat[].CALL METHOD gr_alvgrid->get_frontend_layoutIMPORTINGes_layout = ls_layout.ls_layout-grid_title = 'Flights (with Payment Sums)' .CALL METHOD gr_alvgrid->set_frontend_layoutEXPORTINGis_layout = ls_layout.功能⼆:设置排序条件有时候我们需要使⽤到数据的排序.这个可以通过填充参考结构LVC_T_SORT创建的内表来实现,这个内表中包含了排序的标准.可以传递给set_table_for_first_display这个⽅法的IT_SORT参数来初始化⼀个排序.FORM prepare_sort_table CHANGING pt_sort TYPE lvc_t_sort .DATA ls_sort TYPE lvc_s_sort .ls_sort-spos = '1' .ls_sort-fieldname = 'CARRID' .ls_sort-up = 'X' . "A to Zls_sort-down = space .APPEND ls_sort TO pt_sort .ls_sort-spos = '2' .ls_sort-fieldname = 'SEATSOCC' .ls_sort-up = space .ls_sort-down = 'X' . "Z to AAPPEND ls_sort TO pt_sort .ENDFORM. " prepare_sort_table这有2点特别的说明:1.如果这边排序的字段名,不存在于字段⽬录中,那将出现DUMP.2.排序以后,垂直的⽹格中,如果出现相同的内容,就会合并,如果要避免,请在布局中设置"no_merging"为"X" .你可以通过使⽤⽅法“get_sort_criteria” 和“set_sort_criteria”来获取和设置排序的标准.功能三:设置过滤(和排序类似)ALV的标准按钮中已经有过滤的功能,我们也可以在初始显⽰的时候就设置过滤条件.我们需要把过滤条件填充到参考表类型"LVC_T_FILT"创建的内表中.过滤条件是类似⼀个RANGES结构的.然后把这个内表传递给⽅法"SET_TABLE_FOR_FIRST_DISPLAY"中的参数"IT_FILTER"FORM prepare_filter_table CHANGING pt_filt TYPE lvc_t_filt .DATA ls_filt TYPE lvc_s_filt .ls_filt-fieldname = 'FLDATE' .ls_filt-sign = 'E' .ls_filt-option = 'BT' .ls_filt-low = '20030101' .ls_filt-high = '20031231' .APPEND ls_filt TO pt_filt .ENDFORM. " preparefiltertable我们可以使⽤"get_filter_criteria" 和"set_filter_criteria"来获取过滤条件和设置过滤条件.功能四:选择⽅式有时候,我们需要选择⼀些单元格,⾏或者列,在布局中,有个参数"SEL_MODE"可以设置我们不同的选择⽅式.下⾯是参数的介绍.和不同的地⽅.注意:1.如果你设置了ALV是可编辑的,可能会覆盖你在布局中选择⽅式的设置的.2.设置了选择⽅式以后,我们可以使⽤很多⽅法来获取⽤户的选择.⽐如"GET_SELECTED_CELLS","GET_SELECTED_CELLS_ID", "GET_SELECTED_ROWS","GET_SELECTED_COLUMNS"3.在执⾏PAI以后,⽤户所选择的单元格,⾏或者列可能丢失.你可以在PBO中,使⽤对应的SET⽅法来恢复这些选择.功能五:颜⾊设置有的时候,我们需要在ALV⽹格上绘上⼀些颜⾊.可以给特定的⾏,某个特定的列,某个特定的单元格绘制颜⾊.如果某列被设置为关键列,这列的颜⾊将被⾃动绘制,⽽不需要我们额外的指定.先介绍ALV⾥⾊码.就是颜⾊编码,4位CHAR型.Cx y z------------------------------------------Color | | || 1/0: 相反开/关1/0: 强化开/关其中C是固定的第⼀位,第⼆位代表是颜⾊编码(1到7),第三位是加强的设置,第四位是相反,个⼈理解,在强化关闭的情况下,相反的作⽤是背景和字体的变化.颜⾊编码:A)设置列的颜⾊.我们可以通过字段⽬录的"emphasize"控制字段来控制某列的颜⾊.这个字段同样是4位的CHAR型,传⼊上述的颜⾊编码.例如:LS_FCAT-EMPHASIZE = 'C701'.如果这列被设置为关键列,就是 LS_FCAT-KEY = 'X' ,那么颜⾊设置就不会起作⽤.请注意,⾃动产⽣的字段⽬录中,KEY的设置是⾃动获取的.B)设置⾏的颜⾊为某⾏设置颜⾊,是有点复杂的,我们需要在要显⽰的数据内表中增加⼀个字段,这个字段不需要在字段⽬录中存在.同样,这个字段也是4位的CHAR型,符合颜⾊编码的定义.那我们就需要这样来定义我们的数据内表:DATA BEGIN OF gt_list OCCURS0 .INCLUDE STRUCTURE SFLIGHT .DATA rowcolor(4) TYPE c .DATA END OF gt_list .很明显,填⼊颜⾊编码以后,ALV怎么知道它是我们⽤来设置颜⾊的呢,在布局中,有个控制字段"INFO_FNAME",我们可以设置这个字段来告诉ALV,我们的颜⾊字段是哪个.ps_layout-info_fname = 'ROWCOLOR'.请注意,这个字段随便你起名字,但是记住,⼀定是数据内表⾥的字段,⽽且这边设置的时候⼀定要⼤写.你可以在任何时候设置⾏的颜⾊,只需要去修改内表⾥的这个字段的值,但是记得,⼀定要刷新以后才起作⽤.C)设置单元格的颜⾊设置单元格和设置⾏的颜⾊,本质上没有什么⼤的区别,但是定位单元格需要2个参数.我们需要在数据内表中插⼊⼀个表类型的字段,这样我们的数据内表就变成了DEEP结构了,不过ALV是可以处理的.不需要担⼼.插⼊的这个表类型的类型为"LVC_T_SCOL".⾥⾯有3个参数:FNAME告诉我们你需要设置的是哪个字段,如果为空,然后直接在COLOR中设置颜⾊,就是整⾏设置为这个颜⾊.如果具体到某个单元格,必须指定是哪个字段.COLOR字段是⽤来设置颜⾊的.NOKEYCOL字段⽐较关键了.设置为关键列的⼀些字段,我们的颜⾊设置可能被覆盖.通过这个字段的设置,可以避免被关键列覆盖.同样,ALV在布局中有个字段"CTAB_FNAME"告诉我们,数据内表中,哪个字段是⽤来设置单元格的颜⾊的.DATA BEGIN OF gt_list OCCURS0 .INCLUDE STRUCTURE SFLIGHT .DATA rowcolor(4) TYPE c .DATA cellcolors TYPE lvc_t_scol .DATA END OF gt_list .DATA ls_cellcolor TYPE lvc_s_scol ....READ TABLE gt_list INDEX5 .ls_cellcolor-fname = 'SEATSOCC' .ls_cellcolor-color-col = '7' .ls_cellcolor-color-int = '1' .APPEND ls_cellcolor TO gt_list-cellcolors .MODIFY gt_list INDEX5 .注意:颜⾊设置中有优先级顺序,他们是单元格--->⾏--->列.功能六:插⼊超链接插⼊超链接是通过⼀个含有超级链接和句柄的表来实现的.这个表类型为"LVC_T_HYPE" ,句柄是⼀个INT4类型的字段,我们需要在数据显⽰的内表中,加⼊这样的字段,来告诉ALV,我们的字段指定的句柄,从⽽找到对应的超级链接.在字段⽬录中,WEB_FIELD是⽤来指定对应的句柄名的.下⾯举个例⼦来说明,我们要为字段CARRID,CONNID建⽴超级链接:⾸先,内表定义中,我们加⼊2个句柄字段:DATA BEGIN OF gt_list OCCURS0 .INCLUDE STRUCTURE SFLIGHT .DATA rowcolor(4) TYPE c .DATA cellcolors TYPE lvc_t_scol .DATA carrid_handle TYPE int4 .DATA connid_handle TYPE int4 .DATA END OF gt_list .第⼆: 建⽴⼀个超级链接内表,⾥⾯存放句柄所对应的超级链接.创建的时候注意,它参考的表类型,⼀定是"LVC_T_HYPE". FORM prepare_hyperlinks_table CHANGING pt_hype TYPE lvc_t_hype .DATA ls_hype TYPE lvc_s_hype .ls_hype-handle = '1' .ls_hype-href = '/doc/92c7786f1eb91a37f1115c8d.html /carrids/car1' .APPEND ls_hype TO pt_hype .ls_hype-handle = '2' .ls_hype-href = '/doc/92c7786f1eb91a37f1115c8d.html /carrids/car1' .APPEND ls_hype TO pt_hype .ls_hype-handle = '3' .ls_hype-href = '/doc/92c7786f1eb91a37f1115c8d.html /carrids/car1' .APPEND ls_hype TO pt_hype .ls_hype-handle = '4' .ls_hype-href = '/doc/92c7786f1eb91a37f1115c8d.html /connids/con11' .APPEND ls_hype TO pt_hype .ls_hype-handle = '5' .ls_hype-href = '/doc/92c7786f1eb91a37f1115c8d.html /connids/con12'APPEND ls_hype TO pt_hype ... ..ENDFORM .第三.通过字段⽬录FIELDCATLOG来指定相应的句柄字段.对于CARRID的field catalogLs_fieldcat-web_field = 'CARRID_HANDLE'.对于CONNID的field catalogLs_fieldcat-web_field = 'CONNID_HANDLE’.在⽅法"SET_TABLE_FOR_FIRST_DISPLAY"中把句柄内表传给参数it_hyperlink。
1、常用属性:1.1 AllowPaging:表示是否启用分页功能;若启用分页功能,则为 true;否则为 false。
默认为 false;此属性与OnPageIndexChange一起使用,当AllowPaging为false,没有翻页功能栏,即不能触发OnPageIndexChange事件;当AllowPaging为true,显示翻页功能栏,即可以触发OnPageIndexChange事件。
1.2 AllowSorting:表示是否启用排序功能;若启用排序功能,则为 true;否则为 false。
默认为 false;由于Grid控件中没有SortExpression属性,因此,与OnSort事件一起使用。
1.3 BodyPadding:表示内容区域的内边距,可以设置上下左右为“5px 5px 5px 5px”。
1.4 BodyStyle:设置列头的以及Grid的样式。
例子:BodyStyle="font-weight:bold;color:red;":设置列头为红色黑体1.5 DataKeyNames:表示数据库绑定数据的唯一标识的属性,此值能够标识此记录,通过此值找到此记录信息,例如:此记录所在行的索引值。
1.6 EnableMultiSelect:表示可以同时勾选多条记录,true为可以,false为只能勾选一条记录,此项与EnableCheckBoxSelect共同使用。
1.7 EnableRowNumber:表示是否在显示每列的序号,true为显示,false为不显示。
1.8 EnableAjax:表示启用Ajax。
1.9 EnableAlternateRowColor:启用交替行显示不同的颜色。
1.10 EnableBackgroundColor:表示是否先背景颜色,Grid的背景颜色是白色。
1.11 EnableCheckBoxSelect:表示选择框是否能够使用并显示。
由于近期要使用gridcontrol控件,整理出来,以便以后参考:1.DevExpress控件组中的GridControl控件不能使横向滚动条有效。
现象:控件中的好多列都挤在一起,列宽都变的很小,根本无法正常浏览控件单元格中的内容。
解决:gridView1.OptionsView.ColumnAutoWidth属性是true,即各列的宽度自动调整,你把它设成false,就会出现了。
2.使单元格不可编辑。
gridcontrol -->gridview -->OptionsBehavior -->Editable=false3.没有下拉滚动条事件怎么办?现象:因为需要加载大数据量数据,所以不能一次把所有数据读入datatable进行绑定,所以决定在用户进一步浏览数据时进行数据的实时加载工作,就是每当用户拉动滚动条时,多加载一些数据进入datatable.没有找到合适的滚动条事件,于是用这个事件代替了,非常合适我的需求.TopRowChanged事件.4.获取选定行,指定列单元格的内容private string GetSelectOID(){int[] pRows = this.gridView1.GetSelectedRows();if (pRows.GetLength(0) > 0)return gridView1.GetRowCellValue(pRows[0], mOIDFiledName).ToString ();elsereturn null;}//mOIDFiledName为要获取列的列名5.去除"Drag a Column Header Here To Group by that Column"属性Gridview->Option View->Show Group Panel=false,就好了6.在gridcontrol中添加checkbox复选框gridview->run designer->columns->选择要变成复选框的那一列->column edit->new(在这里可以选择很多类型)加载checkbox数据时,费了一点时间,checkbox的复选框怎么点击,一失去焦点是,选择的操作就无效了,问题就出在datatable的绑定上了,一定要绑定一个布尔的类型.代码是这样滴!private void FrmCreateLegend_Load(object sender, EventArgs e){IFeatureLayer pFeatureLayer;IDataset pDataset;string pName;DataTable pDatatable = new DataTable();pDatatable.Columns.Add("图层名称", System.Type.GetType("System.String")); pDatatable.Columns.Add("选择", System.Type.GetType("System.Boolean"));DataRow pDataRow;object[] rowArray = new object[2];for (int i = 0; i < mFeatureLayers.Count; i++){pDataRow = pDatatable.NewRow();pFeatureLayer = mFeatureLayers[i] as IFeatureLayer;rowArray[0] = ;rowArray[1] = false;pDataRow.ItemArray = rowArray;pDatatable.Rows.Add(pDataRow);}this.gridMark.DataSource = pDatatable;this.gridMark.Refresh();}注意:创建的datatable的列名一定要和gridview中的列的fieldname属性值是一个名字,不然,你会发现添加了和你绑定的datatalbe一样多的行,可是行里面却没有内容的.7.多选GridControl->GridView->属性->OptinosSelecttion->MultiSelect8.不显示子表信息当我们对DataTable建立父子关系后,将父表绑定在Grid上,会造成关系列上有加号显示,并且可以展开.如果你觉得展开的信息对你没有意义的话,是可以关掉的.这是需要修改属性属性Gridview->Option View->ShowDetailButtons=false/515214304/blog/item/dbf702c0368b7e05bf09e654.htmlbandedGridView1.Columns[1].Width =bandedGridView1.CalcColumnBestWidth(bandedGridView1.Columns[1]) + 5;bandedGridView1.Columns[2].Width =bandedGridView1.CalcColumnBestWidth(bandedGridView1.Columns[2]) + 5;bandedGridView1.Columns[3].Width =bandedGridView1.CalcColumnBestWidth(bandedGridView1.Columns[3]) + 5;bandedGridView1.Columns[0].Width = bandedGridView1.CalcColumnBestWidth(bandedGridView1.Columns[0]) + 5;。
dev的gridcontrol的用法-回复"dev的gridcontrol的用法"是指开发中使用的GridControl控件的用法。
GridControl是DevExpress开发框架中的一个重要控件,用于展示和编辑表格数据。
本文将逐步介绍GridControl的使用方法,包括创建GridControl、数据绑定、列定义和数据操作等方面。
一、创建GridControl首先,我们需要在开发环境中导入DevExpress的控件库。
在项目中直接引用DevExpress.XtraGrid的程序集即可。
然后,我们可以在代码中使用以下语句来创建一个GridControl控件:GridControl gridControl = new GridControl();二、数据绑定接下来,我们需要将数据绑定到GridControl上。
GridControl支持多种数据源,包括DataTable、List、数组等。
下面是使用DataTable作为数据源的示例代码:DataTable dataTable = new DataTable();填充dataTable的数据...gridControl.DataSource = dataTable;在数据绑定之后,GridControl会自动根据数据源的结构创建对应的列。
三、列定义GridControl可以根据数据源自动创建列,但是我们也可以手动定义列的特性,例如显示名称、数据类型、编辑控件等。
下面是一个手动定义列的示例代码:GridColumn column = new GridColumn();column.FieldName = "Name";column.Caption = "姓名";column.Visible = true;column.VisibleIndex = 0;gridControl.Columns.Add(column);通过设置GridColumn的属性,我们可以灵活地控制列的显示和行为。
pivotgridcontrol控件自定义字段计算的例子PivotGridControl控件是DevExpress公司提供的一个灵活强大的数据透视表控件,用于展示、分析和汇总大量的数据。
PivotGridControl控件允许用户根据需要自定义字段计算,以满足不同的数据分析需求。
下面将介绍一些参考内容,帮助开发者更好地理解和使用PivotGridControl控件中的自定义字段计算功能。
1. 数据源设置在使用PivotGridControl控件之前,首先需要设置数据源。
通常情况下,我们可以使用DataTable或者BindingList作为数据源。
例如,以下是设置DataTable作为数据源的一个示例:```csharpDataTable dt = new DataTable();dt.Columns.Add("Year", typeof(int));dt.Columns.Add("Quarter", typeof(string));dt.Columns.Add("Category", typeof(string));dt.Columns.Add("Sales", typeof(decimal));dt.Rows.Add(2020, "Q1", "Electronic", 1000);dt.Rows.Add(2020, "Q1", "Clothing", 2000);dt.Rows.Add(2020, "Q2", "Electronic", 1500);dt.Rows.Add(2020, "Q2", "Clothing", 2500);dt.Rows.Add(2021, "Q1", "Electronic", 1200);dt.Rows.Add(2021, "Q1", "Clothing", 2200);dt.Rows.Add(2021, "Q2", "Electronic", 1300);dt.Rows.Add(2021, "Q2", "Clothing", 2300);pivotGridControl1.DataSource = dt;```2. 字段设置设置完数据源后,我们需要设置展示在PivotGridControl中的字段。