How to show data at Fast Report in 3*3 grid format?

前端 未结 2 1155
一向
一向 2020-12-20 06:03

I want to display data from table (column :- ID) at FastReport in Grid format as shown below. Suppose there are 22 records in table then it would display same in 3 * 3 grid

相关标签:
2条回答
  • 2020-12-20 06:46

    Public variable declarations

      public
        i: integer;
        myid: Array Of Integer;
        mydesc: Array Of String;
        k: Integer;
        rowcount: Integer;
    

    Code at FormCreate event

    begin
        i := 0;
        k := 0;
        UniTable1.SQL.Text := 'Select * from userplays';
        UniTable1.Execute;
        rowcount := UniTable1.RecordCount;
        SetLength(myid, rowcount);
        SetLength(mydesc, rowcount);
    
          while not UniTable1.Eof do
          begin
             myid[k] := UniTable1.FieldByName('id').Value;
             mydesc[k] := UniTable1.FieldByName('description').Value;
             UniTable1.Next;
             inc(k);
          end;
    end.
    

    Code at OnGetValue event of the frxReport

    var
      j: Integer;
    
    begin
     j := i div 2;
     if j < rowcount then
       begin
    
         if (VarName = 'ID1') then
           Value :=  myid[j];
    
         if (VarName = 'DESC1') then
           Value :=  mydesc[j];
    
       end
     inc(i);
    

    Above ID1 and DESC1 are two variable declared at frxReport memo, value assigned to it at OnGetValue event with the help of global Array myid & mydesc. Global arrays myid & mydesc are filled with database field values at FormCreate event.

    0 讨论(0)
  • 2020-12-20 07:01

    EDIT since the previous* answer does not work with newer versions

    Set rowcount to 9 for your masterdata band of the subreport.
    In your mainreport, copy the masterdata band containing the subreport and insert it twice.
    Put a headerband between the masterbands with property StartNewPage set to true.
    Add OnBeforePrint events to the second and the third subreport to change the filter for the dataset.

    procedure Subreport2OnBeforePrint(Sender: TfrxComponent);
    begin
      TfrxDBDataSet(Report.GetDataset('frxDBDataset1')).Dataset.Filter := 'ID>9';  
      TfrxDBDataSet(Report.GetDataset('frxDBDataset1')).Dataset.Filtered := true;                                          
    end;
    
    procedure Subreport3OnBeforePrint(Sender: TfrxComponent);
    begin
      TfrxDBDataSet(Report.GetDataset('frxDBDataset1')).Dataset.Filter := 'ID>18';  
      TfrxDBDataSet(Report.GetDataset('frxDBDataset1')).Dataset.Filtered := true;  
    end;
    

    enter image description here

    (*) for older report versions, you can use an other approach, which stopped working between the versions 4.10.01 and 4.12.14.

    Add an OnAfterPrint event to your memo on the subreport. Set the property StartNewPage to true after printing 9 "lines", Rowcount of the Masterband has to set to 1.

    procedure YourMemoFromTheSubReportToRepeat9TimesPerPageOnAfterPrint(Sender: TfrxComponent);
    begin
        MasterDataBandFromSubReport.StartNewPage := <Line#>  mod 9 = 0  
    end;
    

    enter image description here

    0 讨论(0)
提交回复
热议问题