面向对象ALV详解.doc_第1页
面向对象ALV详解.doc_第2页
面向对象ALV详解.doc_第3页
面向对象ALV详解.doc_第4页
面向对象ALV详解.doc_第5页
已阅读5页,还剩24页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

一.ALV介绍The ALV Grid Control (ALV = SAP List Viewer)是一个显示列表的灵活的工具,它提供了基本功能的列表操作,也可以通过自定义来进行增强,因此可以允许你可以在大型的应用程序中使用. 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类 dataALV_GRID1 type ref to cl_gui_alv_grid. ALV GRID继承结构:四、ALV GRID相关的几个控制结构 1.字段目录 Field catalog字段目录是用来控制ALV显示的网格中每个字段的属性的,比如字段的顺序,对齐方式,可编辑状态,颜色,等等. 常用的控制字段如下:(下面的示例将说明这些字段的使用,参考STRUCTURE LVC_S_FCAT)2ROW_POSALV 控制: 输出行 (内部使用)3COL_POSALV 控制: 输出列列的位置,第几列,例如1,2,.4FIELDNAMEALV 控制: 内部表字段的字段名称字段名称5TABNAMELVC 标签名称表名,如果是内表,是16CURRENCYALV 控制: 货币单位7CFIELDNAMEALV 控制: 参考的当前单位的字段名称8QUANTITYALV 控制: 计量单位9QFIELDNAMEALV 控制: 参考计量单位的字段名称10IFIELDNAMEALV 控制: 内部表字段的字段名称11ROUNDALV 控制: ROUND 值12EXPONENTALV 控制:流动表示的指数KEYALV 控制: 关键字段关键字段,前面变蓝色KEY_SELALV 控制: 可以被隐藏的关键列可以被隐藏的关键列15ICONALV 控制: 作为图标输出此列作为图标输出16SYMBOLALV 控制: 输出作为符号17CHECKBOXALV 控制: 作为复选框输出复选框输出18JUSTALV 控制: 对齐对齐方式:R: right justifiedL: left justifiedC: centered19LZEROALV 控制: 输出前导零X20NO_SIGNALV 控制:输出抑制符号X,不输出符号21NO_ZEROALV 控制: 为输出隐藏零X,隐藏022NO_CONVEXTALV 控制: 不考虑输出的转换退出23EDIT_MASKALV 控制: 为输出编辑掩码格式24EMPHASIZEALV 控制: 带有颜色的高亮列列的颜色25FIX_COLUMNALV 控制: 固定列26DO_SUMALV 控制: 总计列值X,合计27NO_SUMALV 控制: 没有总计列值X ,没有合计28NO_OUTALV 控制: 列没有输出X ,隐藏此列29TECHALV 控制: 技术字段X.也是隐藏,但是有点不一样30OUTPUTLENALV 控制: 列的字符宽度输出的长度31CONVEXIT转换例程32SELTEXTALV 控制: 对话功能的列标识符33TOOLTIPALV 控制: 列抬头的工具提示34ROLLNAMEALV 控制: F1 帮助的数据元素35DATATYPEABAP 字典中的数据类型ABAP 字典中的数据类型36INTTYPEABAP 数据类型(C,D,N,.)ABAP 数据类型(C,D,N,.)37INTLEN以字节计的内部长度内容的长度38LOWERCASE允许/不允许小写字母X 允许大小写39REPTEXT标题40HIER_LEVELALV 控制: 内部使用41REPREPALV 控制: 价值是补充/补充接口的选择标准42DOMNAME定义域名43SP_GROUP组代码44HOTSPOTALV 控制: 单击敏感X,下面出现下划线,响应单击45DFIELDNAMEALV 控制: 数据库中列组的字段名称46COL_IDALV 控制: 列 ID47F4AVAILABL字段有输入帮助吗X.此列有搜索帮助48AUTO_VALUEALV 控制: 自动复制值49CHECKTABLE表名50VALEXI固定值存在51WEB_FIELDALV 控制: 内部表字段的字段名称52HREF_HNDL自然数热点连接的句柄53STYLEALV 控制: 样式下面有例子会介绍,比如PUSHBUTTION54STYLE2ALV 控制: 样式55STYLE3ALV 控制: 样式56STYLE4ALV 控制: 样式57DRDN_HNDL自然数下拉的句柄58DRDN_FIELDALV 控制: 内部表字段的字段名称下拉的字段59NO_MERGING字符字段长度 1相同的值不合并60H_FTYPEALV 树控制: 功能类型 (总计,平均,最大.最小, .)61COL_OPT可选列优化的条目62NO_INIT_CH字符字段长度 163DRDN_ALIAS字符字段长度 164REF_FIELDALV 控制: 内部表字段的参考字段名称65REF_TABLEALV 控制: 内部表字段的参考表名称66TXT_FIELDALV 控制: 内部表字段的字段名称67ROUNDFIELDALV 控制: 带有 ROUND 说明的字段名称68DECIMALS_OALV 控制: 输出小数位的编号69DECMLFIELDALV 控制: 带有 DECIMALS 说明的字段名称70DD_OUTLENALV 控制: 输出字符长度71DECIMALS小数点后的位数设置小数的位数72COLTEXTALV 控制: 列标题列标题73SCRTEXT_L长字段标签74SCRTEXT_M中字段标签75SCRTEXT_S短字段标签76COLDDICTXTALV 控制: 确定 DDIC 文本参考77SELDDICTXTALV 控制: 确定 DDIC 文本参考78TIPDDICTXTALV 控制: 确定 DDIC 文本参考79EDITALV 控制: 准备输入输出状态.X可输入80TECH_COLALV 控制: 内部使用81TECH_FORMALV 控制: 内部使用82TECH_COMPALV 控制: 内部使用83HIER_CPOSALV 控制: 层次列位置84H_COL_KEY树控制: 列名称/项目名称85H_SELECT标识是否可以选择树控制中的列86DD_ROLL数据元素 (语义域)87DRAGDROPIDALV 控制: 拖&放处理拖放对象88MAC字符字段长度 189INDX_FIELD自然数90INDX_CFIEL自然数91INDX_QFIEL自然数92INDX_IFIEL自然数93INDX_ROUND自然数94INDX_DECML自然数95GET_STYLE字符字段长度 196MARK字符字段长度 12.布局控制layout 布局是用来控制整个ALV的一个布局,比如ALV的标题,是否可编辑,行颜色,列颜色.参照ALV的控制结构LVC_S_LAYO,以后的例子我将详细介绍如何设置行颜色和列颜色. 详细的结构说明字段名描述 Value rangeCWIDTH_OPT最优化宽度SPACE, XSMALLTITLE小标题,如果设置了这个字段,则标题与列标题大小一样SPACE, XGRID_TITLE标题,在网格和工具条之间最长70个字符NO_HEADERS如果被设置,列标题隐藏SPACE, XNO_HGRIDLN隐藏水平线SPACE, XNO_MERGING禁用单元格合并SPACE, XNO_ROWMARK如果被设置,选择列在选择模式为D和A的时候隐藏SPACE, XNO_TOOLBAR隐藏工具条SPACE, XNO_VGRIDLN隐藏垂直线SPACE, XSEL_MODE选择模式SPACE, A, B, C, DEXCP_CONDS合计例外SPACE, XEXCP_FNAME字段名称带有例外编码最长30个字符EXCP_LED例外作为 LEDSPACE, XEXCP_ROLLN例外文档的数据元素SPACE, XCTAB_FNAME带有复杂单元格颜色编码的字段名称最长30个字符INFO_FNAME带有简单行彩色代码的字段名称最长30个字符ZEBRA可选行颜色,如果设置了,出现了间隔色带SPACE, XNO_TOTLINE没有总计SPACE, XNUMC_TOTAL可以对NUMC字段进行合计SPACE, XTOTALS_BEF总计输出在第一行,小计在新的值之前SPACE, XSTYLEFNAME设置单元格,比如PUSHBUTTON最长30个字符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_CONTAINERTYPEREFTOCL_GUI_CUSTOM_CONTAINER,WCL_ALVTYPEREFTOCL_GUI_ALV_GRID . *- 存放字段目录的内表 DATA gt_fieldcat TYPE lvc_t_fcat . *- 布局结构 DATA gs_layout TYPE lvc_s_layo . *-声明需要显示的内表(以SFLIGHT为例) DATA BEGIN OF gt_list OCCURS 0 . 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 . 在FORM DISPLAY_ALV中,判断ALV实例是否存在,如果不存在,则创建: IF WCL_ALV IS INITIAL . CREATEOBJECT:WCL_CONTAINER EXPORTING CONTAINER_NAME=ALV_CON. CREATEOBJECTWCL_ALV EXPORTING I_PARENT=WCL_CONTAINER. *-准备获取字段目录PERFORM prepare_field_catalog CHANGING gt_fieldcat . *-设置布局PERFORM prepare_layout CHANGING gs_layout . *-显示ALVCALL METHOD gr_alvgrid-set_table_for_first_displayEXPORTING* I_BUFFER_ACTIVE =* I_CONSISTENCY_CHECK =* I_STRUCTURE_NAME =* IS_VARIANT =* I_SAVE =* I_DEFAULT = Xis_layout = gs_layout* IS_PRINT =* IT_SPECIAL_GROUPS =* IT_TOOLBAR_EXCLUDING =* IT_HYPERLINK =CHANGINGit_outtab = gt_listit_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 . 方法set_table_for_first_display的参数说明参数含义I_BUFFER_ACTIVE如果方法调用是静态的,可以设置这个标记,这表示,如果每次显示ALV都是相同的字段目录.既然这样,那么字段目录会被放到一个特殊的缓存里,这样加速了ALV的显示I_STRUCTURE_NAME输出数据参考的数据字典的结构名,例如SFLIGHT.如果指定了这个参数,字段目录会自动生成,下面的参数IT_FIELDCATALOG不需要传值.IS_VARIANT决定布局显示的变式I_SAVE决定用户是否可以保存变式:X 只能保存全局变式U 只能保存特定变式A 都可以保存SPACE 不可以保存变式I_DEFAULT决定用户是否可以定义默认的布局:X 可以定义默认布局,这个参数是默认的SPACE 不可以定义默认布局IS_LAYOUT布局参数,传递布局控制的一些信息IS_PRINT后台打印属性的参数IT_SPECIAL_GROUPS如果在字段目录中,一些字段通过SP_GROUP被分组在一起.我们就必须为这些组传递一个组的文本内表进去IT_TOOLBAR_EXCLUDING需要隐藏的标准的按钮的内表IT_HYPERLINK为每个句柄分配了超连接的内表,LVC_S_HYPE中的HREF存放了超连接的地址,HANDLE指定了句柄,使用这些句柄,你可以在GRID中使用超连接IT_ALV_GRAPHICS比较复杂,没有用过,意思好象是可以在图表中显示ALV.IT_OUTTAB输出数据存放的内表,数据都是存放在这个内表里IT_FIELDCATALOG字段目录IT_SORT排序的标准IT_FILTER过滤的标准 方法REFRESH_TABLE_DISPLAY的参数说明参数含义IS_STABLE刷新的稳定性,有2个参数,一个是行,一个是列.如果设置了相应的值,那么对应的行,或者列,在刷新的时候,将会保持稳定,就是滚动条保持不动.I_SOFT_REFRESH这个参数只是在异常情况下被使用,如果设置了这个参数,任何创建的合计,任何排序次序,任何为了显示数据而设置的过滤都将保持不变.这个是非常有意义的.例如:当然你没有修改数据内表里的数据而想刷新ALV,仅仅只是改变一下布局和字段目录.第三步,获取要显示数据的字段目录.有两种方式. 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_MERGEEXPORTINGi_structure_name = SFLIGHTCHANGINGct_fieldcat = pt_fieldcatEXCEPTIONSinconsistent_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 .第四步,设置布局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_fieldcatalog set_frontend_fieldcatalog 布局: get_frontend_layout set_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_fieldcatalog IMPORTING et_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_fieldcatalog EXPORTING it_fieldcatalog = lt_fcat .CALL METHOD gr_alvgrid-get_frontend_layout IMPORTING es_layout = ls_layout . ls_layout-grid_title = Flights (with Payment Sums) .CALL METHOD gr_alvgrid-set_frontend_layout EXPORTING is_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 Z ls_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 A APPEND 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_FILTERFORM 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可以设置我们不同的选择方式.下面是参数的介绍.和不同的地方.值模式可能的选择注释SPACE等同于B参考B默认设置A行和列的选择,无法选择单元格多行,多列用户可以使用最左边的选择按钮来选择多行B单选,不可以多选行,不可以多选单元格多行,多列C多选,可以多选行,不可以多选单元格多行,多列D单元格的选择,可以多选单元格多行,多列,任何单元格多选用户可以使用最左边的选择按钮来选择多行注意: 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),第三位是加强的设置,第四位是相反,个人理解,在强化关闭的情况下,相反的作用是背景和字体的变化.颜色编码:x颜色主要使用在1Gray-blueheaders2Light grayList bodies3yellowtotals4Blue-greenKey columns5greenPositive threshold value6redNegative threshold value7orangeControl levels A)设置列的颜色. 我们可以通过字段目录的emphasize控制字段来控制某列的颜色.这个字段同样是4位的CHAR型,传入上述的颜色编码.例如: LS_FCAT-EMPHASIZE=C701. 如果这列被设置为关键列,就是 LS_FCAT-KEY=X ,那么颜色设置就不会起作用.请注意,自动产生的字段目录中,KEY的设置是自动获取的.B)设置行的颜色 为某行设置颜色,是有点复杂的,我们需要在要显示的数据内表中增加一个字段,这个字段不需要在字段目录中存在.同样,这个字段也是4位的CHAR型,符合颜色编码的定义.那我们就需要这样来定义我们的数据内表:DATA BEGIN OF gt_list OCCURS 0 . 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 OCCURS 0 . 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 INDEX 5 . ls_cellcolor-fname = SEATSOCC . ls_cellcolor-color-col = 7 . ls_cellcolor-color-int = 1 . APPEND ls_cellcolor TO gt_list-cellcolors . MODIFY gt_list INDEX 5 .注意: 颜色设置中有优先级顺序,他们是单元格-行-列.功能六:插入超链接 插入超链接是通过一个含有超级链接和句柄的表来实现的.这个表类型为LVC_T_HYPE ,句柄是一个INT4类型的字段,我们需要在数据显示的内表中,加入这样的字段,来告诉ALV,我们的字段指定的句柄,从而找到对应的超级链接.在字段目录中,WEB_FIELD是用来指定对应的句柄名的. 下面举个例子来说明,我们要为字段CARRID,CONNID建立超级链接:首先,内表定义中,我们加入2个句柄字段:DATA BEGIN OF gt_list OCCURS 0 . 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 = /carrids/car1 . APPEND ls_hype TO pt_hype . ls_hype-handle = 2 . ls_hype-href = /carrids/car1 . APPEND ls_hype TO pt_hype . ls_hype-handle = 3 . ls_hype-href = /carrids/car1 . APPEND ls_hype TO pt_hype . ls_hype-handle = 4 . ls_hype-href = /connids/con11 .APPEND ls_hype TO pt_hype . ls_hype-handle = 5 . ls_hype-href = /connids/con12 APPEND ls_hype TO pt_hype . .ENDFORM .第三.通过字段目录FIELDCATLOG来指定相应的句柄字段. 对于CARRID的field catalog Ls_fieldcat-web_field = CARRID_HANDLE. 对于CONNID的field catalog Ls_fieldcat-web_field = CONNID_HANDLE.在方法SET_TABLE_FOR_FIRST_DISPLAY中把句柄内表传给参数it_hyperlink。第四:在数据显示的内表中,指定对应的句柄: LOOP AT gt_list. IF gt_list-carrid = XX. Gt_list-carrid_handle = 1. IF gt_list-connid = 01. Gt_list-connid_handle = 4. ENDIF. ENDIF. ENDLOOP.功能七:把字段设置为下拉有时候我们可以把一些字段设置为下拉,比如一些类型,一些字段的值是比较固定的一些值,当然,我们也可以通过搜索帮助来做,这些只是看各自的爱好和需要了. 设置为下拉,和上一篇设置超级链接是类似的,也是使用了一个内表存放了句柄和对应的值,这个表类型为LVC_T_DROP.不过传递给ALV的方式有点区别.超级链接是通过方法SET_TABLE_FOR_FIRST_DISPLAY的参数来传递的,而下拉的内表传递需要使用方法SET_DROP_DOWN_TABLE. 如果我们希望把这个列都设置为下拉,那么我们可以在字段目录中,把控制字段DRDN_HNDL指向对应的下拉内表的句柄就可以了.例如: ps_fcat-drdn_hndl = 1 .如果是某个单元格设置为下拉,那我们就需要在数据显示的内表中增加一个句柄字段(如果是有多个不同的字段需要设置下拉,可以增加多个字段),同时得在字段目录里设置

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论