N天前写了一篇动态报表的文章,里面所用的方法比较简单,适合建立中规中矩的N行N列的简单报表。(具体请参看http://blog.csdn.net/LYMEGG1984/archive/2010/09/21/5898518.aspx)这段时间在做一些套打的程序时,发现这种方法不行,套打中的表格并不是简单的N行N列,而且需要控制的精度也相对的高,如此一来就不能用传入一个或几个表的方法解决问题了,所以只好另辟出路。
从套打的角度出发,如果可以把这个报表保存为一个模板,打印时调用,填充上要打印的数据,就可以解决大部分问题了。XtraReport报表编辑器里的保存,是可以保存为一个文件的,所以它应该提供了一个从文件加载的方法,这时我们可以发现XtraReport里有一个LoadLayout的方法,可以加载报表文件,再往下我们可以发现它的重载方法是可以从IO.Stream里加载报表文件,也就是说,我们可以进一步的把这个报表模板以二进制的方式保存在数据库里。需要的时候,从数据库调用即可。
这时我们发现还有一个问题,就是填充数据的问题。这个问题就有很多的解决办法。我简单的说说我所用的方法,我的方法是,数据源我还是用一个DataTable传递;在做报表模板的时候,在需要填充数据的控件的Tag属性上,填上数据源上的列名;然后加载模板后稍作处理即可。
因为代码中涉及其他公司的东西,就不能尽数全贴代码,只能贴针对问题贴关键的代码,如果有问题,欢迎讨论!!
加载模板的代码:
填充数据的方法,这个问题的解决方法有很多,希望大家讨论,提出更好的方法:
PS:如果你在一个博客名叫笨蛋EGG的163博客看到这篇文章,请不要怀疑,这篇是在163博客首发的,现在搬家转过这里来了。