Bil*_*eed 4 axapta dynamics-ax-2009 dynamics-ax-2012
我有以下表格,我想根据其他列的值更改列的背景颜色;

在橙色列中,我希望单元格颜色是COLOR ATTRIBUTES部分下的红色,绿色和蓝色字段的RGB组合,而不是显示橙色背景.
假设您需要更改其背景的控件名为FirstFieldControl.其设置AutoDeclaration属性Yes和BackgroundColor到Window 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)
| 归档时间: |
|
| 查看次数: |
8393 次 |
| 最近记录: |