DLL封装ReportMachine/FastReport报表

DLL封装ReportMachine/FastReport报表


如果有报表文件兼容性问题,可以参考下面的方法来将某版本的报表封装到DLL中来使用。
首先建立一个DLL工厂,然后建立一个主窗体,在窗体中放入报表相关的控件。


为了传入变量,我们简单定义一个变量名称/值对应用的对象:



// 变量对应,可以用于变量和对象
  RMVariants
= class
    VarName:
string ;
    VarValue:
string ;
 
end ;



然后定义一个输出函数:




procedure ShowReport(vFile: string ;vDSList:TList;vVarValueList:TList = nil ); stdcall ;
var
  i:Integer;
  aDataSet:TADODataSet;
  aRMDBDataSet:TRMDBDataSet;
  aRMVariants:RMVariants;
begin
 
try
    frmReport:
= TfrmReport.Create( nil );
   
with frmReport do
   
begin
      RMReport1.LoadFromFile(vFile);

     
// 创建结果集列表
     
if vDSList <> nil then
     
for I : = 0 to vDSList.Count - 1 do
     
begin
        aDataSet:
= TADODataSet.Create( nil );
        aDataSet.Clone(TADODataSet(vDSList[i]));
        aDataSet.Name:
= TDataSet(vDSList[i]).Name;

        aRMDBDataSet:
= TRMDBDataSet.Create( nil );
        aRMDBDataSet.DataSet:
= aDataSet;
        aRMDBDataSet.Name:
= " RMDB " + aDataSet.Name;

        InsertComponent(aDataSet);
        InsertComponent(aRMDBDataSet);
     
end ;

     
// 对变量进行赋值
     
if vVarValueList <> nil then
     
for I : = 0 to vVarValueList.Count - 1 do
     
begin
        aRMVariants:
= RMVariants(vVarValueList[i]);
        RMReport1.Dictionary.Variables[aRMVariants.VarName] :
= aRMVariants.VarValue;
     
end ;

      RMReport1.ShowReport
   
end ;
 
finally
    frmReport.Free;
 
end ;
end ;



然后在需要的时候调用该DLL即可。


上面代码使用了ADO,为了更通用,可以使用ClientDataSet来处理数据,在窗体中放在TDataSetProvider和TClientDataSet来处理结果集,如果不想发布Midas.dll,可以引用单元MidasLib



注:以上示例使用了ReportMachine,同样适用于FastReport.

转载于:https://www.cnblogs.com/edrp/archive/2012/04/23/2465801.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
ReportMachine for delphi xe5  Report Machine目前主要能做的:   1、支持屏幕打印,控制方法多样,可以打印全部rxlib控件 全部InfoPower控件,TDBGrid,TStringGrid,TImage,TEdit等,TDBGridEh,f1book, TDecisionGrid等等众多控件。(例子1,例子2,例子3,例子4,例子5)   2、支持最终用户设计、修改报表,只需连接相关的数据源,指出数据的位 置(设置报表样式),无论是主从表,子报表,套表,都可迅速生成。开发 一个报表只需几分钟的时间。   3、报表样式可以保存为rmf格式,下次可通过读入使用(配合SQL脚本就可以生成 报表)。并可以把带数据的报表保存为rmp格式,在任何机器上都可以浏览、打印, 而不需要数据库。   4、生成后的报表支持修改,包括字体的设置,边框的设置,修改内容等。   5、报表编辑器内自带ado,bde,ibx,Diamond dao,dbisam等数据访问控件,可以 通过这些控件开发独立的报表制作工具。其使用方法和delphi中的控件是一样的。   6、完全、自由自定义页面、边距、字体,标题和页眉页脚,并可以在自认合适的 地方插入函数来实现当前日期,页合计,总合计等功能,合计字段可以放在页头,分 组头,并支持条件合计,对分组合计,分页合计,总计等只需简单地设置属性即可。   7、完全支持D5--D7,BCB5--BCB6。   8、报表中可以在自认合适的事件(on beforeprint,on afterprint等)中加入程 序脚本,以控制、或实现更复杂的打印效果。   9、更新迅速,可根据使用人员与用户的意见,不断的加入新的功能。   10、多种格式转换,可以把做出的报表转换为html,xls,pdf,bmp,jpeg等等格式。   11、自动对超长记录折行,超长的内容也会自动折行,中文换行不会乱码。   12、首家支持缩放打印功能,可以根据打印时选择的纸张自动缩放报表。   13、首家支持即打即停.   14、首家提供类似excel的报表设计器,给你足够灵活方表的报表设计方式。   15、首家提供双报表设计器(第一种,第二种),满足所有的需求。   16、更是提供类似于ObjectPascal的script,实现特殊功能。   17、首家提供web,IntraWeb中的报表解决方案。   18、首家提供报表压缩处理,占用内存更少,生成报表速度更快。   19、首家提供合并单元格功能,更加适应处理复杂的中文报表。   20、自动填空行,每页打印数量等细节处理更完善。 二、ReportMachine版本简介: 1、VCL版:这是ReportMachine基础版本,一般以全部源码形式提供给注册用户,可以用在Delphi5-Delphi 2009,C++ Builder5.0-C++ Builder 2009开发环境中。 2、com版:是个单独的ocx文件(RMReport.ocx),是用Delphi 7.0及以上版本开发的,是对VCL版ReportMachine控件的再封装,具有VCL版的全部功能,安装、使用上更容易些,com版的ReportMachine可以用在vb,vc,vfp,pb等开发语言中。一般以ocx无源码形式提供,也可以有全部源码(包括vcl源码+ocx源码) 3、com版for .net WinForm:跟com版一样,但多了个.net下的数据库接口程序,此版可以用在vb.net,c#中,做winform程序的报表工具。一般以ocx无源码形式提供,也可以有全部源码。 4、webreport版:是对ReportMachine vcl版的再开发,用在asp,asp.net,jsp做的b/s架构的程序中,为客户端ie提供报表预览、打印、导出功能,webreport包括2部分:服务器端报表引擎(在asp,asp.net,jsp都能用,webreport对上述3中语言都开发了报表引擎)、客户端ie浏览器ActiveX插件(ActiveX插件只有一个,可以自动感知服务器端报表引擎版本)。webreport版不具备设计报表模版功能,需要用单独的报表设计程序在服务器端设计报表,也可以用本站提供的RMDesigner。 5、webreport for IntraWeb版:跟webreport版功能一样,是专为Delphi中的IntraWeb vcl提供的报表插件。 6、RMDesigner:是用vcl版ReportMachine开发的一个报表设计器,可以用来为webreport提供报表设计功能。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值