【SAP Abap】SAP ALV开发(REUSE_ALV_GRID_DISPLAY_LVC)全网最详细 DEMO

news2024/11/13 7:51:40

SAP ALV开发(REUSE_ALV_GRID_DISPLAY_LVC)全网最详细 DEMO

  • 1、ALV 简介
  • 2、演示程序

1、ALV 简介

ALV 报表程序,是我们在 SAP 项目中最常开发的程序类型。
SAP 系统提供了三种 ALV 实现方式,分别是:

  • FM ALV,通常是指:函数 REUSE_ALV_LIST_DISPLAY、REUSE_ALV_GRID_DISPLAY[ _LVC]
  • OO ALV,通常是指:类 CL_GUI_ALV_GRID
  • OO SALV,通常是指:类 CL_SALV_TABLE

FM ALV:Function 一般有 Grid 和 List 两种,Grid 以网格显示,List 以表格显示,两者的工具栏有一点不同。ALV Grid 函数有两个:REUSE_ALV_GRID_DISPLAY 和 REUSE_ALV_GRID_DISPLAY_LVC。REUSE_ALV_GRID_DISPLAY_LVC 其实就是 REUSE_ALV_GRID_DISPLAY 的升级版,两者的操作大同小异,只是后者能更好的和 OO ALV 结合使用,前者则不能;且在输入参数属性的结构上也有些差异。建议使用带 LVC 的 ALV

OO ALV:使用面向对象的方法创建的 ALV,首先需要创建一个屏幕,添加一个容器,然后将 CL_GUI_ALV_GRID 对象分配给这个容器。它存在很多的事件,需要注册自己的事件处理方法,ALV 的布局参数不用依靠类方法来设置,和 Function ALV 一样,还是依靠函数来控制的。

OO SALV:也是面向对象创建 ALV 的一种方式,但不提供编辑的功能,(但可以通过 SALV 适配器来调用 CL_GUI_ALV_GRID 修改为编辑模式),一般情况下 SALV 是不需要创建容器的,SALV 的布局需要通过类方法来控制。

三种 ALV 的应用场景:

  • 单GRID数据展示或简单编辑功能,可以使用 FM ALV
  • 仅数据展示,无需编辑功能的,可以使用 OO SALV
  • 需要复杂功能,如多GRID数据展示、数据联动、编辑功能的,可以使用 OO ALV

日常开发中使用最多的还是 FM ALV,即 REUSE_ALV_GRID_DISPLAY_LVC ,本篇文章主要讲解其使用方法。

2、演示程序

在这里插入图片描述
在这里插入图片描述

REPORT  yz_alv_demo.
TYPE-POOLS:slis.

CONSTANTS:gc_inactive TYPE icon       VALUE '@BZ@',   " ICON_LED_INACTIVE
          gc_red      TYPE icon       VALUE '@5C@',   " ICON_LED_RED
          gc_yellow   TYPE icon       VALUE '@5D@',   " ICON_LED_YELLOW
          gc_green    TYPE icon       VALUE '@5B@'.   " ICON_LED_GREEN

TYPES: BEGIN OF ty_sbook,
          mandt       LIKE sbook-mandt,
          carrid      LIKE sbook-carrid,
          connid      LIKE sbook-connid,
          fldate      LIKE sbook-fldate,
          luggweight  LIKE sbook-luggweight,
          wunit       LIKE sbook-wunit,
          class       LIKE sbook-class,
          loccuram    LIKE sbook-loccuram,
          loccurkey   LIKE sbook-loccurkey,
          counter     LIKE sbook-counter,
          cancelled   LIKE sbook-cancelled,         " 复选框(编辑状态下显示复选框,需设置 Fieldcat-Checkbox)
          passname    LIKE sbook-passname,
          passbirth   LIKE sbook-passbirth,
          sel         TYPE xflag,                   " 选择框(设置 Layout-box_fname,无需设置 Fieldcat)
          icon        TYPE icon_d,                  " 图标(无需设置,直接显示成图标),也可以定义为:icon(4)
          iconname    TYPE iconname,                " 图标名称演示(文本值,具体可以参考数据字典ICON表)
          iconiname   TYPE icon_int,                " 图标内部名称(无需设置,直接显示成图标),也可以定义为:iconiname(8)
          excp(1),                                  " 交通灯图标(需设置 Layout-excp_fname,才能显示图标)
*                                                     值   Light(EXCP_LED = '')          LED(EXCP_LED = 'X')
*                                                     0     熄灯 @EB@ ICON_LIGHT_OUT      熄灯 @BZ@ ICON_LED_INACTIVE
*                                                     1     红灯 @0A@  ICON_RED_LIGHT     红灯 @5C@ ICON_LED_RED
*                                                     2     黄灯 @09@ ICON_YELLOW_LIGHT   黄三角 @5D@ ICON_LED_YELLOW
*                                                     3     绿灯 @08@  ICON_GREEN_LIGHT   绿方块 @5B@ ICON_LED_GREEN
          rowcolor(4),                              " 行颜色,设置 layout-info_fname 后,不显示该字段值
          rclrvalue(4),                             " 行颜色值演示,另外定义一个,用于显示值
          colortab    TYPE lvc_t_scol,              " 单元格颜色
          styletab    TYPE lvc_t_styl,              " 单元格样式,如单元格编辑、按钮等
      END OF ty_sbook,
      tt_sbook      TYPE TABLE OF ty_sbook.
DATA: gt_sbook      TYPE tt_sbook WITH HEADER LINE.

DATA: gt_colortab   TYPE lvc_t_scol WITH HEADER LINE,         " 单元格颜色
      gt_styletab   TYPE lvc_t_styl WITH HEADER LINE.         " 单元格编辑

DATA: gt_fieldcat   TYPE lvc_t_fcat WITH HEADER LINE,         " 字段目录
      gs_layout     TYPE lvc_s_layo,                          " 表格布局
      gt_sort       TYPE lvc_t_sort WITH HEADER LINE,         " 排序&分类汇总
      gt_event_exit TYPE slis_t_event_exit WITH HEADER LINE,  " 预置按钮出口
      gt_exclude    TYPE slis_t_extab WITH HEADER LINE,       " 排除标准工具栏按钮
      gt_event      TYPE slis_t_event WITH HEADER LINE,       " ALV事件
      gs_setting    TYPE lvc_s_glay,                          " 表格设置
      gs_print      TYPE lvc_s_prnt.                          " 打印设置(还没弄明白)


*----------------------------------------------------------------------*
*       CLASS lcl_event_receiver DEFINITION
*----------------------------------------------------------------------*
*       OO ALV 事件处理方法定义
*----------------------------------------------------------------------*
CLASS lcl_event_receiver DEFINITION .
  PUBLIC SECTION.
    METHODS: handle_data_changed    " 值变更事件
             FOR EVENT data_changed OF cl_gui_alv_grid
                       IMPORTING  er_data_changed.
ENDCLASS.                    "LCL_ALV_RECEIVER DEFINITION

*----------------------------------------------------------------------*
*       CLASS LCL_ALV_RECEIVER IMPLEMENTATION
*----------------------------------------------------------------------*
*
*----------------------------------------------------------------------*
CLASS lcl_event_receiver IMPLEMENTATION.

  METHOD handle_data_changed.
    DATA: ls_lines TYPE  lvc_s_modi,
          lv_changed_flag TYPE c.    " 更新标识

    LOOP AT er_data_changed->mt_mod_cells INTO ls_lines.
      CASE ls_lines-fieldname.
        WHEN 'LOCCURAM'.
          lv_changed_flag = 'X'.

          DATA:ls_sbook TYPE ty_sbook.
          READ TABLE gt_sbook INTO ls_sbook INDEX ls_lines-row_id.  "传入选中行记录的row_id,定位alv的行
          IF sy-subrc = 0.
            "赋界面新值
            ls_sbook-loccuram = ls_lines-value.  "传入选中行记录中对应字段的新值
            "赋数据库其他值(适用于仓库变更,显示新的库存量的场景)
*            SELECT SINGLE labst
*            INTO ls_sbook-labst
*            FROM mard
*            WHERE matnr = ls_sbook-matnr
*              AND werks = ls_sbook-reswk
*              AND lgort = ls_sbook-lgort.
            "更新GRID
            MODIFY gt_sbook FROM ls_sbook INDEX ls_lines-row_id.
            CLEAR  ls_sbook.
          ENDIF.
      ENDCASE.
    ENDLOOP.

    " 未做更新,则直接退出
    CHECK lv_changed_flag IS NOT INITIAL.

    " 做了更新,则刷新GRID
    DATA: lr_grid  TYPE  REF TO cl_gui_alv_grid,
          ls_stbl  TYPE  lvc_s_stbl.

    CALL FUNCTION 'GET_GLOBALS_FROM_SLVC_FULLSCR'
      IMPORTING
        e_grid = lr_grid.

    ls_stbl-row = 'X'." 基于行稳定刷新
    ls_stbl-col = 'X'." 基于列稳定刷新
    CALL METHOD lr_grid->refresh_table_display
      EXPORTING
        is_stable = ls_stbl.
  ENDMETHOD.                    "handle_data_changed

ENDCLASS.                    "LCL_GRID_EVENT_RECEIVER IMPLEMENTATION


SELECTION-SCREEN BEGIN OF BLOCK b1 WITH FRAME TITLE text-b01. " 基本设置
PARAMETERS: p_sel,                                " 选择模式:A、B、C、D
            p_title AS CHECKBOX,                  " 显示ALV标题
            p_text TYPE string DEFAULT 'ALV标题'. " 自定义ALV标题
PARAMETERS: p_edit AS CHECKBOX,                   " 显示编辑模式
            p_icon AS CHECKBOX.                   " 显示图标
SELECTION-SCREEN END OF BLOCK b1.

SELECTION-SCREEN BEGIN OF BLOCK b2 WITH FRAME TITLE text-b02. " 样式设置
PARAMETERS: p_excp  AS CHECKBOX.                  " 显示交通灯
SELECTION-SCREEN BEGIN OF LINE.
SELECTION-SCREEN POSITION 3.
PARAMETERS: p_light RADIOBUTTON GROUP 1.
SELECTION-SCREEN COMMENT 5(10) text-s01.          " 交通灯样式
SELECTION-SCREEN POSITION 18.
PARAMETERS: p_led RADIOBUTTON GROUP 1.
SELECTION-SCREEN COMMENT 20(10) text-s02.         " LED样式
SELECTION-SCREEN END OF LINE.

PARAMETERS: p_color AS CHECKBOX.                  " 显示颜色
SELECTION-SCREEN BEGIN OF LINE.
SELECTION-SCREEN POSITION 3.
PARAMETERS: p_col RADIOBUTTON GROUP 2.
SELECTION-SCREEN COMMENT 5(10) text-s03.          " 列颜色
SELECTION-SCREEN POSITION 18.
PARAMETERS: p_row RADIOBUTTON GROUP 2.
SELECTION-SCREEN COMMENT 20(10) text-s04.         " 行颜色
SELECTION-SCREEN POSITION 33.
PARAMETERS: p_cell RADIOBUTTON GROUP 2.
SELECTION-SCREEN COMMENT 35(10) text-s05.         " 单元格颜色
SELECTION-SCREEN POSITION 48.
PARAMETERS: p_all RADIOBUTTON GROUP 2.
SELECTION-SCREEN COMMENT 50(10) text-s06.         " 所有颜色
SELECTION-SCREEN END OF LINE.
SELECTION-SCREEN END OF BLOCK b2.

SELECTION-SCREEN BEGIN OF BLOCK b3 WITH FRAME TITLE text-b03. " 其他设置
PARAMETERS: p_sort AS CHECKBOX.
PARAMETERS: p_ex AS CHECKBOX.     " 显示所有工具栏按钮
PARAMETERS: p_tt AS CHECKBOX.     " 显示表头表尾
PARAMETERS: p_height TYPE i DEFAULT 10.
PARAMETERS: p_dialog AS CHECKBOX. " 以对话框显示
SELECTION-SCREEN END OF BLOCK b3.

INITIALIZATION.

START-OF-SELECTION.
  PERFORM frm_get_data.
  PERFORM frm_handle_data.

END-OF-SELECTION.
  PERFORM frm_build_fieldcat.
  PERFORM frm_build_layout.
  PERFORM frm_build_others.
  PERFORM frm_show_alv.


*&---------------------------------------------------------------------*
*&      Form  frm_get_data
*&---------------------------------------------------------------------*
*       ALV数据获取
*----------------------------------------------------------------------*
FORM frm_get_data.
  SELECT * FROM sbook INTO CORRESPONDING FIELDS OF TABLE gt_sbook UP TO 40 ROWS.
ENDFORM.                    "get_data

*&---------------------------------------------------------------------*
*&      Form  frm_handle_data
*&---------------------------------------------------------------------*
*       ALV数据处理
*----------------------------------------------------------------------*
FORM frm_handle_data.
  FIELD-SYMBOLS:<fs_sbook> LIKE LINE OF gt_sbook.
  DATA: lv_index TYPE i, lv_mod TYPE i.

  LOOP AT gt_sbook ASSIGNING <fs_sbook>.
    lv_index = sy-tabix.
    lv_mod = ( lv_index - 1 ) MOD 4.

*  1、演示EXCP列:
*         0-熄灯,@EB@ ICON_LIGHT_OUT,1-红灯,@0A@  ICON_RED_LIGHT
*         2-黄灯,@09@ ICON_YELLOW_LIGHT,3-绿灯,@08@	ICON_GREEN_LIGHT
    <fs_sbook>-excp = lv_mod.

*  2、演示ICON列:赋值 ICON-ID
    CASE <fs_sbook>-excp.
      WHEN 1.
        <fs_sbook>-icon = gc_red.           " '@5C@',   " ICON_LED_RED
      WHEN 2.
        <fs_sbook>-icon = gc_yellow.        " '@5D@',   " ICON_LED_YELLOW
      WHEN 3.
        <fs_sbook>-icon = gc_green.         " '@5B@'.   " ICON_LED_GREEN
      WHEN OTHERS.
        <fs_sbook>-icon = gc_inactive.      " '@BZ@',   " ICON_LED_INACTIVE
    ENDCASE.
*  2+、演示ICON列:赋值 ICON-INTERNAL
    PERFORM zfrm_icon_get_names_by_id USING <fs_sbook>-icon
          CHANGING <fs_sbook>-iconname <fs_sbook>-iconiname.

*  3、演示行颜色:
    DATA: lv_color TYPE string.
    DATA: lv_value TYPE i, c1,c2,c3.
    IF lv_index LT 33.
      lv_value = ( lv_index + 1 ) / 4 - 1.
      c1 = lv_value.                          " 颜色第2位为颜色值,由0~7表示,不同的数字表示不同的颜色属性:
*         0 = background color,1 = Gray-blue,2 = Light gray,3 = yellow,
*         4 = blue-gray,5 = green,6 = red,7 = orange
      lv_value = ( lv_mod + 1 ) / 2 - 1.
      c2 = lv_value.                          " 颜色第3位为是否高亮显示,由1、0(非1)表示,1表示高亮,非1表示不高亮
      lv_value = lv_mod MOD 2.
      c3 = lv_value.                          " 颜色第4位为是否反转,即颜色作用在背景色(表格行)还是前景色(文字)
*                                                由1、0(非1)表示(仅当第3位为0时才生效),1-前景色,0(非1)-背景色
      CONCATENATE 'C' c1 c2 c3 INTO lv_color. " 颜色定义为4位字符,首位固定为字母“C”
      CONDENSE lv_color NO-GAPS.
      <fs_sbook>-rowcolor = lv_color.
      <fs_sbook>-rclrvalue = lv_color.
    ENDIF.
    IF lv_index EQ 33.
      <fs_sbook>-rowcolor = 'C705'.     " 对比颜色值测试
      <fs_sbook>-rclrvalue = 'C705'.
    ELSEIF lv_index EQ 34.
      <fs_sbook>-rowcolor = 'C791'.     " 对比颜色值测试
      <fs_sbook>-rclrvalue = 'C791'.
    ENDIF.

*  4、演示单元格颜色:
*    IF lv_index GT 34.
    IF <fs_sbook>-luggweight GT 40.
      CLEAR gt_colortab.
      gt_colortab-fname = 'LUGGWEIGHT'.
      gt_colortab-color-col = '6'.      " 红色高亮显示
      gt_colortab-color-int = '1'.
      gt_colortab-color-inv = '0'.
      APPEND gt_colortab.
    ENDIF.
    IF <fs_sbook>-counter GT 0.
      CLEAR gt_colortab.
      gt_colortab-fname = 'COUNTER'.
      gt_colortab-color-col = '6'.    " 红色高亮显示
      gt_colortab-color-int = '1'.
      gt_colortab-color-inv = '0'.
      APPEND gt_colortab.
    ENDIF.
*    ENDIF.
    <fs_sbook>-colortab = gt_colortab[].
    CLEAR: gt_colortab, gt_colortab[].

*   5、演示单元格编辑:价格小于800的可以编辑
*     如果是针对某列的,可以先设置该列Fieldcat-edit = 'X',开启列可编辑,然后通过样式控制不可编辑单元格;
*     如果是针对表格的,可以先设置表格Layout-edit = 'X',开启全部可编辑,然后通过样式控制不可编辑单元格;
    CLEAR gt_styletab.
    gt_styletab-fieldname = 'LOCCURAM'.
    IF <fs_sbook>-loccuram GE 800.
      gt_styletab-style = cl_gui_alv_grid=>mc_style_disabled. " 设置大于等于800的不可编辑
    ELSE.
      gt_styletab-style = cl_gui_alv_grid=>mc_style_enabled. " 设置小于800的可编辑
    ENDIF.
    APPEND gt_styletab.
    <fs_sbook>-styletab = gt_styletab[].
    CLEAR: gt_styletab, gt_styletab[].

  ENDLOOP.
ENDFORM.                    "frm_handle_data

*&---------------------------------------------------------------------*
*&      Form  frm_build_layout
*&---------------------------------------------------------------------*
*       常用Layout设置演示
*----------------------------------------------------------------------*
FORM frm_build_layout.

  CLEAR gs_layout.
  gs_layout-zebra = 'X'.                " 斑马线,隔行换色
*  gs_layout-edit = 'X'.                " ALV所有列可编辑
*  gs_layout-edit_mode = ' '.           " 编辑模式,用途未知
*  gs_layout-no_keyfix = 'X'.           " 关键列不固定,包括设置 FIELDCAT-KEY、FIELDCAT-FIX_COLUMN 的列
* 此处省略4个
*  gs_layout-language = 'E'.            " 语言,没看到效果
* 此处省略1个
*  gs_layout-smalltitle = 'X'.          " 小标题,没看到效果
*  gs_layout-no_hgridln = 'X'.          " 隐藏垂直线,即竖线
*  gs_layout-no_vgridln = 'X'.          " 隐藏水平线,即横线
*  gs_layout-no_headers = 'X'.          " 隐藏标题栏
*  gs_layout-no_merging = 'X'.          " 禁用单元格合并,即排序时相同列内容仍显示,默认显示为空白
  gs_layout-cwidth_opt = 'X'.           " 所有列自动宽度(此时 Fieldcat-outputlen 失效)
*  gs_layout-totals_bef = 'X'.          " 总计、小计放在第一行
*  gs_layout-no_totarr = 'X'.           " 没看到效果:在总计一行和小计行中显示箭头,这些箭头还表示总计区域。 设置此参数以抑制这些箭头
*  gs_layout-no_totexp = 'X'.           " 没看到效果:一个图标显示在一个(子)总计的开始线表示是否已展开的行。 设置此参数以抑制此图标。
* 此处省略7个
  gs_layout-stylefname = 'STYLETAB'.   " 显示样式:控制单元格可否编辑
*  gs_layout-no_rowmark = 'X'.          " 隐藏左边的选择块(当Layout-SEL_MODE = A或D,或设置了Layout-BOX_FNAME,或设置了编辑状态时,默认会有选择块)
*  gs_layout-no_toolbar = 'X'.          " 没看到效果
*  gs_layout-grid_title = '我是Title'.  " 没看到效果
  gs_layout-sel_mode = p_sel.           " 选择模式(需要去掉:layout-box_fname 和 编辑模式,才能看到效果)
  gs_layout-box_fname = 'SEL'.          " 一旦设置了该参数,则相当于设置了 gs_layout-SEL_MODE = 'A',此时FieldCat中不用加入该字段
*  gs_layout-sgl_clk_hd = 'X'.          " 列标题支持单击排序
*  gs_layout-no_totline = 'X'.          " 不显示合计、小计行
  gs_layout-numc_total = 'X'.           " 默认情况,NUMC字段设置 FIELDCAT-DO_SUM = 'X' 是不会计算合计的,设置支持合计
*  gs_layout-no_utsplit = 'X'.          " 是否根据单位拆分总计?
  IF p_excp = 'X'.     " 是否演示图标
    gs_layout-excp_fname = 'EXCP'.      " 指定列按红绿灯显示,否则显示原始值
  ENDIF.
*  gs_layout-excp_rolln = ' '.          " 未知?
*  gs_layout-excp_conds = 'X'.          " 未知?
  IF p_excp = 'X' AND p_led = 'X'.
    gs_layout-excp_led = 'X'.           " 更改EXCP列的显示样式为LED
  ENDIF.
*  gs_layout-excp_group = 'X'.          " 未知?
* gs_layout-detailinit = 'X'.           " 显示明细,初始值的项也显示,即显示空值,默认不显示
  gs_layout-detailtitl = '自定义标题'.  " 显示明细,窗口的标题
*  gs_layout-keyhot = 'X'.              " 关键列作为热点,处理事件在哪里?
* 此处省略3个
*  gs_layout-s_dragdrop = ''.           " ALV拖拽,另外专题讲解
  IF p_color = 'X'.     " 是否演示颜色
    IF p_row EQ 'X' OR p_all EQ 'X'.
      gs_layout-info_fname = 'ROWCOLOR'.  " 行颜色2:设定行颜色值所在的列( COLOR )
    ENDIF.
    IF p_cell EQ 'X' OR p_all EQ 'X'.
      gs_layout-ctab_fname = 'COLORTAB'.  " 单元格颜色3:设定单元格颜色值所在的内表(列名 FNAME +颜色值 COLOR)
    ENDIF.
  ENDIF.
* 此处省略5个

ENDFORM.                    "frm_build_layout

*&---------------------------------------------------------------------*
*&      Form  frm_build_fieldcat
*&---------------------------------------------------------------------*
*       常用Fieldcat设置演示
*----------------------------------------------------------------------*
FORM frm_build_fieldcat.

  DATA: lv_field TYPE string.
  DEFINE mac_field.
    lv_field = '&1'.
    translate lv_field to upper case.

*  gt_fieldcat-row_pos = ''.
*  gt_fieldcat-col_pos = ''.          " 指定显示列位置
    clear gt_fieldcat.
    gt_fieldcat-fieldname = lv_field. " 内表字段名
    gt_fieldcat-reptext = '&2'.       " 字段标题(建议使用该字段,不必设置以下四个字段)
*  gt_fieldcat-scrtext_l = ''.        " 长标题
*  gt_fieldcat-scrtext_m = ''.        " 中标题
*  gt_fieldcat-scrtext_s = ''.        " 短标题
*  gt_fieldcat-tooltip = ''.          " 默认等于 reptext

*  gt_fieldcat-tabname = ''.

*  gt_fieldcat-quantity = ''.
*  gt_fieldcat-qfieldname = ''.
*  gt_fieldcat-ifieldname = ''.
*  gt_fieldcat-round = ''.
*  gt_fieldcat-exponent = ''.

    if gt_fieldcat-fieldname eq 'CARRID'.
      gt_fieldcat-key = 'X'.
      gt_fieldcat-just = 'C'.           " 单元格中内容显示时对齐方式:(R)ight (L)eft (C)ent.
    endif.
    if gt_fieldcat-fieldname eq 'CONNID'.
      gt_fieldcat-fix_column = 'X'.     " 单元格固定
      gt_fieldcat-just = 'L'.
      gt_fieldcat-no_zero = 'X'.        " 为X时,只输出有意义的值,空值不输出,数字不输出前0。
    endif.
    if p_edit eq 'X' and gt_fieldcat-fieldname eq 'FLDATE'.
      gt_fieldcat-edit = 'X'.
      gt_fieldcat-edit_mask = '____/__/__'.
    endif.
    if p_edit eq 'X' and gt_fieldcat-fieldname eq 'CANCELLED'.
*      gt_fieldcat-edit = 'X'.
      gt_fieldcat-checkbox = 'X'.
    endif.
*    if gt_fieldcat-fieldname eq 'ICON'.
*     gt_fieldcat-icon = 'X'.             " 显示图标,对于赋值ICON-ID的列,不设置也能自动显示图标
*     gt_fieldcat-symbol = 'X'.
*    endif.

*  gt_fieldcat-lzero = 'X'.              " 为X时,输出前导零
*  gt_fieldcat-no_sign = 'X'.            " 为X时,不显示数字符号
*  gt_fieldcat-no_zero = 'X'.            " 为X时,只输出有意义的值,空值不输出。
*  gt_fieldcat-no_convext = ''.

    if p_color eq 'X' and ( p_col eq 'X' or p_all eq 'X' )
        and gt_fieldcat-fieldname eq 'CLASS'.
      gt_fieldcat-emphasize = 'C510'.   " 列颜色1:绿色高亮显示
    endif.
    if p_edit eq 'X'
        and gt_fieldcat-fieldname eq 'LOCCURAM'.
*       gt_fieldcat-currency = ''.
      gt_fieldcat-cfieldname = 'LOCCURKEY'.
*      gt_fieldcat-edit = 'X'.      " 设置该列可编辑
    endif.
*
    if gt_fieldcat-fieldname eq 'LUGGWEIGHT'
        or gt_fieldcat-fieldname eq 'COUNTER'.  " NUMC类型
      gt_fieldcat-do_sum = 'X'.   " 合计
*  gt_fieldcat-no_sum = ''.
    endif.

    if gt_fieldcat-fieldname eq 'PASSNAME'.
      gt_fieldcat-no_out = 'X'.     " 不显示在ALV列表中,但可以更改布局显示出来
    endif.
    if gt_fieldcat-fieldname eq 'PASSBIRTH'.
      gt_fieldcat-tech = 'X'.       " 彻底隐藏,在更改布局中不可见
    endif.

*  gt_fieldcat-outputlen = ''.      " 设置列宽,当设置自动列宽是,此参数失效
*  gt_fieldcat-convexit = ''.
*  gt_fieldcat-seltext = ''.

*  gt_fieldcat-rollname = ''.
*  gt_fieldcat-datatype = ''.
*  gt_fieldcat-inttype = ''.
*  gt_fieldcat-intlen = ''.
*  gt_fieldcat-lowercase = ''.
*
*  gt_fieldcat-hier_level = ''.
*  gt_fieldcat-reprep = ''.
*  gt_fieldcat-domname = ''.
*  gt_fieldcat-sp_group = ''.
*  gt_fieldcat-hotspot = ''.        " 设置字段内容下面是否有热点(有下划线,可点击,单击即可触发相应事件)
*  gt_fieldcat-dfieldname = ''.
*  gt_fieldcat-col_id = ''.
*  gt_fieldcat-f4availabl = ''.
*  gt_fieldcat-auto_value = ''.
*  gt_fieldcat-checktable = ''.
*  gt_fieldcat-valexi = ''.
*  gt_fieldcat-web_field = ''.
*  gt_fieldcat-href_hndl = ''.
*  gt_fieldcat-style = ''.
*  gt_fieldcat-style2 = ''.
*  gt_fieldcat-style3 = ''.
*  gt_fieldcat-style4 = ''.
*  gt_fieldcat-drdn_hndl = ''.
*  gt_fieldcat-drdn_field = ''.
*  gt_fieldcat-no_merging = ''.
*  gt_fieldcat-h_ftype = ''.
*  gt_fieldcat-col_opt = ''.          " 单列优化宽度
*  gt_fieldcat-no_init_ch = ''.
*  gt_fieldcat-drdn_alias = ''.
*
*  gt_fieldcat-ref_field = ''.        " 如需单元格显示F4输入帮助,则需要指定字段所参照的表中的字段名
*  gt_fieldcat-ref_table = ''.        " 如需单元格显示F4输入帮助,则需要指定字段所参照的表名
*  gt_fieldcat-txt_field = ''.
*  gt_fieldcat-roundfield = ''.
*  gt_fieldcat-decimals_o = ''.
*  gt_fieldcat-decmlfield = ''.
*  gt_fieldcat-dd_outlen = ''.
*  gt_fieldcat-decimals = ''.         " 控制小数点的位数
*  gt_fieldcat-coltext = ''.

*  gt_fieldcat-colddictxt = ''.
*  gt_fieldcat-selddictxt = ''.
*  gt_fieldcat-tipddictxt = ''.
*
*  gt_fieldcat-tech_col = ''.
*  gt_fieldcat-tech_form = ''.
*  gt_fieldcat-tech_comp = ''.
*  gt_fieldcat-hier_cpos = ''.
*  gt_fieldcat-h_col_key = ''.
*  gt_fieldcat-h_select = ''.
*  gt_fieldcat-dd_roll = ''.
*  gt_fieldcat-dragdropid = ''.
*  gt_fieldcat-mac = ''.
*  gt_fieldcat-indx_field = ''.
*  gt_fieldcat-indx_cfiel = ''.
*  gt_fieldcat-indx_qfiel = ''.
*  gt_fieldcat-indx_ifiel = ''.
*  gt_fieldcat-indx_round = ''.
*  gt_fieldcat-indx_decml = ''.
*  gt_fieldcat-get_style = ''.
*  gt_fieldcat-mark = ''.

    append gt_fieldcat.

  END-OF-DEFINITION.

  mac_field:  "mandt       集团,
              carrid      航运公司,           " 关键字(需设置 fieldcat-key )
              connid      航线id,             " 固定列(需设置 fieldcat-fix_column )
              fldate      航班日期,           " 日期,编辑样式(需设置 fieldcat-edit、fieldcat-edit_mask )
              luggweight  行李重量,           " 合计(需设置 fieldcat-do_sum)
              wunit       重量单位,
              class       航班舱位,
              loccuram    价格,
              loccurkey   币别,
              counter     柜台号,             " NUMC合计(需设置 layout-numc_total、fieldcat-do_sum)
              cancelled   取消,               " 复选框(编辑状态下显示复选框,需设置 Fieldcat-Checkbox)
              passname    乘客姓名,           " 默认隐藏(需设置 fieldcat-no_out )
              passbirth   乘客生日,           " 技术隐藏(需设置 fieldcat-tech )
              icon        图标,               " 图标(无需设置,直接显示成图标)
              iconname    图标名称,           " 图标名称(文本值,具体可以参考数据字典ICON表)
              iconiname   图标内码,           " 图标内部名称(无需设置,直接显示成图标)
              rclrvalue   行颜色值演示.

  IF p_icon IS INITIAL.   " 是否显示图标
    LOOP AT gt_fieldcat WHERE fieldname CS 'ICON'.
      DELETE gt_fieldcat.
    ENDLOOP.
  ELSE.
    LOOP AT gt_fieldcat WHERE fieldname CS 'ICON'.
      gt_fieldcat-just = 'C'.
      MODIFY gt_fieldcat.
    ENDLOOP.
  ENDIF.

  IF p_color IS INITIAL.  " 是否显示颜色
    LOOP AT gt_fieldcat WHERE fieldname EQ 'RCLRVALUE'.
      DELETE gt_fieldcat.
    ENDLOOP.
  ENDIF.

ENDFORM.                    "frm_build_fieldcat

*&---------------------------------------------------------------------*
*&      Form  frm_build_others
*&---------------------------------------------------------------------*
*       ALV 其他设置
*----------------------------------------------------------------------*
FORM frm_build_others.

  " 1、此部分用于排序和分类汇总
  IF p_sort EQ 'X'.
    CLEAR gt_sort.
    gt_sort-spos = 1.
    gt_sort-fieldname = 'LOCCURAM'.   "要排序或分类汇总的字段
    gt_sort-up        = 'X'.          "表示按照上面栏位升序排列
    gt_sort-subtot    = 'X'.          "表示按照该栏位名来分组汇总
    APPEND gt_sort.
  ENDIF.

  " 2、此部分用于设置预置按钮事件
  CLEAR gt_event_exit.
  gt_event_exit-ucomm = '&ETA'.
  gt_event_exit-after = 'X'.
  APPEND gt_event_exit.

  " 3、此部分用于排除特定工具栏按钮
  IF p_ex IS INITIAL.
    CLEAR gt_exclude.
    gt_exclude-fcode = '&VEXCEL'.       " 导出EXCEL
    APPEND gt_exclude.
*    CLEAR gt_exclude.
*    gt_exclude-fcode = '&RNT_PREV'.     " 打印预览
*    APPEND gt_exclude.
    CLEAR gt_exclude.
    gt_exclude-fcode = '%SL'.           " 邮件
    APPEND gt_exclude.
  ENDIF.

  " 4、此部分用于绑定事件处理Form
  CLEAR gt_event.
  gt_event-name = 'CALLER_EXIT'.      " 调用出口,可以和OO ALV结合使用
  gt_event-form = 'FRM_CALLER_EXIT'.
  APPEND gt_event.

*  CLEAR gt_event.
*  gt_event-name = 'PF_STATUS_SET'.    " 作用同 i_callback_pf_status_set
*  gt_event-form = 'FRM_CB_STATUS_SET'.
*  APPEND gt_event.

  " 5、GRID显示、打印设置
  IF p_tt IS INITIAL.   " 显示表头表尾
    gs_setting-coll_top_p = 'X'. "  最小化 TOP_OF_PAGE
    gs_setting-coll_end_l = 'X'. "  最小化 END_OF_LIST
  ENDIF.
  gs_setting-top_p_only = 'X'. "  Top_Of_Page 仅在打印
  gs_setting-eol_p_only = 'X'. "  END_OF_LIST 仅在打印
  gs_setting-no_colwopt = 'X'. "  ALV 控制: 不优化打印的列宽
  gs_setting-edt_cll_cb = 'X'. "  ALV 控制: 退出可编辑单元格时回调

  " 6、后台打印设置(未设置)
*  gs_print

ENDFORM.                    "frm_build_others

*&---------------------------------------------------------------------*
*&      Form  frm_caller_exit
*&---------------------------------------------------------------------*
*       调用出口,可结合OO ALV使用
*----------------------------------------------------------------------*
FORM frm_caller_exit USING ls_data TYPE slis_data_caller_exit.

  " 获取 FM ALV 适配的 OO ALV 对象
  DATA:lr_grid            TYPE REF TO cl_gui_alv_grid.
  CALL FUNCTION 'GET_GLOBALS_FROM_SLVC_FULLSCR'
    IMPORTING
      e_grid = lr_grid.   " 获取OO ALV对象

* 设置enter事件
  CALL METHOD lr_grid->register_edit_event
    EXPORTING
      i_event_id = cl_gui_alv_grid=>mc_evt_enter
    EXCEPTIONS
      error      = 1
      OTHERS     = 2.

* 设置 单光标焦点移开被修改单元格后既触发事件
  CALL METHOD lr_grid->register_edit_event
    EXPORTING
      i_event_id = cl_gui_alv_grid=>mc_evt_modified
    EXCEPTIONS
      error      = 1
      OTHERS     = 2.


  " 注册事件处理器
  DATA: lr_event_receiver  TYPE REF TO lcl_event_receiver.
  CREATE OBJECT lr_event_receiver.
  SET HANDLER lr_event_receiver->handle_data_changed FOR lr_grid.


*  " 设置可编辑字段的F4帮助(该DEMO中没有合适字段)
*  DATA:lt_f4              TYPE lvc_t_f4,
*       ls_f4              TYPE lvc_s_f4.
*  ls_f4-fieldname  = 'LGORT'.   "需要定义F4帮助按钮的字段
*  ls_f4-register   = 'X'.
*  ls_f4-getbefore  = 'X'.
*  ls_f4-chngeafter = 'X'.
*  INSERT ls_f4 INTO TABLE lt_f4.
*
*  CALL METHOD lr_grid->register_f4_for_fields
*    EXPORTING
*      it_f4 = lt_f4[].

*  还需要设置该字段的fieldcat
*  ls_fieldcat-edit = 'X'.        "把这一列变为可修改
*  ls_fieldcat-f4availabl = 'X'.  "这个一定要打上X,字段尾部,添加搜索帮助的的小按钮
ENDFORM.                    "frm_caller_exit

*&---------------------------------------------------------------------*
*&      Form  frm_show_alv
*&---------------------------------------------------------------------*
*       ALV显示
*----------------------------------------------------------------------*
FORM frm_show_alv.
  DATA: lv_title TYPE lvc_title.
  IF p_title EQ 'X'.
    lv_title = p_text.
    IF lv_title IS INITIAL.
      lv_title = '您未定义ALV标题'.
    ENDIF.
  ENDIF.

  DATA: lv_loc1 TYPE i, lv_loc2 TYPE i, lv_loc3 TYPE i, lv_loc4 TYPE i.
  IF p_dialog EQ 'X'.
    lv_loc1 = 1.
    lv_loc2 = 1.
    lv_loc3 = 100.
    lv_loc4 = 10.
  ENDIF.

  CALL FUNCTION 'REUSE_ALV_GRID_DISPLAY_LVC'
  EXPORTING
*    I_INTERFACE_CHECK                 = ' '                        " 接口一致性检查
*    I_BYPASSING_BUFFER                =                            " 是否使用缓存
*    I_BUFFER_ACTIVE                   =                            " 是否激活缓存,如果每次显示ALV都是相同的字段目录,则该字段目录会被放到一特殊的缓存里,加快显示速度。
   i_callback_program                = 'YZ_ALV_DEMO'                " 回调函数、输出内表所在的程序名
   i_callback_pf_status_set          = 'FRM_CB_STATUS_SET'          " 回调本地FORM,设置ALV工具栏
   i_callback_user_command           = 'FRM_CB_USER_COMMAND'        " 回调本地FORM,设置工具栏按钮或数据行事件触发时的操作
   i_callback_top_of_page            = 'FRM_CB_TOP_OF_PAGE'         " 回调函数,设置ALV报表表头信息
   i_callback_html_top_of_page       = 'FRM_CB_HTML_TOP_OF_PAGE'    " 回调函数,设置ALV报表表头HTML代码
   i_callback_html_end_of_list       = 'FRM_CB_HTML_END_OF_LIST'    " 回调函数,设置ALV报表表尾HTML代码
*    I_STRUCTURE_NAME                  = 'YSSBOOK'                  " 字段目录结构,参考数据字典结构,需要为gt_sbook定义结构
*    I_BACKGROUND_ID                   = ' '                        " 设置ALV背景图片ID
   i_grid_title                      = lv_title                     " ALV 标题,位于ALV工具栏和ALV GRID之间
   i_grid_settings                   = gs_setting                   " GRID信息设置
   is_layout_lvc                     = gs_layout                    " ALV输出布局样式
   it_fieldcat_lvc                   = gt_fieldcat[]                " 设定显示的项目名称及输出设定
   it_excluding                      = gt_exclude[]                 " 隐藏设置的ALV工具栏
*    IT_SPECIAL_GROUPS_LVC             =
   it_sort_lvc                       = gt_sort[]                    " ALV排序设置,可以display前对内表数据排序
*    IT_FILTER_LVC                     =                            " ALV过滤设置,可以在get_data时增加过滤
*    IT_HYPERLINK                      =
*    IS_SEL_HIDE                       =
   i_default                         = 'X'                          " 用户是否可以定义默认的布局,’X'-可以定义默认布局,Space-不可以定义默认布局 (默认:X)
   i_save                            = 'A'                          " 保存表格布局:'X'-只能保存为全局标准变式,'U'-只能保存特定用户变式,'A'-都可以保存,SPACE-不能保存变式(默认:space)
*    IS_VARIANT                        =                            " 表格布局变式
   it_events                         =  gt_event[]                  " 设置事件, 类型为slis_t_event的内表(name:事件名称,form:事件的FORM)
   it_event_exit                     =  gt_event_exit[]             " 设置预置按钮回调的执行行为,表明用户所写的代码是在执行标准执行之前还是之后
*    IS_PRINT_LVC                      =
*    IS_REPREP_ID_LVC                  =
    i_screen_start_column             = lv_loc1                     " 以对话框形式显示的开始列
    i_screen_start_line               = lv_loc2                     " 以对话框形式显示的开始行
    i_screen_end_column               = lv_loc3                     " 以对话框形式显示的结束列
    i_screen_end_line                 = lv_loc4                     " 以对话框形式显示的结束行
    i_html_height_top                 = p_height                    " 表头高度
    i_html_height_end                 = p_height                    " 表尾高度
*    IT_EXCEPT_QINFO_LVC               =
*    IR_SALV_FULLSCREEN_ADAPTER        =
*  IMPORTING
*    E_EXIT_CAUSED_BY_CALLER           =
*    ES_EXIT_CAUSED_BY_USER            =
  TABLES
    t_outtab                          = gt_sbook                    " 必须参数,要显示的内表
*  EXCEPTIONS
*    PROGRAM_ERROR                     = 1
*    OTHERS                            = 2
          .
  IF sy-subrc <> 0.
* MESSAGE ID SY-MSGID TYPE SY-MSGTY NUMBER SY-MSGNO
*         WITH SY-MSGV1 SY-MSGV2 SY-MSGV3 SY-MSGV4.
  ENDIF.
ENDFORM.                    "show_alv

*&---------------------------------------------------------------------*
*&      Form  FRM_CB_STATUS_SET
*&---------------------------------------------------------------------*
*       ALV 自定义工具栏
*----------------------------------------------------------------------*
FORM frm_cb_status_set USING rt_extab TYPE slis_t_extab.
* 参数说明:rt_extab是要排除掉的按钮,根据Funcode来排除。
*  另外,也可以通过REUSE_ALV_GRID_DISPLAY函数IT_EXCLUDING内表参数来直接排除哪些预置按钮不可用,
*  IT_EXCLUDING内表结构只有一个fcode字段,即根据保留的FunCode即可disabled掉。

* 1、使用ALV自带的,注释调入参:i_callback_pf_status_set 即可

* 2、调用系统预定义好的标准ALV工具栏,在程序SAPLKKBL中,使用以下语句调用
* SET PF-STATUS 'STANDARD_FULLSCREEN' OF PROGRAM 'SAPLKKBL' EXCLUDING rt_extab.

* 3、自定义ALV工具栏,自已创建一个GUI Status,
*  通常作法是从SLVC_FULLSCREEN函数组中拷贝STANDARD_FULLSCREEN,再在此基础之上新增按钮即可

  "取消激活Function code为 %PC 的本地文件、&AQW 的文字处理
  APPEND '%PC' TO  rt_extab.    " 注意:rt_extab 中已经存在一些fcode了
  APPEND '&AQW' TO  rt_extab.
  IF p_ex IS INITIAL.
    SET PF-STATUS 'STANDARD_FULLSCREEN' EXCLUDING rt_extab.
  ELSE.
    SET PF-STATUS 'STANDARD_FULLSCREEN'.
  ENDIF.
ENDFORM.                    "FRM_CB_STATUS_SET

*&---------------------------------------------------------------------*
*&      Form  FRM_CB_USER_COMMAND
*&---------------------------------------------------------------------*
*       ALV 自定义按钮事件
*----------------------------------------------------------------------*
FORM frm_cb_user_command USING r_ucomm LIKE sy-ucomm rs_selfield TYPE slis_selfield.
* 过程说明:ALV触发的事件(如双击某行数据、单击热点、点ALV工具栏上的自定义的按钮时),
*           会回调I_CALLBACK_USER_COMMAND参数指定的Form;
*           只有自已新增的按钮(或双击数据行时、热点点击)再会调用,
*           ALV 标准默认的Function Code是不会调用的(除非使用使用IT_EVENT_EXIT)
* 参数说明:R_UCOMM 为触发的function code;
*           结构 RS_SELFIELD 为触发字段相关信息
  CASE r_ucomm.
    WHEN '&ETA'.
      MESSAGE '此弹窗仅在设置了IT_EVENT_EXIT才出现' TYPE 'I'.

    WHEN 'SELF'.
      MESSAGE '您点击了自定义工具栏按钮!' TYPE 'I'.

    WHEN '&IC1'."表示双击
      CHECK rs_selfield-tabindex > 0.
      DATA: lv_str TYPE string.
      lv_str = rs_selfield-tabindex.
      CONCATENATE '您双击了:第' lv_str '行的' rs_selfield-fieldname ',值为:' rs_selfield-value
      INTO lv_str.
      MESSAGE lv_str TYPE 'I'.
  ENDCASE.

  "自动刷新
  rs_selfield-refresh    = 'X'.
  rs_selfield-col_stable = 'X'.
  rs_selfield-row_stable = 'X'.
ENDFORM.                    "FRM_CB_USER_COMMAND

*&---------------------------------------------------------------------*
*&      Form  FRM_CB_TOP_OF_PAGE
*&---------------------------------------------------------------------*
*       ALV 表头设置
*----------------------------------------------------------------------*
FORM frm_cb_top_of_page.
  DATA: lt_grid_top_of_page TYPE slis_t_listheader.
  DATA: ls_line TYPE slis_listheader.
  CLEAR lt_grid_top_of_page[].
  CLEAR ls_line.
  ls_line-typ  = 'H'.         " 只显示 INFO
*  ls_line-key  = '大标题'.     " 不显示
  ls_line-info  = '航空公司订单记录表'.
  APPEND ls_line TO lt_grid_top_of_page.

* STATUS LINE: TYPE S
  CLEAR ls_line.
  ls_line-typ  = 'S'.         " 显示 KEY INFO
  ls_line-key  = '系统日期'.
  CONCATENATE sy-datum+0(4) '年' sy-datum+4(2) '月' sy-datum+6(2)  '日'
              INTO ls_line-info  .
  APPEND ls_line TO lt_grid_top_of_page.

  CLEAR ls_line.
  ls_line-typ  = 'A'.         " 只显示 INFO
*  ls_line-key  = '小标题'.     " 不显示
  ls_line-info  = 'TYP-A'.
  APPEND ls_line TO lt_grid_top_of_page.

  CALL FUNCTION 'REUSE_ALV_COMMENTARY_WRITE'
    EXPORTING
      it_list_commentary = lt_grid_top_of_page.

ENDFORM.                    "FRM_CB_TOP_OF_PAGE

*&---------------------------------------------------------------------*
*&      Form  FRM_CB_HTML_TOP_OF_PAGE
*&---------------------------------------------------------------------*
*       ALV HTML表头设置
*----------------------------------------------------------------------*
FORM frm_cb_html_top_of_page USING cl_dd TYPE REF TO cl_dd_document.
*  说明:使用 ABAP 类 CL_DD_DOCUMENT,定义HTML文档,
*  即:使用HTML语言对表头的输出格式进行控制,包括输出文字的大小,字体及颜色等,
*  总之在HTML语言中能实现的在这里都能实现.
*  当I_CALLBACK_TOP_OF_PAGE和I_CALLBACK_HTML_TOP_OF_PAGE同时设置时,
*  只有I_CALLBACK_HTML_TOP_OF_PAGE起作用.

  DATA: m_p TYPE i.
  DATA: m_buff TYPE string.
*表头其实完全可以是一个html文件,自己使用html语言进行格式控制
  m_buff = '<html>'.
  CALL METHOD cl_dd->html_insert
    EXPORTING
      contents = m_buff
    CHANGING
      position = m_p.

  m_buff = '<H4>航空公司订单记录表</H4>'.
  CALL METHOD cl_dd->html_insert
    EXPORTING
      contents = m_buff
    CHANGING
      position = m_p.

  m_buff = sy-datum.
  CALL METHOD cl_dd->html_insert
    EXPORTING
      contents = m_buff
    CHANGING
      position = m_p.

  m_buff = '</html>'.
  CALL METHOD cl_dd->html_insert
    EXPORTING
      contents = m_buff
    CHANGING
      position = m_p.
ENDFORM.                    "FRM_CB_HTML_TOP_OF_PAGE

*&---------------------------------------------------------------------*
*&      Form  FRM_CB_HTML_END_OF_LIST
*&---------------------------------------------------------------------*
*       ALV HTML表尾设置
*----------------------------------------------------------------------*
FORM frm_cb_html_end_of_list USING document TYPE REF TO cl_dd_document.
  DATA: text TYPE sdydo_text_element.
  text = '自定义表尾信息'.
  CALL METHOD document->add_text
    EXPORTING
      text      = text
      sap_style = 'HEADING'.
  "换行写另一标题
  CALL METHOD document->new_line.
  "缩进
  CALL METHOD document->add_gap
    EXPORTING
      width = 10.                                           "空格宽10
  text = '追加标题'.
  CALL METHOD document->add_text
    EXPORTING
      text      = text
      sap_style = 'HEADING'.
ENDFORM.                    "FRM_CB_HTML_END_OF_LIST

*&---------------------------------------------------------------------*
*&      Form  zfrm_icon_get_iname_by_name
*&---------------------------------------------------------------------*
*       创建带自定义提示符的图标
*----------------------------------------------------------------------*
FORM zfrm_icon_create_by_name
    USING value(fv_icon_name) value(fv_info)
    CHANGING fc_icon_iname.
  CALL FUNCTION 'ICON_CREATE'
    EXPORTING
      name   = fv_icon_name  "图标名字
      info   = fv_info       "图标提示
    IMPORTING
      RESULT = fc_icon_iname
    EXCEPTIONS
      OTHERS = 0.
ENDFORM.                    "zfrm_icon_get_iname_by_name

*&---------------------------------------------------------------------*
*&      Form  zfrm_icon_get_iname_by_name
*&---------------------------------------------------------------------*
*       通过图标名称获取图标内码
*----------------------------------------------------------------------*
FORM zfrm_icon_get_iname_by_name
          USING value(fv_name)
          CHANGING fc_icon_iname.
  DATA: ls_icon TYPE icon.
  SELECT SINGLE * INTO ls_icon FROM icon WHERE name = fv_name.
  IF sy-subrc = 0.
    fc_icon_iname = ls_icon-internal.
  ENDIF.
ENDFORM.                    "zfrm_icon_get_iname_by_name

*&---------------------------------------------------------------------*
*&      Form  zfrm_icon_get_names_by_id
*&---------------------------------------------------------------------*
*       通过图标ID获取图标名称
*----------------------------------------------------------------------*
FORM zfrm_icon_get_names_by_id
          USING value(fv_id)
          CHANGING fc_icon_name fc_icon_iname.
  DATA: ls_icon TYPE icon.
  SELECT SINGLE * INTO ls_icon FROM icon WHERE id = fv_id.
  IF sy-subrc = 0.
    fc_icon_name = ls_icon-name.
    fc_icon_iname = ls_icon-internal.
  ENDIF.
ENDFORM.                    "zfrm_icon_get_names_by_id

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/139178.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

win10下安装多个JDK配置方法

环境变量配置 此电脑 --- 属性 -- 高级系统设置 -- 环境变量 -- 系统变量 -- 新建 1、配置JAVA_HOME JAVA6_HOME jdk1.6的安装路径 JAVA8_HOME jdk1.8的安装路径 JAVA_HOME %JAVA8_HOME% 两个%表示引用变量的值&#xff0c;直接用JAVA_HOME&#xff0c;就能表示一连串长…

SAR影像变化检测方法之(SAR_CD_DDNet(无监督变化检测))论文阅读

一、论文信息 1、论文标题&#xff1a;Change Detection in Synthetic Aperture Radar Images Using a Dual-Domain Network 2、代码链接&#xff1a;https://github.com/summitgao/SAR_CD_DDNet 二、摘要 合成孔径雷达(SAR)图像的变化检测是一项关键而具有挑战性的任务。现…

Android---BottomAppBar

目录 BottomAppBar FloatingActionButton UI 完整代码 BottomAppBar Material Design 的一个重要特征是设计 BottomAppBar 。可适应用户不断变化的需求和行为。因此&#xff0c;BottomAppBar 是一个从标准物质指导的演变。它更注重功能&#xff0c;增加参与…

ansible 第三天

1.挂载本地光盘到/mnt 2.配置yum源仓库文件通过多种方式实现 仓库1 &#xff1a; Name: RH294_Base Description&#xff1a; RH294 base software Base urt: file:///mnt/BaseOS 不需要验证钦件包 GPG 签名 启用此软件仓库 仓库 2: Name: RH294_Stream Description &#xff1…

Android Studio 用WIFI无线调试adb (3种方法)

最近数据线一直被boss借走&#xff0c;一旦借走就无法调试了&#xff0c;所以就打算不用数据线调试了&#xff0c;使用WIFI进行调试。 一、命令 1、首先配置adb环境变量 首先找到andoridSDK的路径中的platform-tools文件夹 &#xff0c;将他的路径复制我的是 C:\Users\YiShi…

365天深度学习训练营-第P7周:YOLOv5-Backbone/YOLOv5-C3模块实现

目录 一、前言 二、我的环境 三、代码实现 1、C3模块 2、Backbone模块 一、前言 >- **&#x1f368; 本文为[&#x1f517;365天深度学习训练营](https://mp.weixin.qq.com/s/xLjALoOD8HPZcH563En8bQ) 中的学习记录博客** >- **&#x1f366; 参考文章&#xff1a;36…

【算法】day03:动态规划dp

努力经营当下&#xff0c;直至未来明朗&#xff01; 文章目录1. 青蛙跳台阶2. 矩形覆盖3. 二进制中1的个数4. 链表中倒数第k个结点普通小孩也要热爱生活&#xff01; 1. 青蛙跳台阶 跳台阶 1&#xff09;思路&#xff1a;如果青蛙在第n个台阶上&#xff0c;那么它要么来自n-1…

python命名规范

1.命名有字母、数字和下划线三个组成 2.项目名、包名、模块名、python文件名 都应该用英文开头&#xff0c;不能纯数字&#xff0c;否则无法识别 3.脚本名不能跟系统模块或三方模块重复 4.函数、类、方法、参数名称不能跟系统现有名称重复 5.类名必须以大写字母开头、除了类…

Kafka在windows下下载、启动、测试详细教程

目录 下载地址 启动 启动zookeeper 启动kafka 队列操作 创建消息队列名 删除消息队列名 查看所有的队列 测试 生产测试 消费测试 下载地址 Apache KafkaApache Kafka: A Distributed Streaming Platform.https://kafka.apache.org/downloadswindows下kafka3.0版本的…

G120系列变频器进行参数备份(上传或下载)的2种基本方法介绍(Startdrive+SD卡)

G120系列变频器进行参数备份(上传或下载)的2种基本方法介绍(Startdrive+SD卡) 1. 通过SINAMICS SD存储卡对G120系列变频器进行参数上传/下载的具体方法 适配范围:CU240B-2(DP)/CU240E-2(DP/PN)/CU250S-2(DP/PN) 可将变频器的参数设置保存至 SINAMICS SD 卡。在进行变频器更…

回归预测 | MATLAB实现CNN-LSTM卷积长短期记忆神经网络多输入多输出

回归预测 | MATLAB实现CNN-LSTM卷积长短期记忆神经网络多输入多输出 目录回归预测 | MATLAB实现CNN-LSTM卷积长短期记忆神经网络多输入多输出预测效果基本介绍程序设计往期精彩参考资料预测效果 基本介绍 MATLAB实现CNN-LSTM卷积长短期记忆神经网络多输入多输出&#xff0c;运行…

docker swarm 集群部署和验证

docker swarm可以轻松的部署集群,实现负载均衡,服务器的扩容和扩容的反义词. 首先docker的官方文档非常的不稳定,梯子也不解决问题.还好有替代 docs.docker.com 用不了 https://docs.docker.com.zh.xy2401.com/engine/swarm/swarm-tutorial/ 很好 场景: 三台机器 x.x.x.104 x.…

经典文献阅读之--FAST-LIVO(Fast-LIO系列的激光视觉惯性里程计)

0. 简介 在此之前博主对Fast-LIO2和R3LIVE进行了系统性的学习。最近文章《Fast and Tightly-coupled Sparse-Direct LiDAR-Inertial-Visual Odometry》提出了FAST-LIVO&#xff0c;这是一种快速LiDAR惯性-视觉里程计系统&#xff0c;它建立在两个紧耦合的直接里程计子系统之上…

结构体、枚举、联合(14)

目录 1、结构体 1、结构的声明 2、特殊的声明 2、结构的自引用 3、结构体变量的定义和初始化 4、结构体内存对齐 1、结构体的对齐规则&#xff1a; 2、为什么存在内存对齐? 3、修改默认对齐数 5、结构体传参 2、枚举 1、枚举类型的定义 2、使用 3、优点 3、联合…

MAC(m1)-Vagrant下载安装

Vagrant是一款用来构建虚拟开发环境的工具&#xff0c;它其实算是一个跨平台的虚拟机管理工具。 Vagrant是构建在虚拟化技术之上的虚拟运行环境管理工具。通过使用Vagrant我们可以快速去构建 我们想要的虚拟环境&#xff0c;同样其搭配virtualbox来进行使用&#xff0c;通过构…

重磅来袭!2023年大版本更新,看看有哪些是你期待的功能和优化吧

Hello&#xff01;好久不见&#xff0c;最近两个月我们的攻城狮和产品汪都在潜心的优化产品&#xff0c;我们将于1月5日上线 v10.7.0版本。本次版本迭代&#xff0c;我们更新了上百项体验优化&#xff0c;并将在未来几周发布更多功能和改进。 本次我们对前端底层架构进行优化重…

vue3笔记案例——Teleport使用之模态框

模态框 理想情况下&#xff0c;我们希望触发模态框的按钮和模态框本身是在同一个组件中&#xff0c;因为它们都与组件的开关状态有关。但这意味着该模态框将与按钮一起渲染在应用 DOM 结构里很深的地方。 使用 Teleport 传送组件可以将组件传送至其他层级的DOM结构中 效果图 …

数据流图实例应用

数据流图实例应用 参考链接&#xff1a; https://blog.csdn.net/xiaoxiang2017/article/details/81460397 https://blog.csdn.net/m0_53130858/article/details/127234104 数据流图&#xff1a;简称DFD&#xff0c;它从数据传递和加工角度&#xff0c;以图形方式来表达系统的逻…

Talk预告 | 几何的魅力: 黑盒攻击新策略

本期为TechBeat人工智能社区第468期线上Talk&#xff01; 北京时间1月4日(周三)20:00&#xff0c;清华大学软件工程专业博士——马晨的Talk将准时在TechBeat人工智能社区开播&#xff01; 他与大家分享的主题是: “几何的魅力&#xff1a;黑盒攻击新策略”&#xff0c;届时将介…

【论文笔记】 Exploration With Task Information for Meta Reinforcement Learning

文章目录【论文笔记】 Exploration With Task Information for Meta Reinforcement LearningAbstractKeywordsI. INTRODUCTIONII. RELATED WORKA. Meta Reinforcement LearningB. Exploration in Meta-RLC. Mutual InformationIII. PRELIMINARIESA. Meta Reinforcement Learnin…