【OO ALV实现合并行和列】

需求场景

做了一个FUNCTION ALV,按行展示,但是用户需要做一个转置,前面列按行显示,后面数量列由按列显示调整为按行显示。查了一下,好像是FUNCTION ALV实现不了,参考了一位博主实现了这个需求。
ABAP ALV多行表头(合并列,合并单元格)

问题点

这里面实现按行显示的代码有问题,我这里做了一些调整,代码如下:

FORM set_merge_vert USING col row len value.
  CLEAR: wa_col_merge,it_col_merge.
  wa_col_merge-col_id    = row.
  wa_col_merge-outputlen = len.
  APPEND wa_col_merge TO it_col_merge.

  CALL METHOD g_alv_grid->z_set_merge_vert
    EXPORTING
      col           = col
      value         = value
    CHANGING
      tab_col_merge = it_col_merge.

  "设置Style
  CLEAR:wa_style-style.
  wa_style-style     = alv_style_font_bold_no
  + alv_style_align_center_center
  + alv_style_color_key.

  CALL METHOD g_alv_grid->z_set_cell_style
    EXPORTING
      row   = row
      col   = col
      style = wa_style-style.
ENDFORM.                    " SET_MERGE_VERT

  METHOD z_set_merge_vert.
    FIELD-SYMBOLS <fs_cols> TYPE lvc_s_co01.
    FIELD-SYMBOLS <fs_data> TYPE lvc_s_data.
    DATA outputlen TYPE i.

    SORT tab_col_merge.

    LOOP AT tab_col_merge ASSIGNING <fs_cols>.
      IF <fs_cols>-col_id    LE 0.                CONTINUE. ENDIF.
      IF <fs_cols>-outputlen LE <fs_cols>-col_id. CONTINUE. ENDIF.
      outputlen = <fs_cols>-outputlen - <fs_cols>-col_id.
      LOOP AT mt_data ASSIGNING <fs_data>
      WHERE col_pos = col  AND
      ( row_pos BETWEEN <fs_cols>-col_id AND
      <fs_cols>-outputlen ).

        IF <fs_data>-row_pos = <fs_cols>-col_id.
          <fs_data>-mergevert = outputlen.
          <fs_data>-value = value.
        ELSE.
          CLEAR <fs_data>-mergevert.
          CLEAR <fs_data>-value.
        ENDIF.
      ENDLOOP.
    ENDLOOP.
  ENDMETHOD.                    "Z_SET_MERGE_VERT

效果如下

在这里插入图片描述

  • 7
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
ABAP OOALV 中,可以使用 CL_GUI_ALV_GRID 类来实现菜单下拉栏按钮。首先,需要创建一个继承自 CL_GUI_ALV_GRID 的子类,并重写其 GET_TOP_OF_PAGE 方法。在该方法中,可以使用以下代码来创建菜单下拉栏按钮: ```abap METHOD get_top_of_page. DATA: lr_functions TYPE REF TO cl_salv_functions_list, lr_function TYPE REF TO cl_salv_function, lr_menu TYPE REF TO cl_gui_context_menu, lr_submenu TYPE REF TO cl_gui_context_menu. super->get_top_of_page( ). IF me->alv_functions IS INITIAL. lr_functions = me->get_functions( ). lr_function = lr_functions->add_function( function_name = 'MY_FUNCTION' icon_name = 'ICON_NAME' text = 'MY_TEXT' ). lr_menu = lr_function->get_context_menu( ). lr_submenu = lr_menu->create_submenu( text = 'MY_SUBMENU' ). lr_submenu->add_function( function_name = 'MY_SUBFUNCTION' icon_name = 'ICON_NAME' text = 'MY_SUBTEXT' ). ENDIF. ENDMETHOD. ``` 以上代码中,我们首先获取了 ALV 的函数表对象,并添加了一个自定义的函数 MY_FUNCTION。然后,我们通过该函数的 get_context_menu 方法获取了一个菜单对象 lr_menu,并创建了一个子菜单 lr_submenu。最后,我们在子菜单中添加了一个自定义的函数 MY_SUBFUNCTION。 需要注意的是,在以上代码中,MY_FUNCTION、MY_SUBFUNCTION、ICON_NAME、MY_TEXT、MY_SUBTEXT 都需要根据实际情况进替换。此外,如果需要在菜单下拉栏按钮上显示图标,还需要提供相应的图标名称。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值