ALV Color-颜色

2024-05-11 10:12
文章标签 颜色 color alv

本文主要是介绍ALV Color-颜色,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

目录

前言

实战

        列颜色

        行颜色

         单元格颜色

前言

        在ABAP ALV中,Color颜色设置是一种增强列表显示效果的重要手段,可以用来突出显示特定行、列或单元格,以吸引用户注意或传达数据的特定状态。

        颜色设置中有优先级顺序,他们是单元格->行->列,即若同时使用了上面的三种更改颜色的方法,则列的颜色会被行的颜色覆盖掉,而行的颜色又会被单元格的颜色覆盖掉,最终只会显示出单元格的颜色。
        如果这列被设置为关键列,就是gs_fieldcat-KEY = 'X' ,那么颜色设置就不会起作用。

实战

        列颜色

        直接设置字段列的fieldcat-emphasize属性;
                 gs_fieldcat-emphasize = 'C310'.

        行颜色

        ALV中的每行数据颜色是通过Layout来控制的。需要在显示输出内表结构中增加一列字段,用来存储数据行的颜色。
            gs_layout-info_fieldname = 'COLOR'.

        ALV中的颜色是由4位数组成:'C'+COL+INT+INV

        参数结构如下:

*** Structure for colors
types: begin of slis_color,col type i,int type i,inv type i,end of slis_color.

        详细解释:

                第1位:固定取值C;
                第2位-COL:颜色值,取值为0~7;

                第3位-INT:高亮,即颜色是否加深,取值为0、1;(1表示加深显示)
                第4位-INV:颜色是否反转,即颜色是作用在背景上,还是作用在输出字符上,取值上为0、1(为1时表示设置的是前景色,即输出字符本身的颜色,好像只有在第3位为0时才有效?) 

        颜色值测试表:

        完整代码:

TYPE-POOLS:slis.
DATA: gt_fieldcat TYPE slis_t_fieldcat_alv WITH HEADER LINE.
DATA: gs_layout TYPE slis_layout_alv.DATA:BEGIN OF gt_data OCCURS 0,val1(4),"颜色值val2(4),"颜色值color(4),"用来存储行颜色END OF gt_data.START-OF-SELECTION.PERFORM f_inital.DEFINE f_fdcat.clear gt_fieldcat.gt_fieldcat-fieldname = &1.gt_fieldcat-seltext_l = &2.append gt_fieldcat.END-OF-DEFINITION.f_fdcat 'VAL1' '行颜色值'.f_fdcat 'VAL2' '行颜色值'.gs_layout-info_fieldname = 'COLOR'." 指定哪一列用来作为行颜色的列CALL FUNCTION 'REUSE_ALV_GRID_DISPLAY'EXPORTINGit_fieldcat = gt_fieldcat[]is_layout   = gs_layoutTABLESt_outtab    = gt_data.FORM f_inital .DATA: c1,c2,c3.DO 8 TIMES.c1 = sy-index - 1.DO 2 TIMES.c2 = sy-index - 1.DO 2 TIMES.c3 = sy-index - 1.CONCATENATE 'C' c1 c2 c3 INTO gt_data-color.gt_data-val1 = gt_data-color.gt_data-val2 = gt_data-color.APPEND gt_data.ENDDO.ENDDO.ENDDO.
ENDFORM.

         单元格颜色

         每个单元格的颜色也是可以单独进行设置的,当然既然可以给单元格设置颜色,则整列相同颜色也是可以采用此方式来设置的。
        gs_layout-coltab_fieldname = 'COLORTABLE'

        展示效果:

        完整代码:

TYPE-POOLS:slis.
DATA: gt_fieldcat TYPE slis_t_fieldcat_alv WITH HEADER LINE.
DATA: gs_layout TYPE slis_layout_alv.DATA:BEGIN OF gt_data OCCURS 0,val1(40),"颜色值val2(40),"颜色值val3(40),colortable TYPE slis_t_specialcol_alv, "每行中的单元格颜色内表,可对多个单元格进行不同颜色设置END OF gt_data.
"每行中单元格颜色列表
DATA: gt_color TYPE slis_t_specialcol_alv WITH HEADER LINE.START-OF-SELECTION.PERFORM f_inital.DEFINE def_fdcat.clear gt_fieldcat.gt_fieldcat-fieldname = &1.gt_fieldcat-seltext_l = &2.append gt_fieldcat.END-OF-DEFINITION.def_fdcat 'VAL1' '颜色值'.def_fdcat 'VAL2' '颜色值'.def_fdcat 'VAL3' '无颜色'.gs_layout-colwidth_optimize = 'X'.gs_layout-coltab_fieldname = 'COLORTABLE'."设置输出内表中哪列为颜色列表CALL FUNCTION 'REUSE_ALV_GRID_DISPLAY'EXPORTINGit_fieldcat = gt_fieldcat[]is_layout   = gs_layoutTABLESt_outtab    = gt_data.FORM f_inital .DATA: c1,c2.DO 7 TIMES.c1 = gt_color-color-col = sy-index - 1."颜色值DO 2 TIMES.c2 = gt_color-color-int =  sy-index - 1."颜色亮度gt_color-color-inv = '0'."颜色作用于背景CASE sy-index .WHEN 1.gt_color-fieldname = 'VAL1'."需进行颜色设置的列名(已具体到单元格)CONCATENATE 'col=' c1 ` ` 'int=' c2 ` `  'inv=0'  INTO gt_data-val1 .WHEN 2.gt_color-fieldname = 'VAL2'."需进行颜色设置的列名(已具体到单元格)CONCATENATE 'col=' c1 ` ` 'int=' c2 ` `  'inv=0'  INTO gt_data-val2 .ENDCASE.APPEND gt_color.ENDDO."设置每行数据中单元格的颜色内表gt_data-colortable = gt_color[].gt_data-val3 = '无颜色'.APPEND gt_data.CLEAR:gt_color,gt_color[].ENDDO.
ENDFORM.

这篇关于ALV Color-颜色的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/979243

相关文章

改变背景颜色+碰撞检测

1.让类继承CCLayerColor比如 class HelloWorld:public cocos2d::CCLayerColor{ public : 在.cpp文件中 bool HelloWorld::init(){ if(!CCLayerColor::initWithColor(ccc4(255,255,255,25

服装盘点机在服装行业颜色尺码仓库条码高效管理中的应用

服装行业的商品管理的特点是需要管理颜色和尺码 具体逻辑就是: 什么商品,什么颜色,什么尺码,入库多少个? 什么商品,什么颜色,什么尺码,出库多少个? 什么商品,什么颜色,什么尺码,还有库存多少个? 如果使用服装盘点机PDA实现仓库条码管理,商品在入库时,根据颜色,尺码,贴好条码。这样就可以扫描条码入库,出库,盘点,调拨,配送,库存查询。管理起来轻松,高效,准确。 以盘点为例: 1。扫

CSS盒模型--边框设置:border: 1px solid red(像素 样式 颜色 ),border-bottom:1px dotted #ccc

盒模型--边框(一) 盒子模型的边框就是围绕着内容及补白的线,这条线你可以设置它的粗细、样式和颜色(边框三个属性)。 如下面代码为div来设置边框粗细为2px、样式为实心的、颜色为红色的边框: div{border:2px solid red;} 上面是border代码的缩写形式,可以分开写: div{border-width:2px;border-style:solid;bord

关于DevDxpress GridView的列标题如何文本多颜色表示问题且标题换行

前面写了一篇DevExpress Winform的Html 格式文本支持的控件和便签写法,这里就简单介绍关于GridView的列标题如何实现文本多颜色的方法,设置GridView列的文本为Html Formting前,首先设置 GridView.OptionView.AllowHtmlDrawColumnHeader=true; 接下来设置Column的Caption的文本 gridC

DevExpress GridView 单元格进度条的绑定及拓展自定义进度条不同颜色显示

DevExpress提供进度条的控件ProgressBarControl,并且能在GridView的单元格中使用,效果图如图所示 关于单元格绑定progressBarControl,这里我简单介绍一下,列的ColumnEdit属性选择ProgressBarControl,然后设置选择的repositoryitemprogressBar1的ShowTitle属性来显示中间的百分数文本即可(其中

DevExpress GridView列标题自定义背景颜色

(Dev 19.2版本不需要这些处理,默认就可以直接设置颜色) DevExpress GridView 列标题的颜色是跟随皮肤的,直接修改BackColor是无效的,除非去掉皮肤,若不想去皮肤或者修改皮肤的话,可以采用gridview的CustomDrawColumnHeader事件去处理, 注册这个事件,颜色设置直接设置GridColumn的backColor即可。 注册事件:   g

ios设置导航栏背景图片、返回按钮背景、标题颜色等等

在ios程序的编写过程中,很多时候我们都要自定义自己的UI,而不是使用cocoatouch中原有的。说起对UI的更改,很多时候我们只是修改一下原有UI的背景啊,颜色之类的,以达到新的要求。     在此之前呢,设置UINavigationController的背景颜色,我会使用如下的代码: 首先看.h文件 #import <UIKit/UIKit.h>@interface UI

iOS圆形颜色选择器

最近公司做一款彩色灯,涉及到app控制灯的颜色,这样就催生了这个需求:做一个颜色选择器。 做完后的效果如下: 实现源码:https://github.com/hpy8804/ColorPickerDemo

spark graphx 可视化:不同属性结点指定不同颜色

普通图: 节点指定颜色的图: 方法: 自定义节点的属性如: 属性文件stylesheets,内容如下,ip节点颜色是红色 edge {    shape: cubic-curve;    fill-color: #dd1c77;    z-index: 0;    text-background-mode: rounded-box;    text-background-color:

Xamarin.Forms 判断颜色亮度

Color ColorToContrastColor(Color color)         {             // Standard luminance calculation.                          double luminance = 0.30 * color.R + 0.59 * color.G + 0.11 * color.B;