FastReport中国社区FastReport联系电话 联系电话:023-68661681

如何在报表设计器中使用带有函数的自定义库

来源:   发布时间:2018-09-12   浏览:4276次

【下载FastReport.Net最新版本】

在报表设计器中的内置函数库并不是很小,但有时候仍然缺乏一些特定的功能。由于报表中的脚本,可以轻松实现所需的功能。但是,如果许多记录中需要此功能呢?每次都将它添加到报表脚本中?当然不是。可以在连接到报表设计器的库中收集所有需要的函数。需要库与报表位于同一文件夹中,创建一个类库项目,将在其中拥有一个测试函数。例如,将数组转换为字符串的功能,编译库:
namespace ArrayToString
{
 public static class UserDefined
 {
 public static string ArrayToString(List<string> parameters)
 {
 return String.Join(",", parameters);
 }
 }
}
现在创建应用程序,将在其中打开报表生成器并使用我们的库ArrayToString,这是一个正常的Winforms应用程序。将库FastReport添加到项目引用:建议将库存储在与应用程序的可执行文件相同的目录中,所以可以在draft中添加对它的引用。除此之外,库将被添加到编译中包含可执行文件的文件夹中,应用程序中只有表单和按钮,添加按钮单击事件处理程序:
private void RunBtn_Click(object sender, EventArgs e)
 {
 Report report = new Report();
 report.Design();
 }
运行该应用程序,然后单击按钮,报表设计器将以空报表开头。在报表属性中,可以添加指向.net库的链接。
CustomLib
创建一个简单的报表模板——产品类别列表:
CustomLib
将文本对象添加到页脚页带。转到“Script”选项卡,创建一个列表,将在其中添加类别名称。用户库中的函数将列表转换为一行,在页面的基础中显示该行。所以,创建一个列表:
public class ReportScript
 {
 public List<string> list = new List<string>();
 }
回到报表页面。对于Data band,创建AfterPrint事件处理程序:
 private void Data1_AfterPrint(object sender, EventArgs e)
 {
 list.Add(((String)Report.GetColumnValue("Categories.CategoryName")));
 }
每次显示band“Data”时都会添加类别的名称,现在,为Page Footer band中的文本对象添加BeforePrint事件处理程序:
 private void Text1_BeforePrint(object sender, EventArgs e)
 {
 Text1.Text = ArrayToString.UserDefined.ArrayToString(list);
 }
为文本对象分配用户定义函数从先前添加的dll返回的字符串。请注意,函数的路径已满,包含命名空间和类名。如果将ArrayToString库添加到使用中,则可以缩短名称。现在可以在预览模式下运行报表,页面顶部:
CustomLib
在页面底部:
CustomLib
在一行中获得了产品类别列表,可以在页面底部的文本对象中使用以下表达式:
  [ArrayToString.UserDefined.ArrayToString(list)]
相当于:
   private void Text1_BeforePrint(object sender, EventArgs e)
 {
 Text1.Text = ArrayToString.UserDefined.ArrayToString(list);
 }
不需要创建事件处理程序,如果要在Web项目中使用自定义库来生成报表,则需要将其放在bin文件夹中。
本站文章除注明转载外,均为本站原创或翻译
欢迎任何形式的转载,但请务必注明出处,尊重他人劳动成果
转载请注明:文章转载自:FastReport控件中文网 [https://www.fastreportcn.com/]
本文地址:https://www.fastreportcn.com/post/2232.html

联系我们
  • 重庆总部 023-68661681
购买
  • sales@evget.com
合作
  • business@evget.com


在线
客服
微信
QQ 电话
023-68661681
返回
顶部