diff options
author | graemeg <graemeg@ae50a9b5-8222-0410-bf8d-8a13f76226bf> | 2007-07-31 15:16:02 +0000 |
---|---|---|
committer | graemeg <graemeg@ae50a9b5-8222-0410-bf8d-8a13f76226bf> | 2007-07-31 15:16:02 +0000 |
commit | 3748f92242566d50b322b5afdaa18ed96496b6c2 (patch) | |
tree | 6885bbeaecea953b9ec792c840de35598f61d694 /src/gui | |
parent | fa5e2164e9424a68206bd19ed3087171a69fa9f6 (diff) | |
download | fpGUI-3748f92242566d50b322b5afdaa18ed96496b6c2.tar.xz |
* The beginnings of a PageControl and TabSheet.
Diffstat (limited to 'src/gui')
-rw-r--r-- | src/gui/fpgui_package.lpk | 6 | ||||
-rw-r--r-- | src/gui/gui_tab.pas | 167 |
2 files changed, 172 insertions, 1 deletions
diff --git a/src/gui/fpgui_package.lpk b/src/gui/fpgui_package.lpk index 9959cfb8..5cc884cf 100644 --- a/src/gui/fpgui_package.lpk +++ b/src/gui/fpgui_package.lpk @@ -18,7 +18,7 @@ <Description Value="fpGUI - multi-handle redesign"/> <License Value="Modified LGPL"/> <Version Minor="5"/> - <Files Count="14"> + <Files Count="15"> <Item1> <Filename Value="gui_button.pas"/> <UnitName Value="gui_button"/> @@ -75,6 +75,10 @@ <Filename Value="gui_trackbar.pas"/> <UnitName Value="gui_trackbar"/> </Item14> + <Item15> + <Filename Value="gui_tab.pas"/> + <UnitName Value="gui_tab"/> + </Item15> </Files> <RequiredPkgs Count="2"> <Item1> diff --git a/src/gui/gui_tab.pas b/src/gui/gui_tab.pas new file mode 100644 index 00000000..b1262ca3 --- /dev/null +++ b/src/gui/gui_tab.pas @@ -0,0 +1,167 @@ +unit gui_tab; + +{$mode objfpc}{$H+} + +{ + Incomplete: I'm currently busy developing this component. +} + +interface + +uses + Classes, + SysUtils, + fpgfx, + gfx_widget, + gui_button; + +type + // forward declaration + TfpgPageControl = class; + + TfpgTabSheet = class(TfpgWidget) + private + function GetPageControl: TfpgPageContol; + function GetPageIndex: Integer; + function GetText: string; + procedure SetPageControl(const AValue: TfpgPageContol); + procedure SetPageIndex(const AValue: Integer); + procedure SetText(const AValue: string); + public + constructor Create(AOwner: TComponent); override; + destructor Destroy; override; + property Text: string read GetText write SetText; + property PageIndex: Integer read GetPageIndex write SetPageIndex stored False; + property PageControl: TfpgPageContol read GetPageControl write SetPageControl; + end; + + + TTabSheetChange = procedure(Sender: TObject; NewActiveSheet: TfpgTabSheet); + + + TfpgPageControl = class(TfpgWidget) + private + FPages: TList; + FActivePageIndex: integer; + FOnChange: TTabSheetChange; + function GetActivePageIndex: integer; + function GetPageCount: Integer; + procedure InsertPage(const APage: TfpgTabSheet); + procedure RemovePage(const APage: TfpgTabSheet); + protected + procedure UnregisterTabSheet(ATabSheet: TfpgTabSheet); + procedure RegisterTabSheet(ATabSheet: TfpgTabSheet); + public + constructor Create(AOwner: TComponent); override; + property PageCount: Integer read GetPageCount; + property ActivePageIndex: integer read GetActivePageIndex write FActivePageIndex; + property OnChange: TTabSheetChange read FOnChange write FOnChange; + end; + + +implementation + +{ TfpgTabSheet } + +function TfpgTabSheet.GetPageControl: TfpgPageContol; +begin + if Owner is TfpgPageControl then + Result := TfpgPageControl(Owner) + else + Result := nil; +end; + +function TfpgTabSheet.GetPageIndex: Integer; +begin + if PageControl <> nil then + Result := PageControl.FPages.IndexOf(Self) + else + Result := -1; +end; + +function TfpgTabSheet.GetText: string; +begin + +end; + +procedure TfpgTabSheet.SetPageControl(const AValue: TfpgPageContol); +begin + if PageControl <> AValue then + begin + if PageControl <> nil then + PageControl.RemovePage(self); + Owner := AValue; + if AValue <> nil then + AValue.InsertPage(self); + end; +end; + +procedure TfpgTabSheet.SetPageIndex(const AValue: Integer); +begin + +end; + +procedure TfpgTabSheet.SetText(const AValue: string); +begin + +end; + +constructor TfpgTabSheet.Create(AOwner: TComponent); +begin + inherited Create(AOwner); + FFocusable := True; + if Owner is TfpgPageControl then + begin + TfpgPageControl(Owner).RegisterTabSheet(self); + FPageIndex := TfpgPageControl(Owner).PageCount + 1; + end; +end; + +destructor TfpgTabSheet.Destroy; +begin + if Owner is TfpgPageControl then + TfpgPageControl(Owner).UnregisterTabSheet(self); + inherited Destroy; +end; + +{ TfpgPageControl } + +function TfpgPageControl.GetActivePageIndex: integer; +begin + +end; + +function TfpgPageControl.GetPageCount: Integer; +begin + Result := FPages.Count; +end; + +procedure TfpgPageControl.InsertPage(const APage: TfpgTabSheet); +begin + +end; + +procedure TfpgPageControl.RemovePage(const APage: TfpgTabSheet); +begin + +end; + +procedure TfpgPageControl.UnregisterTabSheet(ATabSheet: TfpgTabSheet); +begin + +end; + +procedure TfpgPageControl.RegisterTabSheet(ATabSheet: TfpgTabSheet); +begin + +end; + +constructor TfpgPageControl.Create(AOwner: TComponent); +begin + inherited Create(AOwner); + FPages := TList.Create; + FOnChange := nil; +end; + +end. + |