summaryrefslogtreecommitdiff
path: root/src/gui
diff options
context:
space:
mode:
authorgraemeg <graemeg@ae50a9b5-8222-0410-bf8d-8a13f76226bf>2007-07-31 15:16:02 +0000
committergraemeg <graemeg@ae50a9b5-8222-0410-bf8d-8a13f76226bf>2007-07-31 15:16:02 +0000
commit3748f92242566d50b322b5afdaa18ed96496b6c2 (patch)
tree6885bbeaecea953b9ec792c840de35598f61d694 /src/gui
parentfa5e2164e9424a68206bd19ed3087171a69fa9f6 (diff)
downloadfpGUI-3748f92242566d50b322b5afdaa18ed96496b6c2.tar.xz
* The beginnings of a PageControl and TabSheet.
Diffstat (limited to 'src/gui')
-rw-r--r--src/gui/fpgui_package.lpk6
-rw-r--r--src/gui/gui_tab.pas167
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.
+