Delphi中用FastReport制作报表

2016-02-19 20:54 142 1 收藏

最近很多朋友喜欢上设计,但是大家却不知道如何去做,别担心有图老师给你解答,史上最全最棒的详细解说让你一看就懂。

【 tulaoshi.com - 编程语言 】

报表作为系统信息的典型输出形式之一,是大多数应用系统非凡是MIS系统的重要功能。是否具有一个良好的打印功能,往往从一定程度上关系到系统的成败。Delphi有很强的报表功能,但是它的报表功能还不能满足我们的需要。于是许多Delphi高手相继推出了不少优秀的报表控件(模块),作为QuickReport的补充,其中FastReport就是一个代表。
  
  FastReport综合了QuickReport和Re portBuilder的优点,个头小,速度快,并带有全部源码。笔者在开发一个药品治理系统时,用FastReport2.51成功制作出了和药品验收单、药品调拨单一模一样的表单式报表。下面给朋友们介绍一下。
  
  FastReport2.51下载地址:http//www.skycn.com/soft/8805.Html。
  
  报表的需求分析
  
  在医院工作的朋友都知道,药品入库时要填写药品验收单,药房工作人员领取药品时要填写药品调拨单。笔者单位使用的药品验收单和调拨单不是专用的,而是通用的商品验收单和调拨单。与百货业、电信系统使用的报表不同,它的外形为条形,每张固定可填五种药品,内容包括发货单位、发货单号、收货单位、品名、规格、单位、价格、金额等,一式。
  
  综上所述,我们可以把报表设计的需求归纳如下:
  
  1. 大小为:长21cm,宽10cm;
  
  2. 每张可以打印5种药品,表单下面有本页小计。
  
  3. 多于5种药品时开始新一张表单的打印,不足5种药品时要用空行补足。
  
  报表设计
  
  1.打开FastReport的报表设计器,按照图1设计出“药品验收单”。
  
  IFRAME src="/uploadImages/2007-5-2/2007527203858480.jpg" frameBorder=0 width=590 scrolling=yes height=400>/IFRAME
  (图片较大,请拉动滚动条观看)
  
  另外,InHJ、OutHJ、CaHj、LineCount这几个变量分别表示“入库合计”、“出库合计”、“差价合计”和“数据总行数”,在程序中将对这几个变量赋值。
  
  2.按F11键,调出对象查看器,选中Band2,在它的OnBeforPrint事件中输入如下代码:
  
  begin
  if LINE#-1 0  and LINE#-1  mod 5=0  then
  begin
  showBandChild1 
  showBandband1 
  end
  end
  代码中用FastReport的内置函数LINE#取得当前行号,假如满足条件,就显示页头和Child3,开始新的一张表单。
  
  3.选中Child3,在它的OnBeforPrint事件中输入如下代码:
  
  begin
  lin=lineCount //在程序中要对该变量赋值
  while lin mod 50  do
  begin
  showbandchild2  //打印空行
  inclin 
  end
  showBandchild3 
  end
  这段代码的用途是假如最后数据行不够一张表单显示时,就打印空行。
  
  4. 选中Band3,在它的OnBeforPrint事件中输入如下代码:
  
  begin
  showbandchild1  //到达报表结束时显示表单底部的内容
  end
  5.将报表保存后回到Delphi开发环境。
  Delphi编程部分
  
  在Delphi编程部分我们主要完成报表所需参数的传递,因为要在好几个过程中访问这些参数,所以要将这几个参数设为全局变量:
  
  private
  line1line2integer //保存行号
  inputXjintemp //入库小计 ,每5行后清零,下同
  outXjoutemp //出库小计
  CajiaXjcatempReal //差价小计
  下面是几个主要过程的代码清单。
  //单张表单数据合并过程
  procedure TInputForm.frDBDataSet1NextSender TObject 
  var
  ReCountinteger
  begin
  ReCount = Adoruku.RecordCount
  Incline1 // 该变量传至报表文件控制打印空行
  Incline2 // 该变量控制清零小计值
  if not Adoruku.Eof then
  begin
  inputXj=inputXj+ADORuku.fieldByName'入库金额' .AsFloat
  outXj=outXj+Adoruku.fieldByName'出库金额' .AsFloat
  CajiaXj=CajiaXj+AdorukuJXCJ.AsFloat
  end
  //每5行后将小计值清零
  if line2 mod 5 = 0  and ReCountline2 div 5 5   then
  begin
  intemp=inputXj
  outemp=outXj
  Catemp=CajiaXj
  inputXj=0
  outXj=0
  CajiaXj=0
  
   end
  //到达数据集末尾时给变量赋值
  if Adoruku.Eof then
  begin
  intemp=inputXj
  outemp=outXj
  Catemp=CajiaXj
  end
  end
  以上程序在windows 2000/XP+Delphi6.0中调试通过。至此,我们已经完成了药品验收单的设计工作,其他的类似报表设计可以参照以上过程。图2是程序运行时生成的报表预览效果。
  
  IFRAME src="/uploadImages/2007-5-2/2007527203885819.jpg" frameBorder=0 width=590 scrolling=yes height=400>/IFRAME
  (图片较大,请拉动滚动条观看)

来源:http://www.tulaoshi.com/n/20160219/1624796.html

延伸阅读
如何制作复杂报表——利用excel输出复杂报表     在读这篇文章以前首先要提醒大家,Access 本身的报表也具有很强的实用性和强大的功能,只有当你发掘了其本身全部的功能却仍不能满足你对报表的特殊要求时才请使用 Excel 输出报表。很明显,使用 Excel 输出报表第一个弱点就是必须同时打开 Access 和 Excel (当然,你得在...
何制作复杂报表——利用excel输出复杂报表     在读这篇文章以前首先要提醒大家,Access 本身的报表也具有很强的实用性和强大的功能,只有当你发掘了其本身全部的功能却仍不能满足你对报表的特殊要求时才请使用 Excel 输出报表。很明显,使用 Excel 输出报表第一个弱点就是必须同时打开 Access 和 Excel (当然,你得在一...
笔者设计了一段程序。首先在窗体上添加一个DBGrid来显示我们所要打印的数据,在这里,DBGrid不只是起到显示数据的作用,而且用户对DBGrid作的调整,例如改变了各字段的排列顺序,各字段的显示宽度等,都将直接反映到打印结果中去,也就是说,我们实际上就是要把DBGrid的内容直接输出到打印机。以下程序在Win 98+Delphi 4下编译通过,代码如...
---------------- 使用自定义函数 ---------------------------------------- Q: 我怎样添加我的自定义函数? A: 使用 TfrReport.OnUserFunction 事件. 这里有一个简单的例子: procedure TForm1.frReport1UserFunction(const Name: String; p1, p2, p3: Variant; var val: Variant); begin if AnsiCompareTex...
FineReport怎么制作聚合报表   FineReport是一款制作报表软件,也是日常办公要用到的一款常用软件。下面小编为大家介绍一下怎么用FineReport制作聚合报表希望能帮到大家 1. 聚合报表设计界面 聚合报表指一个报表中包含多个模块,每一块都类似一张单独的报表或者一张图表,块与块之间相对独立,互不影响。打开设计器文件新...

经验教程

930

收藏

99
微博分享 QQ分享 QQ空间 手机页面 收藏网站 回到头部