动态创建FastReport4报表2 - 由cxGrid动态创建报表

本文介绍了一种使用Delphi动态创建FastReport4报表的方法,包括如何设置报表页面、标题、页眉等,并通过循环遍历表格视图的列来自动生成报表数据区域及表头。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

动态创建FastReport4报表2

这次在第一版的基础上增加了对数据集的支持


unit Unit1;
  
interface
  
uses
  Windows, Messages, SysUtils, Variants, Classes, Graphics, Controls, Forms,
  Dialogs, cxGraphics, cxControls, cxLookAndFeels, cxLookAndFeelPainters,
  cxContainer, cxEdit, cxTextEdit, cxMaskEdit, cxButtonEdit, cxStyles,
  cxCustomData, cxFilter, cxData, cxDataStorage, DB, cxDBData,
  cxGridCustomTableView, cxGridTableView, cxGridDBTableView, ComCtrls, frxClass,
  ToolWin, ADODB, cxGridLevel, cxClasses, cxGridCustomView, cxGrid, frxDesgn,
  frxDBSet, frxDMPExport, frxDCtrl, frxBarcode;
  
type
  TForm1 = class(TForm)
    cxGrid1DBTableView1: TcxGridDBTableView;
    cxGrid1Level1: TcxGridLevel;
    cxGrid1: TcxGrid;
    ADOTable1: TADOTable;
    DataSource1: TDataSource;
    ADOConnection1: TADOConnection;
    ToolBar1: TToolBar;
    ToolButton1: TToolButton;
    cxGrid1DBTableView1OID: TcxGridDBColumn;
    cxGrid1DBTableView1AID: TcxGridDBColumn;
    cxGrid1DBTableView1Name: TcxGridDBColumn;
    cxGrid1DBTableView1Code: TcxGridDBColumn;
    cxGrid1DBTableView1Description: TcxGridDBColumn;
    cxGrid1DBTableView1Address: TcxGridDBColumn;
    cxGrid1DBTableView1Logo: TcxGridDBColumn;
    cxGrid1DBTableView1Level: TcxGridDBColumn;
    cxGrid1DBTableView1CodeB: TcxGridDBColumn;
    frxDesigner1: TfrxDesigner;
    frxDBDataset1: TfrxDBDataset;
    frxDialogControls1: TfrxDialogControls;
    frxReport1: TfrxReport;
    frxBarCodeObject1: TfrxBarCodeObject;
    procedure ToolButton1Click(Sender: TObject);
  private
    { Private declarations }
  public
    { Public declarations }
  end;
  
var
  Form1: TForm1;
  
implementation
  
{$R *.dfm}
  
procedure TForm1.ToolButton1Click(Sender: TObject);
var
  vPage: TfrxReportPage;
  vTitle: TfrxReportTitle;
  vHeader: TfrxPageHeader;
  vView: TfrxMemoView;
  vData: TfrxMasterData;
  vDataView: TfrxMemoView;
  vHeadView: TfrxMemoView;
  i: integer;
  vLeft: integer;
begin
  frxReport1.Clear;
  frxReport1.DataSets.Add(frxDBDataset1);
  vPage := TfrxReportPage.Create(frxReport1);
  vPage.CreateUniqueName;
  vPage.LeftMargin := 10;
  vPage.RightMargin := 10;
  vPage.TopMargin := 10;
  vPage.BottomMargin := 10;
  vTitle := TfrxReportTitle.Create(vPage);
  vTitle.CreateUniqueName;
  vTitle.Height := 48;
  vTitle.Top := 0;
  
  vView := TfrxMemoView.Create(vTitle);
  vView.CreateUniqueName;
  vView.Top := 0;
  vView.Left := 0;
  vView.Width := vPage.Width - Round(vPage.LeftMargin * 2.8) - Round(vPage.RightMargin* 2.8);
  vView.Height := vTitle.Height;
  vView.Text := 'This is a title';
  vView.Font.Size := 24;
  vView.Font.Style := vView.Font.Style + [fsBold];
  vView.HAlign := frxClass.haCenter;
  
  vHeader := TfrxPageHeader.Create(vPage);
  vHeader.CreateUniqueName;
  vHeader.Top := 0;
  vHeader.Height := 20;
  
  vData := TfrxMasterData.Create(vPage);
  vData.CreateUniqueName;
  vData.Height := 20;
  vData.Top := 0;
  vData.DataSet := frxDBDataset1;
  vLeft := 0;
  for i := 0 to cxGrid1DBTableView1.ColumnCount - 1 do
  begin
    vDataView := TfrxMemoView.Create(vData);
    vDataview.WordBreak := True;
    vDataView.Frame.Typ := [ftLeft, ftRight, ftTop, ftBottom];
    vDataView.VAlign := frxClass.vaCenter;
    vDataView.Top := 0;
    vDataView.Left := vLeft;
    vDataView.Height := vData.Height;
    vDataView.Font.Name := 'Tahoma';
    vDataView.Font.Size := 8;
  
    vHeadView := TfrxMemoView.Create(vHeader);
    vHeadView.CreateUniqueName;
    vHeadView.WordBreak := True;
    vHeadView.Frame.Typ := [ftLeft, ftRight, ftTop, ftBottom];
    vHeadView.VAlign := frxClass.vaCenter;
    vHeadView.Left := vLeft;
    vHeadView.Height := vData.Height;
    vHeadView.Font.Name := 'Tahoma';
    vHeadView.Font.Size := 8;
  
    vDataView.Width := cxGrid1DBTableView1.Columns[i].Width;
  
    vHeadView.Width :=cxGrid1DBTableView1.Columns[i].Width;
    vHeadView.Text := cxGrid1DBTableView1.Columns[i].Caption;
    vDataView.Text := Format('[frxDBDataset1."%s"]', [cxGrid1DBTableView1.Columns[i].DataBinding.FieldName]);
    vleft := vLeft + cxGrid1DBTableView1.Columns[i].Width;
  end;
  
//  frxReport1.PrepareReport();
  frxReport1.ShowReport();
//  frxReport1.DesignReport();
end;
  
  
  
end.



StringGrid打印报表(FastReport) {*************StringGrid打印功能***********************************} (*uses unit: FR_Class, FR_View from (fast-Report) *) (*参数说明:printRow:每页打印的行数 *) (* styleType:边框类型 0:无边框,15:所有边框,18:底部画线 *) (* title:标题 *) (* FrmGrid:所在窗体 *) (*date:2005-04-24 *) (*author:kxy *) {******************************************************************} function GridPrint (Grid1:TstringGrid;printRow,StyleType:integer;Title:string;FrmGrid:TForm):boolean;//打印报 表 var fr: TfrReport; ReportTitle,Masterdata,ColumnHeader,PageHeader,pageFooter:Tfrbandview; //栏目 MemoVT,MemoVC:Array of TfrMemoview; //列 TitleV ,dateV,pageV:TfrMemoview ; lineV:TfrlineView; //线 page:Tfrpage; //页 GridRow,GridCol,CurrRow,I,J,col:integer;//总的行数,列数,当前行 PageCount,pageRow:integer; //总共页数; Left,Top,Width,Heigth:integer; TempLeft,TempWidth:integer; printDate :string; begin screen.Cursor := crHourGlass; GridRow := Grid1.RowCount; GridCol := Grid1.ColCount; CurrRow := 0; pageRow := printRow; try fr := TfrReport.Create(FrmGrid); fr.StoreInDFM := True; PageCount := GridRow div printRow ; //计算出页数 for I := 0 to PageCount - 1 do begin left :=0; top :=20; width :=757; heigth :=25; fr.Pages.Add; page := fr.Pages[i]; if I = 0 then //第一页增加标题; begin {标题栏} ReportTitle := Tfrbandview.Create; ReportTitle.BandType := btReportTitle; ReportTitle.SetBounds(left,top,width,40); page.Objects.Add(ReportTitle); TitleV := TfrMemoview.Create; Titlev.SetBounds(0,top,width,30); Titlev.Alignment := (Titlev.Alignment and $FC) + 2;//居中 Titlev.Font.Name := '宋体'; TitleV.Font.Size := 16; TitleV.Memo.Add(title); page.Objects.Add(TitleV); {打印日期} dateV := TfrMemoview.Create; dateV.SetBounds(0,top + 40,width,30); dateV.Alignment := (dateV.Alignment and $FC) + 1 ;//右对齐 dateV.Font.Name := '宋体'; dateV.Font.Size := 9; printDate :='打印日期:' + FormatDateTime('yyyy/mm/dd',Now) +' '; dateV.Memo.Add(printDate); page.Objects.Add(dateV); PageRow := PageRow - 4 ; //少打两行组成一个标题 Top := 60; end ELSE begin pageRow := PrintRow; Top := 20; end; for J:= 0 to PageRow + 1 do //每页的行数 begin {列头} IF J = 0 then //第一行打行列标题栏 begin ColumnHeader := Tfrbandview.Create; ColumnHeader.BandType := btColumnHeader; ColumnHeader.SetBounds(left,top,width,heigth); page.Objects.Add(ColumnHeader); SetLength(MemoVT,GridCol); TempLeft := 20; for col:= 0 to GridCol - 1 do begin MemoVt[col] := TfrMemoview.Create; MemoVt[col].Font.Name := Grid1.Font.Name; MemoVt[col].Font.Size := Grid1.Font.Size; MemoVt[col].Memo.Add(Grid1.Cells[col,0]); MemoVt[col].FrameTyp := StyleType; //显示边框 TempWidth := Grid1.ColWidths[col]; //宽度与Grid中的宽度一致 MemoVt[col].SetBounds(tempLeft,top ,tempWidth,heigth); templeft := tempLeft + tempwidth; page.Objects.Add(MemoVt[col]) end; end Else begin top := top + heigth; Inc(CurrRow); TempLeft := 20; SetLength(MemoVc,GridCol); for col :=0 to GridCol - 1 do begin MemoVc[col] := TfrMemoview.Create; MemoVc[col].Font.Name := Grid1.Font.Name; MemoVc[col].Font.Size := Grid1.Font.Size; MemoVc[col].Memo.Add(Grid1.Cells[col,CurrRow]); MemoVc[col].FrameTyp := StyleType; //显示边框 TempWidth := Grid1.ColWidths[col]; //宽度与Grid中的宽度一致 MemoVc[col].SetBounds(tempLeft,top ,tempWidth,heigth); templeft := tempLeft + tempwidth; page.Objects.Add(MemoVc[col]); end; end; if currRow >= GridRow then break; end; {页码} pageV := TfrMemoview.Create; pageV.Font.Name := '宋体'; pagev.Font.Size := 10; pagev.FrameWidth := 2; //pagev.FrameTyp := 24 ; pagev.Alignment := (pagev.Alignment and $FC) + 2;//居中 pageV.Memo.Add('第'+ inttostr(I + 1) + '页 (共' + inttostr(PageCount) + '页)' ); pagev.SetBounds(0,1025,750,20); page.Objects.Add(pageV); end; fr.ShowReport; screen.Cursor := crDefault; finally fr.Free; end; end;
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值