Delphi中用FastReport制作报表

牛比的二楼亮了

牛比的二楼亮了

2016-02-19 20:54

最近很多朋友喜欢上设计,但是大家却不知道如何去做,别担心有图老师给你解答,史上最全最棒的详细解说让你一看就懂。
报表作为系统信息的典型输出形式之一,是大多数应用系统非凡是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
  (图片较大,请拉动滚动条观看)
展开更多 50%)
分享

猜你喜欢

Delphi中用FastReport制作报表

编程语言 网络编程
Delphi中用FastReport制作报表

用Delphi制作中国式报表

Delphi
用Delphi制作中国式报表

s8lol主宰符文怎么配

英雄联盟 网络游戏
s8lol主宰符文怎么配

用FASTREPORT实现WEB应用中自定义报表

编程语言 网络编程
用FASTREPORT实现WEB应用中自定义报表

在VB中用代码打印ACCESS报表

编程语言 网络编程
在VB中用代码打印ACCESS报表

lol偷钱流符文搭配推荐

英雄联盟 网络游戏
lol偷钱流符文搭配推荐

Delphi控制Excel自动生成报表

Delphi
Delphi控制Excel自动生成报表

教程: 在VB中用代码打印ACCESS报表

编程语言 网络编程
教程: 在VB中用代码打印ACCESS报表

lolAD刺客新符文搭配推荐

英雄联盟
lolAD刺客新符文搭配推荐

在C++中的ODBC API数据库编程

在C++中的ODBC API数据库编程

C语言教程第一章: C语言概论

C语言教程第一章: C语言概论
下拉加载更多内容 ↓