QQ登录

只需要一步,快速开始

 注册地址  找回密码
查看: 2229|回复: 0
打印 上一主题 下一主题

QuickReport基本知识

[复制链接]
字体大小: 正常 放大
韩冰        

823

主题

3

听众

4048

积分

我的地盘我做主

该用户从未签到

发帖功臣 元老勋章

跳转到指定楼层
1#
发表于 2005-1-26 12:33 |只看该作者 |倒序浏览
|招呼Ta 关注Ta

一、 简单了解各控件功能 2 O& _3 p( n! C! P" N. R+ Q 以下是各控件最简单的使用功能,其他功能依具体的实现而介绍。 , _, n U. r) P7 Q6 W: x6 d, X 1. TquickRep:带有坐标,作为其他报表控件(如TQRBand)的容器,它的Band属性可以自动添加各种类型的TQRBand. 1 a" e/ B+ l* ` 2. TQRLabel:打印静态的文本(即不是根据数据库值来改变的),作用象Tlabel , Caption的内容就打印出来的内容。 8 K8 y3 F' d7 E$ H* t0 _: U 3. TQRDBText:打印数据库字段值,一个值一行。作用象TDBText.把它的DataSet , DataField分别赋予Table1,Company时,将打印Table1所指向的表的Company字段的内容。 # c. v, u* V( R" I* p, F% [$ b 4. TQRSysData:打印系统信息如时间,页码,报表头等。 # P6 ?: d+ e8 V/ W8 R 5. TQRMem非常象TQRLabel,只是它可以打印多行,也是打印静态数据。 4 H$ J& u0 [' m- W 6. TQRRichText:打印RichText格式,能够连接到一个Form上的RichEdit控件并打印它的内容,不过必须是32位版本的。 ' R( X5 U& d& c2 A5 E: @ 7. TQRShape:打印方框、圆和垂直、水平线。 / C4 D% G- \3 b/ l7 M 8. TQRImage:打印静态的图片,包括(BMP,WMF,ICON). " x+ A/ V" G, s 9. TQRDBImage:从数据库接收图片。 # k8 B0 Z4 o+ u+ ~8 N! b% B! m 10. TQRBand:用来确定报表的不同位置应该显示什么内容,它上面可以放控件(参见二)。 . ] n% _3 c+ S A 11.TQRGoups:Groups可以不限级别的组操作。当你连接了几个datasets到报表时可以通过Groups成组的对dataset进行操作。

. R) m) G6 j, a" T

二、 报表的控件摆放循序

& C" R! ~5 e7 h# E* r' A

出现在所有页上的标题(PageHeader) 2 L/ k, }% `9 B2 s+ ` | 2 }( _9 L |+ {& d# Z% ? 标题(只有首页才有)(Title) 0 C" Z# X' l, E+ O2 N7 p | 0 \/ Q; P( {3 J7 L0 Y 所有列的标题(ColumnHeader) {1 R- A9 `; ]0 t, I- F" V | % d8 S/ n. j1 O5 J; w7 ~ 记录的内容,一个字段一列(Detail) 4 E0 K5 [+ d5 E% C! y2 b0 E( S | ) P ^' w% p X W 摘要(最后一页才有)(Summary) # t1 L1 d5 }# p | i0 H" X9 }" V+ e+ x 出现在所有页上的页脚(PageFooter) & \7 ~6 H$ U4 X* v8 t3 ] 6 P/ ?2 J: O* w5 g9 W, z" c6 p 这些根据设置不同的Band(不是控件,一种类型而已,在其上面可以放其他控件)来定位。总共有六种Band。

& d) }/ t9 S! C3 _$ y4 P0 L

三、 一个简单的例子 ; s: K& j7 V4 ]" s# n! y 这个例子制作打印一张表的部分字段名及该字段数据内容的报表。 . t0 O J8 C) L 1. 建立一个新project ( e7 w4 ^' [; ]3 Y, W g0 T 2. 放一个TTable到Form上,DatabaseName设为BCDEMOS,TableName指向Customer表,Active设为true. 1 q6 `' x( p+ M9 `( O6 \+ O 3. 放一个TquickRep控件在Form上,DataSet属性为Table1.(即要显示上边Table1所指向的表的内)。 , s1 X6 n9 F/ @ 4.展开TquickRep的Bands属性,设HasDetail为true,这时自动增加个detail band(一个TQRBand控件,故也可以直接放一个TQRBand控件,BandType属性设为detail就行了)。 0 C$ e+ H f0 A& T: V 5.放一个TQRDBText控件在detail band上面,设DataSet指向Table1,DataField指向Company。第四步是设置在报表的什么位置显示什么类型的数据,而TQRDBText则具体实现。 - }/ n0 i2 g( W8 w+ u+ E* a4 l 6.选TquickRep控件,按右键,选择”Preview”预览,应该看到表Customer的字段Company的所有字段值。 z( F* s+ O/ F. M/ {9 a: v 到这一个简单的例子就OK了,程序实现预览及利用TQRuickRep自带的打印功能只须在Form中加一个按钮,它的OnClick事件为:QuickRep1->review();

8 V$ P; Z3 G7 a" E

四、 一个使用TQRGoups、TQRExpr控件的报表 / U+ M, A/ ]: w8 T 该报表先列出州名,接着列出该州的所有公司及公司总数,一个州列完后空一行(groups中断),列出新的州名,接着列新州下的所有公司,没有填州名的公司统一列在Unknown state下面。 , D0 B6 q0 Q) m3 ], W$ J 1. 建立一个新project。 + I. V& ? r: s9 w r 2. 放一个Tquery在Tquickrep上,其SQL属性为:select * from customer order by State,Company;(即根据州、公司排序),DatabaseName为BCDMome,Active为true. $ I1 f# B( c% M' d 3. 放一个TquickRep控件在Form1上,DataSet为Tquery1. ! g9 i+ a5 y9 U- Y2 G4 f. n6 ~" t 4. 放一个TQRGroups控件在TquickRep上,这时默认为group header。(任何时候当group中断或更高级别的group中断,这个header都将打印出来,如果有表达式,根据表达式的值显示内容。)接着添加一个group footer band,添加时,放一个TQRBand控件在报表上,连接TQRGroups的FooterBand属性到这个QRBand,这时这个新建的TQRBand就成为Group Footer. (TQRGroup的一个重要特性是表达式,任何时候当表达式的值变时Group都将中断,如表达式是按省列出城市名,当前列出广东省,当属于该省的城市列完后,表达式值改变,这时Group中断,接着显示其他省的城市名。)TQRGroups的Expression属性设为Query1.State(根据不同的州来中断)。 # i" v! k' p8 L) D" O! y0 J 5. 放一个TQRBand控件在报表上,BandType为rbDetail. 6 D$ X5 C" Q$ i H 6.放一个TQRExpr控件在group header上面,其Expression属性为:if(State<>’’,State,’Unknown state’),即如果公司的州没填,就归入Unknown state,否则归入State. 0 q3 o" V' T1 A4 p! u' h- S 7.放三个TQRDBText在Detail上,他们的DataSet都指向Query1,DataField分别指向Company,Contact,Phone. - ]1 [! r/ B! z. X4 E: b. ] 8.在放一个TQRExpr控件在group Footer上面,Expression为’Customers in’+State+’:’+Str(Count) 作用是在每个州的公司列完后显示该州总共有多少个公司。 4 ?/ J0 {1 {: O* y1 r 9.按右键选预览,应该看到不同的州名及其公司和公司公司总数。

* h& D7 B- E# p& j6 T2 f( i( b- |

五、QuickReport 条件式列印 2 f8 T/ M+ ?# L! F* V. R2 ` 可以直接在 TQuickReport 的 OnFilter 事件中写明条件判断,OnFilter事件的引数中有一个以 var 宣告的 PrintRecord 布林型态变数,将这个变数设为 True(预设值), 该笔记录便会印出;反之, 设为False,就不印出这笔记录. . r; e: H5 p, h- m! T- i procedure TForm1.QuickReport1Filter(var PrintRecord: Boolean); 1 [( {- Z7 H$ U5 v& ?" | begin ! N9 Q* S$ C" ?* o, W* L PrintRecord := False; ' C0 k: x( ]/ M2 l if YourTable.FieldByName('WantedField').AsInteger <= 100 then 4 p, D0 }# d0 j1 c0 D$ O+ d% y Exit; 1 E) s; b3 `7 v) s2 }7 d if YourTable.FieldByName('WantedField').AsInteger >= 150 then 5 C& Z/ X) I! c% S Exit; 9 x9 {! d. `: [7 }% ] PrintRecord := True; # A+ ~, Q4 j/ V$ T2 Q

zan
转播转播0 分享淘帖0 分享分享0 收藏收藏0 支持支持0 反对反对0 微信微信
您需要登录后才可以回帖 登录 | 注册地址

qq
收缩
  • 电话咨询

  • 04714969085
fastpost

关于我们| 联系我们| 诚征英才| 对外合作| 产品服务| QQ

手机版|Archiver| |繁體中文 手机客户端  

蒙公网安备 15010502000194号

Powered by Discuz! X2.5   © 2001-2013 数学建模网-数学中国 ( 蒙ICP备14002410号-3 蒙BBS备-0002号 )     论坛法律顾问:王兆丰

GMT+8, 2026-4-18 20:19 , Processed in 0.421632 second(s), 52 queries .

回顶部