热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

关于ALV颜色的控制

本文转自http:scnblogs.techweb.com.cnqq19851116archives3.htmlALV的颜色控制可以分3中级别:1.数据LIST中某一

本文转自http://scnblogs.techweb.com.cn/qq19851116/archives/3.html

ALV的颜色控制可以分3中级别:

1.数据LIST中某一行颜色的控制

2.数据LIST中某一列颜色的控制

3.数据LIST中某个单元格颜色的控制

如果在ALV中这三种颜色控制同时存在时,它们会有一个优先级的。单元格控制的优先级别最高,下来是行控制的优先级,最后是列控制的优先级。

效果如下

ALV颜色控制

代码如下

TH_LAYOUT-coltab_fieldname

这个属性里面放的是内表中表示行颜色字段的CODE

TH_FIELDCAT-emphasize = ‘C110′.

这个属性里面放的是内表中表示列颜色字段的属性,在ALV的FIELDCAT属相设置时把颜色代码值(C110)填入即可.

TH_LAYOUT-info_fieldname = ‘LNCOLOR’.

这里面放的字段是内表中单元格颜色字段的CODE.

    COLOR     TYPE slis_t_specialcol_alv,

   在内表中要定义一个字段(COLOR)参考这个内表,slis_t_specialcol_alv它里面有FIELDNAME,COL,INT,INV属性需要设置。分别是字段名字,颜色代码,背景深浅度,字体深浅度控制。

      TH_COLOR-fieldname = ‘COUNTRYFR’.
      TH_COLOR-color-col = ‘6′.
      TH_COLOR-color-int = ‘1′.
      TH_COLOR-color-inv = ‘1′.
REPORT  ZTEST_SPFLI MESSAGE-ID zf.

INCLUDE .

INCLUDE .

TYPE-POOLS:slis.

TABLES:
  SPFLI.

TYPES:
  BEGIN OF TYP_SPFLI,
    CARRID    TYPE SPFLI-CARRID,
    CONNID    TYPE SPFLI-CONNID,
    COUNTRYFR TYPE SPFLI-COUNTRYFR,
    COUNTRYTO TYPE SPFLI-COUNTRYTO,
    CITYFROM  TYPE SPFLI-CITYFROM,
    CITYTO    TYPE SPFLI-CITYTO,
  END OF TYP_SPFLI,

  BEGIN OF TYP_OUTPUT,
    CHECK     TYPE C,
    ICON      TYPE icon_d,
    SYMBOL    TYPE icon_d,
    CARRID    TYPE SPFLI-CARRID,
    CONNID    TYPE SPFLI-CONNID,
    COUNTRYFR TYPE SPFLI-COUNTRYFR,
    COUNTRYTO TYPE SPFLI-COUNTRYTO,
    CITYFROM  TYPE SPFLI-CITYFROM,
    CITYTO    TYPE SPFLI-CITYTO,
    COLOR     TYPE slis_t_specialcol_alv,
    LNCOLOR   TYPE CHAR4,
    HAND      TYPE INT4,
    LINK      TYPE string,
  END OF TYP_OUTPUT.

DATA:
  TH_SPFLI TYPE TYP_SPFLI,
  TD_SPFLI TYPE TABLE OF TYP_SPFLI,

  BEGIN OF TYP_DATA.
   INCLUDE STRUCTURE zcddi.
   DATA: A1 TYPE C,
         A3 TYPE N,
* zcddi
  END OF TYP_DATA,

  TH_COLOR TYPE slis_specialcol_alv,
  TD_COLOR TYPE TABLE OF slis_specialcol_alv,

  TH_LAYOUT TYPE SLIS_LAYOUT_ALV,
  TH_FIELDCAT TYPE slis_fieldcat_alv,
  TD_FIELDCAT TYPE TABLE OF slis_fieldcat_alv,

  TH_OUTPUT TYPE TYP_OUTPUT,
  TD_OUTPUT TYPE TABLE OF TYP_OUTPUT.
START-OF-SELECTION.

* PARAMETERS:      gjahr LIKE glpca-RYEAR MEMORY ID gjr OBLIGATORY.

 SELECT-OPTIONS:
   S_CARRID FOR SPFLI-CARRID,
   S_CONNID FOR SPFLI-CONNID.

 PERFORM FRM_GET_DATA.

 PERFORM FRM_EDIT_DATA.

 PERFORM FRM_DISPLAY_DATA.

*&———————————————————————*
*&      Form  FRM_GET_DATA
*&———————————————————————*
*       GET MAIN DATA
*———————————————————————-*
FORM FRM_GET_DATA .

  SELECT  CARRID
          CONNID
          COUNTRYFR
          COUNTRYTO
          CITYFROM
          CITYTO
   INTO  TABLE TD_SPFLI
   FROM   SPFLI
  WHERE CARRID IN S_CARRID
    AND CONNID IN S_CONNID.

 IF SY-SUBRC <> 0.
   MESSAGE S001 DISPLAY LIKE ‘E’.
   LEAVE LIST-PROCESSING.
 ENDIF.
ENDFORM.                    ” FRM_GET_DATA
*&———————————————————————*
*&      Form  FRM_DISPLAY_DATA
*&———————————————————————*
*       text
*———————————————————————-*
*  –>  p1        text
*  <–  p2        text
*———————————————————————-*
FORM FRM_DISPLAY_DATA .
  PERFORM FRM_SET_TITLE.

  PERFORM FRM_SET_FIELDCAT.
  PERFORM FRM_CALL_FUNCTION.
ENDFORM.                    ” FRM_DISPLAY_DATA

*&———————————————————————*
*&      Form  FRM_SET_TITLE
*&———————————————————————*
*       text
*———————————————————————-*
*  –>  p1        text
*  <–  p2        text
*———————————————————————-*
FORM FRM_SET_TITLE .
  TH_LAYOUT-colwidth_optimize &#61; ‘X’.
  TH_LAYOUT-coltab_fieldname &#61; ‘COLOR’.
  TH_LAYOUT-window_titlebar  &#61; ’spfli data’.
  TH_LAYOUT-detail_popup &#61; ‘X’.
  TH_LAYOUT-COLWIDTH_OPTIMIZE &#61; ‘X’.
  TH_LAYOUT-info_fieldname &#61; ‘LNCOLOR’.
ENDFORM.                    ” FRM_SET_TITLE
*&———————————————————————*
*&      Form  FRM_SET_FIELDCAT
*&———————————————————————*
*       text
*———————————————————————-*
*  –>  p1        text
*  <–  p2        text
*———————————————————————-*
FORM FRM_SET_FIELDCAT .
  PERFORM FRM_SET_VALUE USING ‘1′ ‘CHECK’  ‘CHECK’ ‘1′ ‘X’.
  PERFORM FRM_SET_VALUE USING ‘2′ ‘ICON’   ‘ICON’ ‘5′ ‘ ‘.
  PERFORM FRM_SET_VALUE USING ‘3′ ‘SYMBOL’ ‘SYMBOL’ ‘5′ ‘ ‘.

  PERFORM FRM_SET_VALUE USING ‘4′ ‘CARRID’ ‘航线承运人ID’ ‘3′ ”.
  PERFORM FRM_SET_VALUE USING ‘5′ ‘CONNID’ ‘航班连接 Id’ ‘4′ ”.
  PERFORM FRM_SET_VALUE USING ‘6′ ‘COUNTRYFR’ ‘国家代码FROM’ ‘3′ ”.
  PERFORM FRM_SET_VALUE USING ‘7′ ‘COUNTRYTO’ ‘国家代码TO’ ‘3′ ”.
  PERFORM FRM_SET_VALUE USING ‘8′ ‘CITYFROM’ ‘起飞城市’ ‘20′ ”.
  PERFORM FRM_SET_VALUE USING ‘9′ ‘CITYTO’ ‘目标城市’ ‘20′ ”.

ENDFORM.                    ” FRM_SET_FIELDCAT
*&———————————————————————*
*&      Form  FRM_SET_VALUE
*&———————————————————————*
*       text
*———————————————————————-*
*      –>P_COL_POS  text   NO_ROWMARK
*      –>P_FIELDNAME  text
*      –>P_SELTEXT_L  text
*      –>P_OUTPUTLEN  text
*———————————————————————-*
FORM FRM_SET_VALUE  USING    I_COL_POS
                             I_FIELDNAME
                             I_SELTEXT_L
                             I_OUTPUTLEN
                             I_CHECKBOX.

 TH_FIELDCAT-COL_POS &#61;   I_COL_POS.
 TH_FIELDCAT-FIELDNAME &#61; I_FIELDNAME.
 TH_FIELDCAT-SELTEXT_L &#61; I_SELTEXT_L.
 TH_FIELDCAT-OUTPUTLEN &#61; I_OUTPUTLEN.
 IF I_FIELDNAME &#61; ‘CARRID’.

 ELSEIF I_FIELDNAME &#61; ‘CHECK’.
  TH_FIELDCAT-SELTEXT_M &#61; ‘SELECT’.
  TH_FIELDCAT-CHECKBOX &#61; ‘X’.
  TH_FIELDCAT-OUTPUTLEN &#61; 1.
  TH_FIELDCAT-EDIT &#61; ‘X’.
ELSEIF I_FIELDNAME &#61; ‘CITYFROM’ OR I_FIELDNAME &#61; ‘CITYTO’.
  TH_FIELDCAT-emphasize &#61; ‘C110′.
ELSEIF I_FIELDNAME &#61; ‘ICON’.
  TH_FIELDCAT-icon &#61; ‘X’.
ELSEIF I_FIELDNAME &#61; ‘SYMBOL’.
  TH_FIELDCAT-symbol &#61; ‘X’.
ENDIF.
 APPEND TH_FIELDCAT TO TD_FIELDCAT.
 CLEAR TH_FIELDCAT.

ENDFORM.                    ” FRM_SET_VALUE
*&———————————————————————*
*&      Form  FRM_CALL_FUNCTION
*&———————————————————————*
*       text
*———————————————————————-*
*  –>  p1        text
*  <–  p2        text
*———————————————————————-*
FORM FRM_CALL_FUNCTION .
  CALL FUNCTION ‘REUSE_ALV_GRID_DISPLAY’
    EXPORTING
     I_CALLBACK_USER_COMMAND           &#61; ‘FRM_SET_COMMAND’
     IS_LAYOUT                         &#61; TH_LAYOUT
     IT_FIELDCAT                       &#61; TD_FIELDCAT
     I_SAVE                            &#61; ‘A’
    TABLES
      T_OUTTAB                          &#61; TD_OUTPUT
    EXCEPTIONS
      PROGRAM_ERROR                     &#61; 1
      OTHERS                            &#61; 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.                    ” FRM_CALL_FUNCTION
*&———————————————————————*
*&      Form  FRM_EDIT_DATA
*&———————————————————————*
*       text
*———————————————————————-*
*  –>  p1        text
*  <–  p2        text
*———————————————————————-*
FORM FRM_EDIT_DATA .
  DATA:
    LW_INDEX TYPE SY-INDEX,
    LW_MOD   TYPE I.
  LOOP AT TD_SPFLI INTO TH_SPFLI.
    LW_INDEX &#61; SY-TABIX.
    LW_MOD &#61; LW_INDEX MOD 3.

    IF TH_SPFLI-CARRID IS INITIAL .

      TH_COLOR-fieldname &#61; ‘CARRID’.
      TH_COLOR-color-col &#61; ‘6′.
      TH_COLOR-color-int &#61; ‘1′.
      TH_COLOR-color-inv &#61; ‘1′.
      APPEND TH_COLOR TO TD_COLOR.
      CLEAR TH_COLOR.
    ENDIF.

    IF TH_SPFLI-CONNID IS INITIAL.
      TH_COLOR-fieldname &#61; ‘CONNID’.
      TH_COLOR-color-col &#61; ‘6′.
      TH_COLOR-color-int &#61; ‘1′.
      TH_COLOR-color-inv &#61; ‘1′.
      APPEND TH_COLOR TO TD_COLOR.
      CLEAR TH_COLOR.
    ENDIF.

    IF TH_SPFLI-COUNTRYFR IS INITIAL.
      TH_COLOR-fieldname &#61; ‘COUNTRYFR’.
      TH_COLOR-color-col &#61; ‘6′.
      TH_COLOR-color-int &#61; ‘1′.
      TH_COLOR-color-inv &#61; ‘1′.
      APPEND TH_COLOR TO TD_COLOR.
      CLEAR TH_COLOR.
    ENDIF.

    IF TH_SPFLI-COUNTRYTO IS INITIAL.
      TH_COLOR-fieldname &#61; ‘COUNTRYTO’.
      TH_COLOR-color-col &#61; ‘6′.
      TH_COLOR-color-int &#61; ‘1′.
      TH_COLOR-color-inv &#61; ‘1′.
      APPEND TH_COLOR TO TD_COLOR.
      CLEAR TH_COLOR.
    ELSEIF TH_SPFLI-COUNTRYTO &#61; ‘MQ’.
      TH_COLOR-fieldname &#61; ‘COUNTRYTO’.
      TH_COLOR-color-col &#61; ‘5′.
      TH_COLOR-color-int &#61; ‘1′.
      TH_COLOR-color-inv &#61; ‘1′.
      APPEND TH_COLOR TO TD_COLOR.
      CLEAR TH_COLOR.
    ELSEIF TH_SPFLI-COUNTRYTO &#61; ‘CA’.
      TH_COLOR-fieldname &#61; ‘COUNTRYTO’.
      TH_COLOR-color-col &#61; ‘7′.
      TH_COLOR-color-int &#61; ‘1′.
      TH_COLOR-color-inv &#61; ‘1′.
      APPEND TH_COLOR TO TD_COLOR.
      CLEAR TH_COLOR.
    ENDIF.

    IF TH_SPFLI-CITYFROM IS INITIAL.
      TH_COLOR-fieldname &#61; ‘CITYFROM’.
      TH_COLOR-color-col &#61; ‘6′.
      TH_COLOR-color-int &#61; ‘1′.
      TH_COLOR-color-inv &#61; ‘1′.
      APPEND TH_COLOR TO TD_COLOR.
      CLEAR TH_COLOR.
    ENDIF.

    IF TH_SPFLI-CITYTO IS INITIAL.
      TH_COLOR-fieldname &#61; ‘CITYTO’.
      TH_COLOR-color-col &#61; ‘6′.
      TH_COLOR-color-int &#61; ‘1′.
      TH_COLOR-color-inv &#61; ‘1′.
      APPEND TH_COLOR TO TD_COLOR.
      CLEAR TH_COLOR.
    ENDIF.

    MOVE-CORRESPONDING  TH_SPFLI TO TH_OUTPUT .
    CLEAR TH_SPFLI.
    TH_OUTPUT-COLOR[] &#61; TD_COLOR[].

    IF LW_INDEX >&#61; 3 AND LW_INDEX &#61;<13.
      TH_OUTPUT-LNCOLOR &#61; ‘C700′.
    ENDIF.

*    TH_OUTPUT-HAND   &#61; SY-TABIX.
*    TH_OUTPUT-LINK   &#61; ‘WWW.BAIDU.COM’.
  IF LW_MOD <> 0.
    TH_OUTPUT-ICON   &#61; ICON_TIME.
    TH_OUTPUT-SYMBOL &#61; SYM_LEFT_HAND.
  ELSE.
    TH_OUTPUT-ICON   &#61; ICON_COLOR.
    TH_OUTPUT-SYMBOL &#61; sym_folder.
  ENDIF.
    APPEND TH_OUTPUT TO TD_OUTPUT.
    CLEAR:
      LW_INDEX,
      LW_MOD,
      TH_OUTPUT.
    REFRESH:
      TD_COLOR.
  ENDLOOP.
ENDFORM.                    ” FRM_EDIT_DATA

FORM FRM_SET_COMMAND USING r_ucomm LIKE sy-ucomm
                  rs_selfield TYPE slis_selfield.

  CASE r_ucomm.
      WHEN ‘&IC1′. “双击事件

*        READ TABLE itab INTO wa INDEX rs_selfield-tabindex.
*
*        SET PARAMETER ID ‘BLN’ FIELD wa-belnr.
*        SET PARAMETER ID ‘BUK’ FIELD wa-bukrs.
*        SET PARAMETER ID ‘GJR’ FIELD wa-gjahr.
*
*        CALL TRANSACTION ‘FB03′ AND SKIP FIRST SCREEN.
    ENDCASE.

ENDFORM.

转:https://www.cnblogs.com/kalasitifen/archive/2012/10/16/2725890.html



推荐阅读
  • UNP 第9章:主机名与地址转换
    本章探讨了用于在主机名和数值地址之间进行转换的函数,如gethostbyname和gethostbyaddr。此外,还介绍了getservbyname和getservbyport函数,用于在服务器名和端口号之间进行转换。 ... [详细]
  • 在Ubuntu 16.04 LTS上配置Qt Creator开发环境
    本文详细介绍了如何在Ubuntu 16.04 LTS系统中安装和配置Qt Creator,涵盖了从下载到安装的全过程,并提供了常见问题的解决方案。 ... [详细]
  • 深入探讨CPU虚拟化与KVM内存管理
    本文详细介绍了现代服务器架构中的CPU虚拟化技术,包括SMP、NUMA和MPP三种多处理器结构,并深入探讨了KVM的内存虚拟化机制。通过对比不同架构的特点和应用场景,帮助读者理解如何选择最适合的架构以优化性能。 ... [详细]
  • 本文详细介绍如何使用arm-eabi-gdb调试Android平台上的C/C++程序。通过具体步骤和实用技巧,帮助开发者更高效地进行调试工作。 ... [详细]
  • 技术分享:从动态网站提取站点密钥的解决方案
    本文探讨了如何从动态网站中提取站点密钥,特别是针对验证码(reCAPTCHA)的处理方法。通过结合Selenium和requests库,提供了详细的代码示例和优化建议。 ... [详细]
  • 导航栏样式练习:项目实例解析
    本文详细介绍了如何创建一个具有动态效果的导航栏,包括HTML、CSS和JavaScript代码的实现,并附有详细的说明和效果图。 ... [详细]
  • 1:有如下一段程序:packagea.b.c;publicclassTest{privatestaticinti0;publicintgetNext(){return ... [详细]
  • 本文介绍了Java并发库中的阻塞队列(BlockingQueue)及其典型应用场景。通过具体实例,展示了如何利用LinkedBlockingQueue实现线程间高效、安全的数据传递,并结合线程池和原子类优化性能。 ... [详细]
  • 深入理解 SQL 视图、存储过程与事务
    本文详细介绍了SQL中的视图、存储过程和事务的概念及应用。视图为用户提供了一种灵活的数据查询方式,存储过程则封装了复杂的SQL逻辑,而事务确保了数据库操作的完整性和一致性。 ... [详细]
  • 使用 Azure Service Principal 和 Microsoft Graph API 获取 AAD 用户列表
    本文介绍了一段通用代码示例,该代码不仅能够操作 Azure Active Directory (AAD),还可以通过 Azure Service Principal 的授权访问和管理 Azure 订阅资源。Azure 的架构可以分为两个层级:AAD 和 Subscription。 ... [详细]
  • 本文详细介绍了Java编程语言中的核心概念和常见面试问题,包括集合类、数据结构、线程处理、Java虚拟机(JVM)、HTTP协议以及Git操作等方面的内容。通过深入分析每个主题,帮助读者更好地理解Java的关键特性和最佳实践。 ... [详细]
  • DNN Community 和 Professional 版本的主要差异
    本文详细解析了 DotNetNuke (DNN) 的两种主要版本:Community 和 Professional。通过对比两者的功能和附加组件,帮助用户选择最适合其需求的版本。 ... [详细]
  • XNA 3.0 游戏编程:从 XML 文件加载数据
    本文介绍如何在 XNA 3.0 游戏项目中从 XML 文件加载数据。我们将探讨如何将 XML 数据序列化为二进制文件,并通过内容管道加载到游戏中。此外,还会涉及自定义类型读取器和写入器的实现。 ... [详细]
  • 本文详细介绍了美国最具影响力的十大财团,包括洛克菲勒、摩根、花旗银行等。这些财团在历史发展过程中逐渐形成,并对美国的经济、政治和社会产生深远影响。 ... [详细]
  • 基于KVM的SRIOV直通配置及性能测试
    SRIOV介绍、VF直通配置,以及包转发率性能测试小慢哥的原创文章,欢迎转载目录?1.SRIOV介绍?2.环境说明?3.开启SRIOV?4.生成VF?5.VF ... [详细]
author-avatar
ytdytduyufy_100
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有