您的位置:首页 > 其它

ALV GRID的参考文档 ( 1 )

2008-05-26 22:58 267 查看
SAP HELP对ALV的定义如下:The ALV grid control is a flexible tool for displaying lists. The tool provides common list operations as generic functions and can be enhanced by self-defined options。
ALV Grid控件用来创建非层次的友好的交互式报表。作为一个控件,他被安装在本地机的客户端上。
ALV Grid控件提供了典型的常用功能,比如排序,筛选和总计等。同时他也提供了自开发功能的接口。它提供了大量与excel和水晶报表的接口。
类CL_GUI_GRID用来实现ALV GRID控件的各种功能。还可以使用:REUSE_ALV….这些功能模块,来实现ALV报表。
当我们想通过ALV来实现报表时,我们通常需要准备一下几个部分:
1) List data;就是你要显示的内表。除排序功能之外,ALV GRID的控件只是读取所要显示的内表中的内容。然而,排序将会改表内表的状态。所要显示的内表可以包含任何flat type的数据。如果要显示deep type的数据,那可能就要设定ALV GRID的某些特定功能。
2) Field Catalog: 使用另外一个内表来定义ALV报表的每一个字段的显示方式。Field catalog可以通过三种方式来实现:自动生成,半自动和手动生成。这个内表的类型必须是LVC_T_FCAT
3) Layout Structure: 我们可以通过这个结构来设置ALV的显示格式。用这个结构我们可以用来设置ALV的常用选项,对GRID控件的配置,汇总选项已经颜色等。这个结构的类型必须是LVC_S_LAYO
4) Event Handler: 如果我们想在alv grid中触发时间,可以通过事件处理类来实现,必须注册一个事件处理类的实例来处理alv grid的事件。
5) Additional data: 通过alv其他的一些参数可以用来设置alv grid的其它的一些特征。例如设置初始的排序顺序,把某些按钮置为非激活状态等。
下面我们来简单看一下alv的实现步骤,作为一个控件对象必须有一个容器来实现与屏幕的连接。我们用cl_gui_custom_container这个类的实例来实现这个目的。另外还有一些其他类的实例也可能会用到,比如cl_gui_docking_container,cl_gui_dialogbox_container。首先我们要在屏幕上创建custome control区域。
下面简单描述一下ALV GRID的创建过程;
1. 在屏幕上创建custom control区域,比如我们把这个区域的名字定位cc_alv



1. 定义alv grid的全局变量
2. *--GLOBAL DATA DEFINITIONS FOR ALV
*--- ALV GRID instance reference
DATA: gr_alvgrid TYPE REF TO cl_gui_alv_grid.
*--- Name of the custome control added on the screen
DATA: gc_custome_control_name TYPE scrfname VALUE 'CC_ALV'.
*-- Custome container instance reference
DATA: gr_container TYPE REF TO cl_gui_custom_container.
*-- Field catalog table
DATA gt_fieldcat TYPE lvc_t_fcat.
*-- Layout structure
DATA gs_layout TYPE lvc_s_layo.声明用来创建容纳显示内容的内表
3. 根据自己的具体需求把取出来的数据放到内表中
4. 建立PBO MODULE用来创建ALV GRID的实例
PROCESS BEFORE OUTPUT.
* MODULE STATUS_0100.
MODULE display_alv.
MODULE display_alv OUTPUT.
PERFORM display_alv.
ENDMODULE.
5. 下面是显示alv的主要步骤,先检查一下alv容器的实例是否存在,如果存在的话就把刷新,否则的话就创建它,并调用显示alv的方法。
FORM display_alv.
IF gr_alvgrid IS INITIAL.
CREATE OBJECT GR_CONTAINER
EXPORTING
CONTAINER_NAME = gc_custome_control_name
EXCEPTIONS
CNTL_ERROR = 1
CNTL_SYSTEM_ERROR = 2
CREATE_ERROR = 3
LIFETIME_ERROR = 4
LIFETIME_DYNPRO_DYNPRO_LINK = 5
others = 6.
IF SY-SUBRC <> 0.

ENDIF.
CREATE OBJECT GR_ALVGRID
EXPORTING
I_PARENT = GR_CONTAINER
EXCEPTIONS
ERROR_CNTL_CREATE = 1
ERROR_CNTL_INIT = 2
ERROR_CNTL_LINK = 3
ERROR_DP_CREATE = 4
others = 5.
IF SY-SUBRC <> 0.

ENDIF.
*-- preparing field catalog
* PERFORM prepare_fieldcatalog CHANGING gt_fieldcat.
*-- preparing layout structure
* PERFORM prepare_layout CHANGING gs_layout.
*-- display alv list
CALL METHOD GR_ALVGRID->SET_TABLE_FOR_FIRST_DISPLAY
EXPORTING
* I_BUFFER_ACTIVE =
* I_BYPASSING_BUFFER =
* 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 =
* IT_ALV_GRAPHICS =
* IT_EXCEPT_QINFO =
CHANGING
IT_OUTTAB = gt_list
IT_FIELDCATALOG = gt_fieldcat
* IT_SORT =
* IT_FILTER =
EXCEPTIONS
INVALID_PARAMETER_COMBINATION = 1
PROGRAM_ERROR = 2
TOO_MANY_LINES = 3
others = 4.
IF SY-SUBRC <> 0.
ENDIF.
ELSE.
CALL METHOD GR_ALVGRID->REFRESH_TABLE_DISPLAY
* EXPORTING
* IS_STABLE =
* I_SOFT_REFRESH =
EXCEPTIONS
FINISHED = 1
others = 2.
IF SY-SUBRC <> 0.
ENDIF.
ENDIF.
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: