热门标签 | 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



推荐阅读
  • 开发笔记:9.八大排序
    开发笔记:9.八大排序 ... [详细]
  • 本文深入探讨了HTTP请求和响应对象的使用,详细介绍了如何通过响应对象向客户端发送数据、处理中文乱码问题以及常见的HTTP状态码。此外,还涵盖了文件下载、请求重定向、请求转发等高级功能。 ... [详细]
  • PHP 过滤器详解
    本文深入探讨了 PHP 中的过滤器机制,包括常见的 $_SERVER 变量、filter_has_var() 函数、filter_id() 函数、filter_input() 函数及其数组形式、filter_list() 函数以及 filter_var() 和其数组形式。同时,详细介绍了各种过滤器的用途和用法。 ... [详细]
  • 本文详细介绍了 iBatis.NET 中的 Iterate 元素,它用于遍历集合并重复生成每个项目的主体内容。通过该元素,可以实现类似于 foreach 的功能,尽管 iBatis.NET 并未直接提供 foreach 标签。 ... [详细]
  • 本题探讨了在一个有向图中,如何根据特定规则将城市划分为若干个区域,使得每个区域内的城市之间能够相互到达,并且划分的区域数量最少。题目提供了时间限制和内存限制,要求在给定的城市和道路信息下,计算出最少需要划分的区域数量。 ... [详细]
  • 本文详细探讨了HTML表单中GET和POST请求的区别,包括它们的工作原理、数据传输方式、安全性及适用场景。同时,通过实例展示了如何在Servlet中处理这两种请求。 ... [详细]
  • 本文将介绍网易NEC CSS框架的规范及其在实际项目中的应用。通过详细解析其分类和命名规则,探讨如何编写高效、可维护的CSS代码,并分享一些实用的学习心得。 ... [详细]
  • Java 数组及其常用操作
    本文详细介绍了 Java 中的数组类型、定义方法以及常见操作,帮助开发者更好地理解和使用 Java 数组。 ... [详细]
  • 本文介绍了Android开发中Intent的基本概念及其在不同Activity之间的数据传递方式,详细展示了如何通过Intent实现Activity间的跳转和数据传输。 ... [详细]
  • 本文将详细探讨Linux pinctrl子系统的各个关键数据结构,帮助读者深入了解其内部机制。通过分析这些数据结构及其相互关系,我们将进一步理解pinctrl子系统的工作原理和设计思路。 ... [详细]
  • Struts与Spring框架的集成指南
    本文详细介绍了如何将Struts和Spring两个流行的Java Web开发框架进行整合,涵盖从环境配置到代码实现的具体步骤。 ... [详细]
  • Kubernetes 持久化存储与数据卷详解
    本文深入探讨 Kubernetes 中持久化存储的使用场景、PV/PVC/StorageClass 的基本操作及其实现原理,旨在帮助读者理解如何高效管理容器化应用的数据持久化需求。 ... [详细]
  • 本文将探讨Java编程语言中对象和类的核心概念,帮助读者更好地理解和应用面向对象编程的思想。通过实际例子和代码演示,我们将揭示如何在Java中定义、创建和使用对象。 ... [详细]
  • Hadoop发行版本选择指南:技术解析与应用实践
    本文详细介绍了Hadoop的不同发行版本及其特点,帮助读者根据实际需求选择最合适的Hadoop版本。内容涵盖Apache Hadoop、Cloudera CDH等主流版本的特性及应用场景。 ... [详细]
  • 本文深入探讨了SQL数据库中常见的面试问题,包括如何获取自增字段的当前值、防止SQL注入的方法、游标的作用与使用、索引的形式及其优缺点,以及事务和存储过程的概念。通过详细的解答和示例,帮助读者更好地理解和应对这些技术问题。 ... [详细]
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社区 版权所有