关于字段的动态打印(100分)

  • 主题发起人 主题发起人 冰刀
  • 开始时间 开始时间

冰刀

Unregistered / Unconfirmed
GUEST, unregistred user!
一个库有多个字段,想让用户在程序运行时动态选定要打印的字段,有没什么简单的方法?
我知道一个复杂的方法,在选取字段时用checkbox,然后编写它的onclick事件,靠它向
quickreport里的qrdbtext(事先放好的),添加要打印的字段,但是一些细节相当麻烦。
 
用EHLIB控件好像可以选者行,列打印.
或用QUICKREPORT专业版里有允许用户修改控件
与FASTREPORT,REPORTBUILD相似
 
好像是QREditor没用过
 
我要的不是选择行列,而是选择字段。您能不能说详细些?
 
你自己的方法可以呀,QRDBText不用事先放好,动态生成就行了。
 
可以使用LISTBOX通过多行选择,直接写入QRDBEDIT
 
不过,我再变量声明的时候,遇到一个问题,我想把一个变量xlable:tqrlable,和
xqrdbtext:tqrdbtext,我是在一个过程中定义的,但是系统总是报错,说没有声明tqrlable,
 
procedure TForm1.PreparePrint;
var LeftValue:integer;
aLabel : TQRLabel;
aText:TQRDBText;
变量声明时,总是说[Error] Unit1.pas
(33): Undeclared
identifier: 'tQRLabel'
是不是哪儿还要说明,谢了!
 
是不是要USE什么UNIT
 
Creat了吗?不会犯这样的错吧?
 
我已经找到了一个方法,供大家学习。
Delphi编制的程序运行中动态制作报表
整理编辑:China ASP

Delphi中的quickreport是挪威的QuSoft AS公司专门为Delphi设计的用于制作报表的组件,具有很强的访问
数据库的能力。但是,从我个人的使用经验来看,这个组件的帮助写的不够详尽,例程也不多。因而一般编
程人员都是在设计期间设计好报表的所有格式,并在运行时连上数据源(即delphi中的dataset)运行程序的。
显然,这种方法不具备很强的灵活性。在这里我想向大家介绍一种在程序运行时如何动态制作报表的方法。
---- 首先,建立form1;unit1(调用窗体),其中放入button1:caption为‘预览’,用以查看报表,再加
入label1:caption为‘报表标题’;edit1用以接收用户输入的标题。再建立form2(放置quickreport元件的
窗体),其中放入quickrep元件和三个qrband元件,其bandtype分别为rbTitle,rbColumnHeader,rbDetail.但
其中无须放入qrlabel和qrdbtext元件,由程序中自动生成。再在form2;unit2中放入table1,table2。在
databasename属性中填入数据库所在的Alias Name.在tablename中分别填入Goods,TableInformation.其中
Goods中存放商品信息,可以设置以下字段:ID;Name;Unit;Price。TableInformation中的字段为TableName;
FieldsName;
DisplayName数据库中填入以下信息。
————————————————————————
Goods ID 商品编号
Goods Name 商品名称
Goods Price 商品单价
---- 好了,准备工作完成了一半,现在写入代码。在unit1的implementation下写入uses Unit2;在button1的
click事件中写入以下代码:
begin

PreparePrint;
with Form2do

begin

Preview;
Table1.Close;
Table2.Close;
end;

end;

在unit1中添加一个过程PreparePrint;
procedure TForm1.PreparePrint;
var LeftValue:integer;
aLabel : TQRLabel;
aText:TQRDBText;
begin

LeftValue:=100;
with Form2do

begin

aLabel := TQRLabel.Create(Form2);
'设置标题
aLabel.Parent := TitleBand1;
with aLabeldo

begin

Width:=300;
Height:=TitleBand1.Height;
Alignment:=taCenter;
Caption := Edit1.Text;
end;

Table1.Open;
Table2.Open;
Table2.First;
while not Table2.EOFdo

begin

aLabel := TQRLabel.Create(Form2);
’设置显示字段标题
aLabel.Parent := HeaderBand1;
with aLabeldo

begin

AutoSize:=False;
AutoStretch:=True;
Left :=LeftValue;
Top := 0;
Width:=80;
Height:=HeaderBand1.Height;
Alignment:=taCenter;
Caption := ' '+table2.FieldbyName(
'DisplayName').AsString+' ';
end;

aText := TQRDBText.Create(Form2);

'设置显示字段内容
aText.Parent := DetailBand1;
with aTextdo

begin

AutoSize:=False;
AutoStretch:=True;
Height:=DetailBand1.Height;
DataSet:=Table1;
DataField:=Table2.FieldbyName(
'FieldsName').AsString;
Alignment:=taCenter;
end;

LeftValue:=LeftValue+80;
Table2.Next;
end;

end;

end;

---- 好了,运行程序可以看到报表预览的效果,显示了Goods中的ID,Name,Price。在运行时完全可以控制
table1和table2中的数据内容。显示不同数据库的不同信息,改变table2中的记录顺序可改变报表中的显示
顺序。而且,由于报表的各部分,甚至包括各band和system data均可在程序运行时依据上述方法动态生成。
其属性也可动态设置。所以我们完全可以制作一个类似于Dephi中Form Wizard一样的报表精灵,还可提供一
个灵活而且强大的打印设置功能。
---- 以上代码在delphi3中运行通过。
加入时间:2000-4-27
阅读次数:1029

 
我写了一个读EhLib多层表头的程序,并且对Ehlib进行了功能扩充(基干茶壶的1.54),增加了
选择显示列、修改字体方法,对PrintDbGridEH也有效,并且可能在运行期动态生成fastReport,支持fastReport的所有功能。
但对fastReport报表格式有一定的限制,因为我对fastReport内部格式还不太熟,如果你有
需要,可直接与我联系:pick@wx88.net
 
多人接受答案了。
 

Similar threads

S
回复
0
查看
3K
SUNSTONE的Delphi笔记
S
S
回复
0
查看
2K
SUNSTONE的Delphi笔记
S
S
回复
0
查看
1K
SUNSTONE的Delphi笔记
S
后退
顶部