高分征求 打印预览 见者有分(200分)

Unregistered / Unconfirmed
GUEST, unregistred user!
我自编了一个工资管理程序,其它部分已调试完毕。唯独差“打印预览”这一部分
没有思路 在这里向各位大侠请教了,(我有很多理由不想用delphi本身的report控件)
如有哪位能切实帮我解决此问题,愿再加100分…………
 
使用第三方控件呀,比如FastReport
delphi本身的QuickReport控件bug太多
我也建议你别用
 
你用过QuantumGrid没有?
他的功能非常强大,还支持打印、预览功能,使用也非常方便!
 
FastReport,绝对满足你的要求
 
你最好还是用delphi本身的qreport,
我就用它写,感觉挺好
工资发放表的设计应该不是很复杂。有兴趣,探讨一下
ami_me@sina.com
 
用memo做一个!
 
使用 TTF16 。在Delphi中有一个比较老的版本,它可以使用Excel格式,在Excel中做好了
报表它可以直接使用。
 
用FastReport
 
用 ScrollBox + PaintBox 就可以实现。
我也是讨厌使用 Delphi 现成的报表,基本上全是手工做的。
不过,实现过程大量是依靠Win32API。
如果需要再改善一下,再加个 Image 作为后台页面。
在 Image 上绘制报表,然后 BitBlt/StrechBlt 到 PaintBox 就行了。
绘制过程中要注意 MapMode 以及 DeviceCaps 中的 ScalesXY。
 
你去www.delphibbs.net上,那里有一些文章讲做打印预览的,去看看吧
 
to 上铺的兄弟
现在不就是在大富翁吗。

用控件fastReport
 
give me your E-mail,I have a Program code.
guangmin001@263.net
 
其实思路非常简单:
1:能做出打印程序,修改为打印预览非常简单。
2:生成图元文件,预览时把Printer.Canvas->图元文件的Canvas,换页时,生成新的图元文件,
一直到打印结束。
3: 自己作一个图元文件的浏览界面,打开生成的图元文件即可。
4: 特点:无级缩放,编程简单。不占用多少内存资源。
5: 我就是这么作的,效果非常好。
 
FR有一些缺点,归纳有三:
1、不能实现真正的套打功能(真正的灵活套打应在预览时还能看见套打的底板)
2、缺少预览信息导出工具(自带的太烂,唯一的上好工具根本找不到D版,具体信息见
http://www.pragnaan.com/download.html)
3、字体容易乱码(唯一解决方法是将所有FR的控件设成宋体)
 
自定义快速报表的打印预览窗口

---- Quick Report 2.0 中 提 供 的 默 认 打 印 预 览 窗 口 是 英 文 界 面 的, 如 果 开 发 的 中 文 软 件 中 带 有 这 种 英 文 显 示, 不 免 有 些 小 小 的 缺 憾。 因 此 有 必 要 实 现 中 文 界 面 的 打 印 预 览 窗 口。 但 是Delphi 提 供 的 源 代 码 中 并 没 有 打 印 预 览 窗 口 的.PAS 源 文 件, 这 就 无 法 直 接 修 改 源 码, 只 能 全 部 自 己 编 程 实 现。 经 多 次 实 践, 笔 者 模 仿 实 现 了 与 默 认 预 览 窗 口 外 观 类 似, 功 能 相 同 的 打 印 预 览 窗 口。 步 骤 如 下:

---- 1. 新 建 一 个 窗 体, 设 置Name 为MyPreview。
---- 2. 在 窗 体 上 添 加 一Toolbar 控 件, 模 仿 默 认 预 览 窗 口 创 建 相 应 的Toolbutton, 并 设 置 各 按 钮 的Hint 提 示。
---- 3. 添 加 一Panel 控 件, 对 齐 方 式 置 为alBottom。 再 在 此Panel 上 放 一ProgressBar( 左 对 齐) 和Panel( 右 对 齐), 分 别 显 示 报 表 装 载 进 度 和 其 他 提 示 信 息。
---- 4. 添 加QRPreview 控 件, 对 齐 方 式 置 为alClient。
---- 5. 添 加OpenDialog, 设 置Filter 属 性 为*.QR; 添 加SaveDialog, 设 置Filter 属 性 为*.QR|*.TXT|*.HTM|*.CSV, 设 置DefaultExt 属 性 为*.QR。
---- 6. 双 击 各 个Toolbutton, 输 入 相 应 代 码。
---- 可 以 按 以 下 方 法 调 用 自 定 义 预 览 窗 口。

---- 重 载TQuickRep 的OnPreview 事 件, 输 入 如 下 代 码:
procedure TRptForm.RptFormPreview(Sender: TObject);
begin

with TMyPreview.Create(Application)do

begin

QRPreview1.QRPrinter := TQRPrinter(Sender);
CurRep := self;
Show;
end;

end;

附 各 成 员 方 法 的 具 体 实 现:
unit Myprv;

interface
uses
Windows
Messages
SysUtils
Classes
Graphics
Controls
Forms
Dialogs
ComCtrls
ToolWin
qrprntr
Quickrpt
StdCtrls
ExtCtrls
qrextra
qrhtml;

type
TMyPreview = class(TForm)
QRPreview1: TQRPreview;
ToolBar1: TToolBar;
(其 余 成 员 变 量 和 成 员 方 法 声 明 略。)
private
{ Private declarations }
FPageCount : integer;
// 生 成 报 表 的 总 页 数
public
{ Public declarations }
CurRep : TQuickRep;
// 所 预 览 的 报 表
procedure UpdatePanelShow;
end;

implementation

{$R *.DFM}
procedure TMyPreview.UpdatePanelShow;
begin
// 更 新 显 示
Panel2.Caption := ' 第 '+inttostr(QRPreview1.PageNumber)+ ' 页 总 '+inttostr(FPageCount)+' 页';
end;

procedure TMyPreview.ToolButton2Click(Sender: TObject);
begin
//ZoomToFit 缩 放 至 全 屏
QRPreview1.ZoomToFit;
end;

procedure TMyPreview.ToolButton3Click(Sender: TObject);
begin
//ZoomTo100% 缩 放 至 实 际 大 小
QRPreview1.Zoom:=100;
end;

procedure TMyPreview.ToolButton4Click(Sender: TObject);
begin
//ZoomToWidth 缩 放 至 页 宽
QRPreview1.ZoomToWidth;
end;

procedure TMyPreview.ToolButton6Click(Sender: TObject);
begin
//First page
QRPreview1.PageNumber := 1;
UpdatePanelShow;
end;

procedure TMyPreview.ToolButton8Click(Sender: TObject);
begin
//prior page
QRPreview1.PageNumber := QRPreview1.PageNumber+1;
UpdatePanelShow;
end;

procedure TMyPreview.ToolButton7Click(Sender: TObject);
begin
//next page
QRPreview1.PageNumber := QRPreview1.PageNumber-1;
if QRPreview1.PageNumber =0 then

QRPreview1.PageNumber:=1;
UpdatePanelShow;
end;

procedure TMyPreview.ToolButton9Click(Sender: TObject);
begin
//Last page
QRPreview1.PageNumber := FPageCount;
UpdatePanelShow;
end;

procedure TMyPreview.QRPreview1PageAvailable(Sender: TObject;
PageNum: Integer);
begin
//get pagecount
FPageCount := PageNum ;
UpdatePanelShow;
end;

procedure TMyPreview.FormClose(Sender: TObject;
var Action: TCloseAction);
begin

CurRep := nil;
Action := caFree;
end;

procedure TMyPreview.ToolButton14Click(Sender: TObject);
begin
//close the window
Close;
end;

procedure TMyPreview.ToolButton11Click(Sender: TObject);
begin
//print setup
QRPreview1.QRPrinter.PrintSetup;
end;

procedure TMyPreview.ToolButton13Click(Sender: TObject);
begin
//print
QRPreview1.QRPrinter.Print;
end;

procedure TMyPreview.ToolButton16Click(Sender: TObject);
begin
//save button
if SaveDlg1.Execute then

begin

if (SaveDlg1.FIlterIndex <>1) and (CurRep = nil) then

Exit;
case SaveDlg1.FilterINdex of
1: //--*.QR
QRPreview1.QRPrinter.Save(SaveDlg1.FileName);
2: //--*.TXT
CurRep.ExportToFilter (TQRAsciiExportFilter.Create(SaveDlg1.FileName));
3: //--*.HTM
CurRep.ExportToFilter (TQRHTMLExportFilter.Create(SaveDlg1.FileName));
4: //--*.CSV
CurRep.ExportToFilter(TQRCSVExportFilter.Create(SaveDlg1.FileName));
end;

end;

end;

procedure TMyPreview.ToolButton17Click(Sender: TObject);
begin
//load button
if OpenDlg1.Execute then

QRPreview1.QRPrinter.Load(OpenDlg1.FileName);
end;

procedure TMyPreview.QRPreview1ProgressUpdate(Sender: TObject;
Progress: Integer);
begin
//updage progress bar
ProgressBar1.Position := Progress;
end;

procedure TMyPreview.SaveDlg1TypeChange(Sender: TObject);
begin
//set DefaultExt property of Savedialog
with SaveDlg1do

case FilterIndex of
0: DefaultExt := '.QR';
1: DefaultExt := '.TXT';
2: DefaultExt := '.HTM';
3: DefaultExt := '.CSV';
end;

end;

end.
//end of Unit
 
把报表导出到Excel吧,导出后就要以不管了,
用户还可以对报表内容更改,保存。多好。
 
如果谁有比较好的套打方案,别忘了小弟哟!!
zcm1975117@21cn.com
 
下面是我写的通用文档微机管理系统的打印部分原代码,包括合并execl单元格,加入分页符号,设置行高,列宽,设置execl页头,设置每页记录数,画单元格边框,调用execl模板,实现套打等等
软件主页 http://xhonghui.patching.net/
procedure TfrmMain.Button3Click(Sender: TObject);
//动态打印excel报表
var
tiaojian : string;
//tiaojian 为一个sql查询语句,全宗号,目录号,起始日期为一数据库字段
begin

tiaojian := '';
if Edit7.Text <> '' then
begin
tiaojian := tiaojian + ' ( 全宗号=''' + EDit7.Text + ''' ) and';
end;
if Edit8.Text <> '' then
begin
tiaojian := tiaojian + ' ( 目录号=''' + Edit8.Text + ''') and';
end;
if Edit9.Text <> '' then
begin
tiaojian := tiaojian + ' ( 起始日期>= ' + Edit9.Text + ' ) and';
end
else
tiaojian := tiaojian + ' ( 起始日期>=0) and';
if Edit10.Text <> '' then
begin
tiaojian := tiaojian + ' ( 起始日期<= ' + Edit10.Text + ' ) and';
end;
tiaojian := copy(tiaojian, 1, length(tiaojian) - 3);
//tiaojian 为一个sql查询语句
Printanjuan(tiaojian);
//调用打印过程
//打印预览
ShellExecute(Handle, 'Open', PChar(GetCurpath + 'temp.xls'), nil, nil, sw_shownormal);
//调用excel查看生成的文件
ProgressBar1.Position:=0;
//ProgressBar1 为一个进程条控件
end;

procedure TfrmMain.Printanjuan(tiaojiao:string);
var
nowhangi, i, jilushu, LCID: integer;
//nowhangi当前 execl的所在行,jilushu当前的记录位置
ssql, PathName: string;
oldcur: tcursor;
ExcelApplication1: TExcelApplication;
ExcelWorkbook1: TExcelWorkbook;
ExcelWorkSheet1: TExcelWorksheet;
xl, Cell1: olevariant;
begin
LCID := LOCALE_USER_DEFAULT;
if FileExists(GetCurpath + 'temp.xls') then
//删除动态生成的临时temp.xls文件
try
DeleteFile(GetCurpath + 'temp.xls');
except
end;

ssql := '';
//执行sql查询
ssql := 'select * from mainanjuan where (' + tiaojiao + ') order by 系统编号 ';
do
adosql(dm1.queryanjuan, ssql);
begin
try
ExcelApplication1 := TExcelApplication.Create(Self);
ExcelWorkbook1 := TExcelWorkbook.Create(Self);
ExcelWorkSheet1 := TExcelWorksheet.Create(Self);

except
showmessage('对不起,您没有安装Excel 2000!');
abort;
end;
end;
ExcelApplication1.Connect;
ExcelApplication1.Workbooks.Add(null, 0);
//如果调用一个模板 ,实现套打,改动该句如:
//ExcelApplication1.Workbooks.Add('c:/zichang.xls', 0);
ExcelWorkBook1.ConnectTo(ExcelApplication1.Workbooks[1]);
ExcelWorkSheet1.ConnectTo(ExcelWorkBook1.Sheets[1] as _WorkSheet);
//写入execl
ProgressBar1.Position:=5;
if dm1.queryanjuan.RecordCount > 0 then
begin
//设置列宽,行高
nowhangi := 1;
ExcelApplication1.Range['A1', 'A1'].ColumnWidth := 3.5;
ExcelApplication1.Range['B1', 'B1'].ColumnWidth := 3.5;
ExcelApplication1.Range['C1', 'C1'].ColumnWidth := 3.5;
ExcelApplication1.Range['D1', 'D1'].ColumnWidth := 8;
ExcelApplication1.Range['E1', 'E1'].ColumnWidth := 20;
ExcelApplication1.Range['F1', 'F1'].ColumnWidth := 8.75;
ExcelApplication1.Range['G1', 'G1'].ColumnWidth := 8.75;
ExcelApplication1.Range['H1', 'H1'].ColumnWidth := 3.0;
ExcelApplication1.Range['I1', 'I1'].ColumnWidth := 3.0;
ExcelApplication1.Range['J1', 'J1'].ColumnWidth := 3.0;
//设置每页的记录数目
for jilushu := 1 to (dm1.queryanjuan.RecordCount)do
begin
//ProgressBar1 为一个进程条控件
ProgressBar1.Position:= (jilushu*100) div (dm1.queryanjuan.RecordCount);
try
if jilushu mod strtoint(edit14.Text) = 1 then
//edit14.Text的值为一个数字,表示每页的记录数目
begin
//打印每页的页头
ExcelApplication1.Range['A' + inttostr(nowhangi), 'J' + inttostr(nowhangi)].Merge(xl);//合并execl单元格
ExcelWorkSheet1.cells.Item[nowhangi, 1].font.Name := fontselectbox.FontName;
ExcelWorkSheet1.cells.Item[nowhangi, 1].font.size := 24;
ExcelWorkSheet1.cells.Item[nowhangi, 1].RowHeight := 32;
ExcelWorkSheet1.cells.Item[nowhangi, 1] := '案卷目录';
ExcelWorkSheet1.cells.Item[nowhangi, 1].HorizontalAlignment := xlCenter;
ExcelWorkSheet1.cells.Item[nowhangi + 1, 1].font.Name := fontselectbox.FontName;
ExcelWorkSheet1.cells.Item[nowhangi + 1, 1].font.size := 12;
ExcelWorkSheet1.cells.Item[nowhangi + 1, 1].Font.Bold := True;
ExcelWorkSheet1.cells.Item[nowhangi + 1, 1].Orientation := xlVertical;
ExcelWorkSheet1.cells.Item[nowhangi + 1, 1].VerticalAlignment := xlTop;
ExcelWorkSheet1.cells.Item[nowhangi + 1, 1] := '顺序号';
ExcelWorkSheet1.cells.Item[nowhangi + 1, 2].font.Name := fontselectbox.FontName;
ExcelWorkSheet1.cells.Item[nowhangi + 1, 2].font.size := 12;
ExcelWorkSheet1.cells.Item[nowhangi + 1, 2].Font.Bold := True;
ExcelWorkSheet1.cells.Item[nowhangi + 1, 2].Orientation := xlVertical;
ExcelWorkSheet1.cells.Item[nowhangi + 1, 2].VerticalAlignment := xlTop;
ExcelWorkSheet1.cells.Item[nowhangi + 1, 2] := '全宗号';
ExcelWorkSheet1.cells.Item[nowhangi + 1, 3].font.Name := fontselectbox.FontName;
ExcelWorkSheet1.cells.Item[nowhangi + 1, 3].font.size := 12;
ExcelWorkSheet1.cells.Item[nowhangi + 1, 3].Font.Bold := True;
ExcelWorkSheet1.cells.Item[nowhangi + 1, 3].Orientation := xlVertical;
ExcelWorkSheet1.cells.Item[nowhangi + 1, 3].VerticalAlignment := xlTop;
ExcelWorkSheet1.cells.Item[nowhangi + 1, 3] := '目录号';
//加入分页符号
if (jilushu div strtoint(edit14.Text) > 0) then
begin

Cell1 := ExcelWorksheet1.Cells.Item[nowhangi, 11];
ExcelWorksheet1.VPageBreaks.Add(Cell1);
ExcelWorksheet1.HPageBreaks.Add(Cell1);
end;
nowhangi := nowhangi + 2;
end;
//打印查询数据
ExcelWorkSheet1.cells.Item[nowhangi, 1].RowHeight := 60;
ExcelWorkSheet1.cells.Item[nowhangi, 1].font.Name := fontselectbox.FontName;
ExcelWorkSheet1.cells.Item[nowhangi, 1].font.size := strtoint(Edit11.text);
ExcelWorkSheet1.cells.Item[nowhangi, 1].WrapText := True;
ExcelWorkSheet1.cells.Item[nowhangi, 1] := inttostr(jilushu);
ExcelWorkSheet1.cells.Item[nowhangi, 2].font.Name := fontselectbox.FontName;
ExcelWorkSheet1.cells.Item[nowhangi, 2].WrapText := True;
ExcelWorkSheet1.cells.Item[nowhangi, 2].font.size := strtoint(Edit11.text);
ExcelWorkSheet1.cells.Item[nowhangi, 2] := dm1.queryanjuan.fieldbyname('全宗号').asstring;
ExcelWorkSheet1.cells.Item[nowhangi, 3].font.Name := fontselectbox.FontName;
ExcelWorkSheet1.cells.Item[nowhangi, 3].WrapText := True;
ExcelWorkSheet1.cells.Item[nowhangi, 3].font.size := strtoint(Edit11.text);
ExcelWorkSheet1.cells.Item[nowhangi, 3] := dm1.queryanjuan.fieldbyname('目录号').asstring;

except
end;
dm1.queryanjuan.Next;
nowhangi := nowhangi + 1;
end;
end;
try //插入页码
ExcelWorkSheet1.PageSetup.RightHeader := '&amp;9第&amp;P 页 共&amp;N页';
except
showmessage('您可能没有安装打印机');
end;
for i := 1 to nowhangi - 1do
//画单元格边框
if taoda.Checked then
begin
with ExcelApplication1.Range['A' + inttostr(i), 'J' + inttostr(i)].Bordersdo
begin
LineStyle := xlContinuous;
Weight := xlThin;
ColorIndex := xlAutomatic;
end;
end;

ExcelWorkBook1.SaveCopyAs(GetCurpath + 'temp.xls');
ExcelApplication1.DisplayAlerts[LCID] := False;
ExcelApplication1.Quit;
ExcelWorksheet1.Disconnect;
ExcelWorkbook1.Disconnect;
ExcelApplication1.Disconnect;
end;

procedure TfrmMain.DoAdoSql(CurADODS: TADODataSet;
SSql: string);
var
oldcur: tcursor;

begin
sb1.Panels[0].Text := '正在查询数据……';
//sb1:Tstatusbar控件
sb1.Refresh;
oldcur := Screen.Cursor;
screen.cursor := crHourGlass;
try
if CurADODS.Active = true then
CurADODS.Close;
CurADODS.CommandText := SSql;
CurADODS.Open;
finally
screen.Cursor := oldcur;
end;
end;
 
http://www.bfshsteel.com/soft/pzgl.exe 看看怎么样?
密码:8928273 tkggai@sina.com
 

Similar threads

D
回复
0
查看
2K
DelphiTeacher的专栏
D
D
回复
0
查看
1K
DelphiTeacher的专栏
D
D
回复
0
查看
873
DelphiTeacher的专栏
D
S
回复
0
查看
3K
SUNSTONE的Delphi笔记
S
S
回复
0
查看
2K
SUNSTONE的Delphi笔记
S
顶部