更改网格中列的背景颜色

Bil*_*eed 4 axapta dynamics-ax-2009 dynamics-ax-2012

我有以下表格,我想根据其他列的值更改列的背景颜色; 在此输入图像描述

在橙色列中,我希望单元格颜色是COLOR ATTRIBUTES部分下的红色,绿色和蓝色字段的RGB组合,而不是显示橙色背景.

10p*_*10p 6

假设您需要更改其背景的控件名为FirstFieldControl.其设置AutoDeclaration属性YesBackgroundColorWindow background.

现在您需要覆盖displayOption数据源上的方法,例如:

public void displayOption(Common _record, FormRowDisplayOption _options)
{
    YourTable   yourTable   = _record;
    int         color;
    ;

    switch (yourTable.Name)
    {
         case 'Red' :
                 color = WINAPI::rgbCon2int([255, 0, 0]);
                 break;
         case 'Green' :
                 color = WINAPI::rgbCon2int([0, 255, 0]);
                 break;
         case 'Blue' :
                 color = WINAPI::rgbCon2int([0, 0, 255]);
                 break;
    }

    if (color)
    {
        _options.backColor(color);
        _options.affectedElementsByControl(FirstFieldControl.id());
    }
    else
    {
        super(_record, _options);
    }
}
Run Code Online (Sandbox Code Playgroud)

这只是一个给你一个想法的例子 - 不要复制粘贴:)

将颜色值存储在表格中更容易,然后代码会更好.

PS如果您要更改颜色运行时,可能需要使用以下代码刷新记录:

yourTable_ds.clearDisplayOption(yourTable);
yourTable_ds.refresh();
Run Code Online (Sandbox Code Playgroud)