Writing Custom Wizards 編寫自定義的嚮導ide
You can extend FastReport's functionality with the help of custom wizards. FastReport, for example, contains the standard 「Report Wizard」 which is called from the 「File >|New…」 menu item.this
There are two types of wizards supported by FastReport. The first type includes the wizard already mentioned, called from the 「File>New…」 menu item. The second one includes wizards that can be called from the 「Wizards」 toolbar.orm
The base class for any wizard is 「TfrxCustomWizard」, defined in the 「frxClass」 file.ip
TfrxCustomWizard = class(TComponent)it
Publicio
Constructor Create(AOwner: TComponent); override;ast
class function GetDescription: String; virtual; abstract; //須要實現function
function Execute: Boolean; virtual; abstract; //須要實現form
property Designer: TfrxCustomDesigner read FDesigner;class
property Report: TfrxReport read FReport;
end;
To write your own wizard inherit from this class and override at least the 「GetDescription」 and 「Execute」 methods. The first method returns the wizard name; the second method is called when running the wizard; it must return 「True」 if the wizard finished successfully and made any changes to the report. While the wizard is running you can access designer and report methods and properties as normal using the 「Designer」 and 「Report」 properties.
Wizard registration and deletion is performed using the procedures defined in the 「frxDsgnIntf」 file:
嚮導的註冊用如下方法,聲明在frxDsgnIntf文件:
frxWizards.Register(ClassRef: TfrxWizardClass; ButtonBmp: TBitmap;IsToolbarWizard: Boolean = False);
frxWizards.Unregister(ClassRef: TfrxWizardClass);
On registration supply the wizard class name, its picture and whether the wizard is to be placed on the 「Wizards」 toolbar. If the wizard should be placed on the toolbar the ButtonBmp size must be either 16x16 pixels or 32x32 pixels.
//舉例
Let's look at a primitive wizard that will be accessed through the "File>New..." menu item. It adds a new page to a report.
uses frxClass, frxDsgnIntf;
type
TfrxMyWizard = class(TfrxCustomWizard)
public
//須要重寫的方法
class function GetDescription: String; override;
function Execute: Boolean; override;
end;
class function TfrxMyWizard.GetDescription: String;
begin
Result := 'My Wizard';
end;
function TfrxMyWizard.Execute: Boolean;
var
Page: TfrxReportPage;
begin
{ lock any drawings in designer }
Designer.Lock;
{ create new page in report }
Page := TfrxReportPage.Create(Report);
{ create unique name for page }
Page.CreateUniqueName;
{ set paper sizes and orientation to defaults }
Page.SetDefaults;
{ update report pages and switch focus to last added page }
Designer.ReloadPages(Report.PagesCount - 1);
end;
//註冊
var
Bmp: TBitmap;
initialization
Bmp := TBitmap.Create;
{ load picture from resource; of course, it must already be there }
Bmp.LoadFromResourceName(hInstance, 'frxMyWizard');
frxWizards.Register(TfrxMyWizard, Bmp);
finalization
frxWizards.Unregister(TfrxMyWizard);
Bmp.Free;
end.