二开案例.表格控件.前景色
【应用场景】设置表格控件的数据行的前景色。
【案例演示】采购订单的明细信息,设置单双行显示不同的颜色。
【实现步骤】
<1>编写单据插件,实现设置指定单元格前景色的功能,代码如下。
using Kingdee.BOS.Core.Bill.PlugIn;
using Kingdee.BOS.Core.DynamicForm.PlugIn.Args;
using Kingdee.BOS.Core.DynamicForm.PlugIn.ControlModel;
using Kingdee.BOS.Util;
using System.Collections.Generic;
using System.ComponentModel;
namespace Jac.XkDemo.BOS.Business.PlugIn
{
/// <summary>
/// 【单据插件】设置表格前景色
/// </summary>
[Description("【单据插件】设置表格前景色"), HotUpdate]
public class GridSetForeColorBillPlugIn : AbstractBillPlugIn
{
private bool reset = true;
public override void EntryBarItemClick(BarItemClickEventArgs e)
{
base.EntryBarItemClick(e);
reset = !reset;
var rowCount = this.View.Model.GetEntryRowCount("FPOOrderEntry");
if (rowCount <= 0)
{
return;
}
var backColor0 = reset ? "" : "#FF0000";
var backColor1 = reset ? "" : "#FF00FF";
var grid = this.View.GetControl<EntryGrid>("FPOOrderEntry");
#region 设置指定字段的某一行的前景色
if (e.BarItemKey == "tbSetForeColor")
{
for (var x = 0; x < rowCount; ++x)
{
var backColor = x % 2 == 0 ? backColor0 : backColor1;
grid.SetForecolor("FMaterialId", backColor, x);
}
}
#endregion
#region 批量设置指定字段的某一行的背景色
if (e.BarItemKey == "tbSetForeColorBatch")
{
var colors = new List<KeyValuePair<int, string>>();
for (var x = 0; x < rowCount; ++x)
{
var backColor = x % 2 == 0 ? backColor0 : backColor1;
colors.Add(new KeyValuePair<int, string>(x, backColor));
}
grid.SetCellsForecolor("FMaterialName", colors);
}
#endregion
}
}
}
<2>拷贝插件组件到应用站点的WebSite\Bin目录下,重启IIS。
<3>BOSIDE扩展采购订单,选中明细信息单据体,新增2个菜单,如下图所示。
<4>注册表单插件,保存元数据,开发完毕。
现在可以登录业务站点,打开采购订单,检验一下插件效果啦。
【金蝶云星空BOS二次开发案例演示】https://vip.kingdee.com/article/94751030918525696
二开案例.表格控件.前景色
本文2024-09-23 04:20:59发表“云星空知识”栏目。
本文链接:https://wenku.my7c.com/article/kingdee-k3cloud-164731.html