SAP OOALV分割屏幕

同一个alv屏幕上显示上下两个屏幕,用于显示不同的数据。
需要用到四个对象类:
cl_gui_docking_container 屏幕容器类
cl_gui_splitter_container 分割屏幕类
cl_gui_container 屏幕容器类
cl_gui_alv_grid 屏幕对象类

显示效果如下:
在这里插入图片描述
代码如下:


TABLES: sflight.

"抬头数据输出
TYPES: BEGIN OF ty_head.
    INCLUDE TYPE scarr.
TYPES: slbox   TYPE c,
       light   TYPE icon_d,
       message TYPE string,
       END OF ty_head.

DATA: gt_head TYPE TABLE OF ty_head,
      gs_head TYPE ty_head.

"行项目数据输出
TYPES: BEGIN OF ty_item.
    INCLUDE TYPE sflight.
TYPES: slbox   TYPE c,
       light   TYPE icon_d,
       message TYPE string,
       END OF ty_item.

DATA: gt_item TYPE TABLE OF ty_item,
      gs_item TYPE ty_item.

"字段属性定义
DATA: gs_fcat TYPE lvc_s_fcat.
DATA: gt_fcat_h TYPE lvc_t_fcat,
      gt_fcat_i TYPE lvc_t_fcat.
DATA: gs_layout_h TYPE lvc_s_layo,
      gs_layout_i TYPE lvc_s_layo.
DATA: gs_variant_h TYPE disvariant,
      gs_variant_i TYPE disvariant,
      gv_colno     TYPE i.
DATA: gt_ui_func TYPE ui_functions. "隐藏alv菜单控件

DATA: ok_code TYPE sy-ucomm. "用户功能码接收
DATA: save_ok TYPE sy-ucomm. "用户功能码接收

"ALV grid
DATA: gs_dock        TYPE REF TO cl_gui_docking_container,
      gs_splitter    TYPE REF TO cl_gui_splitter_container, "分割屏幕类
      gs_container_h TYPE REF TO cl_gui_container, "抬头容器
      gs_container_i TYPE REF TO cl_gui_container, "行项目容器
      gs_grid_h      TYPE REF TO cl_gui_alv_grid, "抬头屏幕对象类
      gs_grid_i      TYPE REF TO cl_gui_alv_grid. "行项目屏幕对象类

CONSTANTS: gc_h   TYPE c VALUE 'H'. "抬头标识符
CONSTANTS: gc_i  TYPE c VALUE 'I'. "行项目标识符


"选择屏幕
SELECTION-SCREEN BEGIN OF BLOCK blk1 WITH FRAME.
SELECT-OPTIONS: s_carrid FOR sflight-carrid.
SELECTION-SCREEN END OF BLOCK blk1 .

START-OF-SELECTION.
  "取数
  PERFORM frm_select_data.

END-OF-SELECTION.
  "输出屏幕准备
  PERFORM frm_prepare_alv.
  "调用100屏幕输出
  CALL SCREEN 0100.


*&---------------------------------------------------------------------*
*& Module STATUS_0100 OUTPUT
*&---------------------------------------------------------------------*
*&
*&---------------------------------------------------------------------*
MODULE status_0100 OUTPUT.
  SET PF-STATUS 'ZSTATUS_0100'.
  SET TITLEBAR 'ZTITLE_0100'.
ENDMODULE.
*&---------------------------------------------------------------------*
*&      Module  USER_COMMAND_0100  INPUT
*&---------------------------------------------------------------------*
*       text
*----------------------------------------------------------------------*
MODULE user_command_0100 INPUT.
  save_ok = ok_code.
  CLEAR ok_code.

  CASE save_ok.
    WHEN 'ZBACK' .
      LEAVE TO SCREEN 0. "返回上一个屏幕

    WHEN 'ZCANCEL'.
      LEAVE TO SCREEN 0.

    WHEN 'EXIT'.
      LEAVE PROGRAM. "返回程序
    WHEN OTHERS.
  ENDCASE.

ENDMODULE.

*&---------------------------------------------------------------------*
*& Module INIT_ALV OUTPUT
*&---------------------------------------------------------------------*
*&
*&---------------------------------------------------------------------*
MODULE init_alv OUTPUT.

  IF gs_dock IS INITIAL.
    "屏幕分割
    PERFORM frm_split_screen.

    "创建alv grid
    PERFORM frm_create_grid.

    "显示数据
    PERFORM frm_display_alv USING gc_h gs_grid_h.
    PERFORM frm_display_alv USING gc_i gs_grid_i.

  ELSE.
    "alv 刷新
    PERFORM frm_refresh_alv USING gs_grid_h.
    PERFORM frm_refresh_alv USING gs_grid_i.
  ENDIF.



ENDMODULE.
*&---------------------------------------------------------------------*
*& Form FRM_SELECT_DATA
*&---------------------------------------------------------------------*
*& text
*&---------------------------------------------------------------------*
*& -->  p1        text
*& <--  p2        text
*&---------------------------------------------------------------------*
FORM frm_select_data .

  SELECT *
    FROM scarr
    INTO CORRESPONDING FIELDS OF TABLE gt_head
    WHERE carrid IN s_carrid.

  SELECT *
    FROM sflight
    INTO CORRESPONDING FIELDS OF TABLE gt_item
    WHERE carrid IN s_carrid.

ENDFORM.
*&---------------------------------------------------------------------*
*& Form FRM_PREPARE_ALV
*&---------------------------------------------------------------------*
*& text
*&---------------------------------------------------------------------*
*& -->  p1        text
*& <--  p2        text
*&---------------------------------------------------------------------*
FORM frm_prepare_alv .
* ALV字段属性
  PERFORM frm_build_fieldcat.

* 屏幕隐藏按钮
  PERFORM frm_build_ui_functions.

* 屏幕布局
  PERFORM frm_set_layout.

* 屏幕自定义布局参数
  PERFORM frm_set_variant.

ENDFORM.
*&---------------------------------------------------------------------*
*& Form FRM_BUILD_FIELDCAT
*&---------------------------------------------------------------------*
*& text
*&---------------------------------------------------------------------*
*& -->  p1        text
*& <--  p2        text
*&---------------------------------------------------------------------*
FORM frm_build_fieldcat .
  DEFINE m_fcat_0100.
    CLEAR gs_fcat.
    gs_fcat-fieldname = &1.
    gs_fcat-ref_field = &2.
    gs_fcat-ref_table = &3.
    gs_fcat-coltext   =
    gs_fcat-seltext   =
    gs_fcat-tooltip   =
    gs_fcat-reptext   =
    gs_fcat-scrtext_l = &4.
    gs_fcat-checkbox  = &5.
    gs_fcat-edit      = &6.
    gs_fcat-hotspot       = &7.
    gv_colno          = gv_colno + 1.
    gs_fcat-col_pos   = gv_colno.
    CASE &8.
      WHEN gc_h.
        APPEND gs_fcat TO gt_fcat_h.
      WHEN gc_i.
        APPEND gs_fcat TO gt_fcat_i.
      WHEN OTHERS.
    ENDCASE.

  END-OF-DEFINITION.


  REFRESH: gt_fcat_h.
  CLEAR: gv_colno.

* 抬头屏幕字段
*  m_fcat_0100 'SLBOX' '' '' '复选框' 'X' '' '' GC_H.
  m_fcat_0100 'CARRID' '' '' '航线代码' '' '' '' gc_h.
  m_fcat_0100 'CARRNAME' '' '' '航线名称' '' '' '' gc_h.
  m_fcat_0100 'CURRCODE' '' '' '航班的本地货币' '' '' '' gc_h.
  m_fcat_0100 'URL' '' '' '航线 URL' '' '' '' gc_h.

  REFRESH: gt_fcat_i.
  CLEAR: gv_colno.
* 行项目屏幕字段
*  m_fcat_0100 'SLBOX' '' '' '复选框' 'X' '' '' GC_I.
  m_fcat_0100 'CARRID' '' '' '航线代码' '' '' '' gc_i.
  m_fcat_0100 'CONNID' '' '' '航班连接编号' '' '' '' gc_i.
  m_fcat_0100 'FLDATE' '' '' '航班日期' '' '' '' gc_i.
  m_fcat_0100 'PRICE' '' '' '航空运费' '' '' '' gc_i.
  m_fcat_0100 'CURRENCY' '' '' '航班的本地货币' '' '' '' gc_i.
  m_fcat_0100 'PLANETYPE' '' '' '飞机类型' '' '' '' gc_i.
  m_fcat_0100 'SEATSMAX' '' '' '经济舱的最大容量' '' '' '' gc_i.
  m_fcat_0100 'SEATSOCC' '' '' '占据的经济舱座位' '' '' '' gc_i.
  m_fcat_0100 'PAYMENTSUM' '' '' '当前预定总数' '' '' '' gc_i.
  m_fcat_0100 'SEATSMAX_B' '' '' '商务舱的最大容量' '' '' '' gc_i.
  m_fcat_0100 'SEATSOCC_B' '' '' '占据的商务舱座位' '' '' '' gc_i.
  m_fcat_0100 'SEATSMAX_F' '' '' '头等舱的最大容量' '' '' '' gc_i.
  m_fcat_0100 'SEATSOCC_F' '' '' '占据的头等舱座位' '' '' '' gc_i.

ENDFORM.
*&---------------------------------------------------------------------*
*&      Form  FRM_BUILD_UI_FUNCTIONS
*&---------------------------------------------------------------------*
*       build ui functions for alv
*----------------------------------------------------------------------*
FORM frm_build_ui_functions.

  DATA: ls_ui_func TYPE ui_func.

  REFRESH: gt_ui_func.
  ls_ui_func = cl_gui_alv_grid=>mc_fc_loc_copy .
  APPEND ls_ui_func TO gt_ui_func.
  ls_ui_func = cl_gui_alv_grid=>mc_fc_loc_copy_row .
  APPEND ls_ui_func TO gt_ui_func.
  ls_ui_func = cl_gui_alv_grid=>mc_fc_loc_cut .
  APPEND ls_ui_func TO gt_ui_func.
  ls_ui_func = cl_gui_alv_grid=>mc_fc_refresh .
  APPEND ls_ui_func TO gt_ui_func.
  ls_ui_func = cl_gui_alv_grid=>mc_fc_loc_move_row .
  APPEND ls_ui_func TO gt_ui_func.
  ls_ui_func = cl_gui_alv_grid=>mc_fc_loc_paste .
  APPEND ls_ui_func TO gt_ui_func.
  ls_ui_func = cl_gui_alv_grid=>mc_fc_loc_paste_new_row .
  APPEND ls_ui_func TO gt_ui_func.
  ls_ui_func = cl_gui_alv_grid=>mc_fc_loc_undo .
  APPEND ls_ui_func TO gt_ui_func.
  ls_ui_func = cl_gui_alv_grid=>mc_fc_pc_file .
  APPEND ls_ui_func TO gt_ui_func.
  ls_ui_func = cl_gui_alv_grid=>mc_fc_loc_delete_row .
  APPEND ls_ui_func TO gt_ui_func.
  ls_ui_func = cl_gui_alv_grid=>mc_fc_loc_insert_row .
  APPEND ls_ui_func TO gt_ui_func.
  ls_ui_func = cl_gui_alv_grid=>mc_fc_loc_append_row.
  APPEND ls_ui_func TO gt_ui_func.

ENDFORM. " FRM_BUILD_UI_FUNCTIONS
*&---------------------------------------------------------------------*
*&      Form  FRM_SET_LAYOUT
*&---------------------------------------------------------------------*
*       Set output layout
*----------------------------------------------------------------------*
FORM frm_set_layout .

  CLEAR: gs_layout_h.
  gs_layout_h-zebra      = 'X'.        "striped pattern
  gs_layout_h-cwidth_opt = 'X'.        "Optimized width

  gs_layout_i = gs_layout_h.

ENDFORM. " FRM_SET_LAYOUT
*&---------------------------------------------------------------------*
*&      FORM  FRM_SET_VARIANT
*&---------------------------------------------------------------------*
*       SET OUTPUT VARIANT
*----------------------------------------------------------------------*
FORM frm_set_variant .

"用于区分抬头和项目的布局

  CLEAR: gs_variant_h.
  gs_variant_h-handle = '1001'.
  gs_variant_h-report = sy-repid.

  CLEAR: gs_variant_i.
  gs_variant_i-handle = '2001'.
  gs_variant_i-report = sy-repid.

ENDFORM. " FRM_SET_VARIANT
*&---------------------------------------------------------------------*
*&      Form  FRM_SPLIT_SCREEN
*&---------------------------------------------------------------------*
*       Split screen
*----------------------------------------------------------------------*
FORM frm_split_screen.

  "创建屏幕容器:comtainer
  CREATE OBJECT gs_dock
    EXPORTING
      repid                       = sy-repid
      dynnr                       = '0100'
      side                        = cl_gui_docking_container=>dock_at_left
      extension                   = 200
      metric                      = 0
      ratio                       = 95
    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.
    MESSAGE ID sy-msgid TYPE sy-msgty NUMBER sy-msgno
               WITH sy-msgv1 sy-msgv2 sy-msgv3 sy-msgv4.
  ENDIF.

*拆分成一行二列部分*
  CREATE OBJECT gs_splitter
    EXPORTING
      parent  = gs_dock
      rows    = 2
      columns = 1.

*第一行一列*
  CALL METHOD gs_splitter->get_container
    EXPORTING
      row       = 1
      column    = 1
    RECEIVING
      container = gs_container_h.

*第二行一列*
  CALL METHOD gs_splitter->get_container
    EXPORTING
      row       = 2
      column    = 1
    RECEIVING
      container = gs_container_i.
ENDFORM.
*&---------------------------------------------------------------------*
*&      FORM  FRM_CREATE_GRID
*&---------------------------------------------------------------------*
*       Create alv grid on the screen
*----------------------------------------------------------------------*
FORM frm_create_grid .

  "创建抬头屏幕对象
  CREATE OBJECT gs_grid_h
    EXPORTING
      i_parent = gs_container_h.

  "准备输入事件
  CALL METHOD gs_grid_h->set_ready_for_input
    EXPORTING
      i_ready_for_input = 1.

  "check data changed
  CALL METHOD gs_grid_h->check_changed_data.

  "数据变更事件
  CALL METHOD gs_grid_h->register_edit_event
    EXPORTING
      i_event_id = cl_gui_alv_grid=>mc_evt_modified.

  "创建行项目屏幕对象
  CREATE OBJECT gs_grid_i
    EXPORTING
      i_parent = gs_container_i.

ENDFORM. " FRM_CREATE_GRID
*&---------------------------------------------------------------------*
*&      FORM  FRM_DISPLAY_ALV
*&---------------------------------------------------------------------*
*       Display in ALV
*----------------------------------------------------------------------*
FORM frm_display_alv USING pv_flg TYPE c
                           pv_grid TYPE REF TO cl_gui_alv_grid .

  CASE pv_flg.
    WHEN gc_h.

      CALL METHOD pv_grid->set_table_for_first_display
        EXPORTING
*         I_CONSISTENCY_CHECK           = 'X'
          is_variant                    = gs_variant_h
          it_toolbar_excluding          = gt_ui_func
          i_save                        = 'A'
          i_default                     = 'X' "允许定义默认布局
          is_layout                     = gs_layout_h
        CHANGING
          it_outtab                     = gt_head
          it_fieldcatalog               = gt_fcat_h
        EXCEPTIONS
          invalid_parameter_combination = 1
          program_error                 = 2
          too_many_lines                = 3
          OTHERS                        = 4.
      IF sy-subrc <> 0.
        MESSAGE ID sy-msgid TYPE sy-msgty NUMBER sy-msgno
                        WITH sy-msgv1 sy-msgv2 sy-msgv3 sy-msgv4.
      ENDIF.
    WHEN gc_i.

      CALL METHOD pv_grid->set_table_for_first_display
        EXPORTING
*         I_CONSISTENCY_CHECK           = 'X'
          is_variant                    = gs_variant_i
          it_toolbar_excluding          = gt_ui_func
          i_save                        = 'A'
          i_default                     = 'X' "允许定义默认布局
          is_layout                     = gs_layout_i
        CHANGING
          it_outtab                     = gt_item
          it_fieldcatalog               = gt_fcat_i
        EXCEPTIONS
          invalid_parameter_combination = 1
          program_error                 = 2
          too_many_lines                = 3
          OTHERS                        = 4.
      IF sy-subrc <> 0.
        MESSAGE ID sy-msgid TYPE sy-msgty NUMBER sy-msgno
                        WITH sy-msgv1 sy-msgv2 sy-msgv3 sy-msgv4.
      ENDIF.

    WHEN OTHERS.
  ENDCASE.



ENDFORM. " FRM_DISPLAY_ALV
*&---------------------------------------------------------------------*
*&      FORM  FRM_REFRESH_ALV
*&---------------------------------------------------------------------*
*       Refresh ALV
*----------------------------------------------------------------------*
*      -->PV_GRID     GRID对象
*----------------------------------------------------------------------*
FORM frm_refresh_alv USING pv_grid TYPE REF TO cl_gui_alv_grid.

  "刷新变量
  DATA: ls_stable TYPE lvc_s_stbl.

  "刷新显示
  CLEAR ls_stable.
  ls_stable-row = 'X'."基于行刷新
  ls_stable-col = 'X'."基于列刷新
  CALL METHOD pv_grid->refresh_table_display
    EXPORTING
      is_stable = ls_stable
    EXCEPTIONS
      finished  = 0
      OTHERS    = 0.

ENDFORM. " FRM_REFRESH_ALV

屏幕逻辑流如下:
在这里插入图片描述
状态栏按钮如下:
在这里插入图片描述
代码可以直接粘贴运行,只需自建一个100屏幕和状态栏即可。

OVER……

  • 10
    点赞
  • 22
    收藏
    觉得还不错? 一键收藏
  • 3
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值