summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorgraemeg <graemeg@ae50a9b5-8222-0410-bf8d-8a13f76226bf>2008-01-10 15:03:10 +0000
committergraemeg <graemeg@ae50a9b5-8222-0410-bf8d-8a13f76226bf>2008-01-10 15:03:10 +0000
commit249cb5ab4a5150a34fc36c1b58e45cdb6310e331 (patch)
tree7779a1999bd71160a2c0b1b18a128c2b355fae85 /src
parent5bd231fc9fefecd6f8916be29673218c4bd9a9a1 (diff)
downloadfpGUI-249cb5ab4a5150a34fc36c1b58e45cdb6310e331.tar.xz
* Made some nice progress with the MessageDialog class. Buttons are created dynamically. Captions get set and the default button gets set. I still have plenty to do, but it's progress.
Diffstat (limited to 'src')
-rw-r--r--src/gui/gui_dialogs.pas9
-rw-r--r--src/gui/messagedialog.inc209
2 files changed, 204 insertions, 14 deletions
diff --git a/src/gui/gui_dialogs.pas b/src/gui/gui_dialogs.pas
index e3537243..18b29373 100644
--- a/src/gui/gui_dialogs.pas
+++ b/src/gui/gui_dialogs.pas
@@ -33,6 +33,7 @@ interface
uses
Classes,
SysUtils,
+ gfxbase,
fpgfx,
gfx_imgfmt_bmp,
gui_form,
@@ -59,6 +60,11 @@ const
mbAbortRetryIgnore = [mbAbort, mbRetry, mbIgnore];
+ { todo: Somehow we need to localize this }
+ cMsgDlgBtnText: array[TfpgMsgDlgBtn] of string =
+ ( '', 'Yes', 'No', 'OK', 'Cancel', 'Abort', 'Retry', 'Ignore',
+ 'All', 'No to All', 'Yes to All', 'Help', 'Close' );
+
type
TfpgMessageBox = class(TfpgForm)
@@ -186,7 +192,6 @@ function SelectFontDialog(var FontDesc: string): boolean;
implementation
uses
- gfxbase,
gfx_widget,
gfx_utf8utils
{$IFDEF MSWINDOWS}
@@ -416,11 +421,13 @@ begin
FDefaultButtonWidth := 80;
btnCancel := CreateButton(self, Width-FDefaultButtonWidth-FSpacing, 370, FDefaultButtonWidth, 'Cancel', @btnCancelClick);
+ btnCancel.Name := 'btnCancel';
btnCancel.ImageName := 'stdimg.Cancel';
btnCancel.ShowImage := True;
btnCancel.Anchors := [anRight, anBottom];
btnOK := CreateButton(self, btnCancel.Left-FDefaultButtonWidth-FSpacing, 370, FDefaultButtonWidth, 'OK', @btnOKClick);
+ btnOK.Name := 'btnOK';
btnOK.ImageName := 'stdimg.OK';
btnOK.ShowImage := True;
btnOK.Anchors := [anRight, anBottom];
diff --git a/src/gui/messagedialog.inc b/src/gui/messagedialog.inc
index ddfae403..d3e7b31f 100644
--- a/src/gui/messagedialog.inc
+++ b/src/gui/messagedialog.inc
@@ -1089,18 +1089,28 @@ type
FButtons: TfpgMsgDlgButtons;
FDefaultButton: TfpgMsgDlgBtn;
FDialogType: TfpgMsgDlgType;
+ FButtonList: TList; // pointers to buttons
procedure SetButtons(const AValue: TfpgMsgDlgButtons);
procedure SetDefaultButton(const AValue: TfpgMsgDlgBtn);
procedure SetInformativeText(const AValue: string);
procedure SetText(const AValue: string);
procedure pnlIconPaint(Sender: TObject);
+ procedure PrepareIcon;
+ procedure PrepareText;
+ procedure PrepareButtons;
protected
+ procedure SetWindowTitle(const ATitle: string); override;
procedure HandlePaint; override;
+ procedure HandleShow; override;
+ procedure HandleResize(awidth, aheight: TfpgCoord); override;
+ procedure PrepareLayout;
public
{@VFD_HEAD_BEGIN: fpgMessageDialog}
lblName1: TfpgLabel;
pnlIcon: TfpgBevel;
{@VFD_HEAD_END: fpgMessageDialog}
+ constructor Create(AOwner: TComponent); override;
+ destructor Destroy; override;
procedure AfterCreate; override;
class procedure About(const ATitle: string; const AText: string);
class procedure AboutFPGui(const ATitle: string = '');
@@ -1162,12 +1172,105 @@ begin
wg.Visible := False;
end;
+procedure TfpgMessageDialog.PrepareIcon;
+begin
+ writeln(' > implement PrepareIcon');
+end;
+
+procedure TfpgMessageDialog.PrepareText;
+begin
+ writeln(' > implement PrepareText');
+ Height := 150;
+end;
+
+procedure TfpgMessageDialog.PrepareButtons;
+const
+ cSpacing = 4;
+var
+ i: integer;
+ b: TfpgButton;
+ lcount: integer;
+ lwidth: integer;
+ ltop: integer;
+ lleft: integer;
+ sl: TStringList;
+ lDefault: integer;
+
+ function GetButtonCount: integer;
+ var
+ i: TfpgMsgDlgBtn;
+ begin
+ Result := 0;
+ for i := Low(TfpgMsgDlgBtn) to High(TfpgMsgDlgBtn) do
+ begin
+ if i in Buttons then
+ begin
+ inc(Result);
+ sl.Add(cMsgDlgBtnText[i]);
+ if i = DefaultButton then
+ lDefault := Result-1;
+ end;
+ end;
+ end;
+
+begin
+ writeln('PrepareButtons');
+ sl := TStringList.Create; // holds button captions
+ lcount := GetButtonCount;
+ lwidth := 0;
+ writeln(' DEBUG: form width: ', width, ' height:', height, ' count:', lcount);
+
+ // create buttons
+ for i := 0 to lcount-1 do
+ begin
+ b := TfpgButton.Create(self);
+ b.Text := sl[i];
+ b.Name := 'DlgButton' + IntToStr(i+1);
+ if (i = lDefault) or (lcount = 1) then
+ b.Default := True;
+ FButtonList.Add(b);
+ lwidth := lwidth + b.Width
+ end;
+ lwidth := lwidth + (cSpacing * (lcount-1));
+
+ // position buttons
+ ltop := Height - TfpgButton(FButtonList[0]).Height - cSpacing;
+ lleft := (Width - lwidth) div 2;
+ for i := 0 to lcount-1 do
+ begin
+ b := TfpgButton(FButtonList[i]);
+ b.SetPosition(lleft, ltop, b.Width, b.Height);
+ writeln(' button l:', lleft, ' t:', ltop, ' w:', b.width, ' h:', b.height);
+ lleft := lleft + b.Width + cSpacing;
+ end;
+
+ sl.Free;
+end;
+
+procedure TfpgMessageDialog.SetWindowTitle(const ATitle: string);
+begin
+ if ATitle = '' then
+ begin
+ case DialogType of
+ mtAbout: SetWindowTitle('About fpGUI...');
+ mtError: SetWindowTitle('Error');
+ mtWarning: SetWindowTitle('Warning');
+ mtConfirmation: SetWindowTitle('Confirmation');
+ end;
+ end
+ else
+ inherited SetWindowTitle(ATitle);
+end;
+
procedure TfpgMessageDialog.HandlePaint;
var
logo: TfpgImage;
+ i: integer;
begin
- inherited HandlePaint;
+// writeln('HandlePaint');
+
Canvas.BeginDraw;
+ inherited HandlePaint;
case FDialogType of
mtAbout:
begin
@@ -1202,6 +1305,55 @@ begin
Canvas.EndDraw;
end;
+procedure TfpgMessageDialog.HandleShow;
+var
+ i: integer;
+begin
+// writeln('HandleShow');
+ inherited HandleShow;
+
+ for i := 0 to ComponentCount-1 do
+ if Components[i] is TfpgButton then
+ if TfpgButton(Components[i]).Default then
+ TfpgButton(Components[i]).SetFocus;
+end;
+
+procedure TfpgMessageDialog.HandleResize(awidth, aheight: TfpgCoord);
+begin
+// writeln('HandleResize');
+ inherited HandleResize(awidth, aheight);
+end;
+
+procedure TfpgMessageDialog.PrepareLayout;
+begin
+ PrepareIcon;
+ PrepareText;
+ PrepareButtons;
+end;
+
+constructor TfpgMessageDialog.Create(AOwner: TComponent);
+begin
+ inherited Create(AOwner);
+ FButtonList := TList.Create;
+
+{
+ btnOK.Enabled := False;
+ btnOK.Visible := False
+ btnCancel.Enabled := False;
+ btnCancel.Visible := False;
+}
+end;
+
+destructor TfpgMessageDialog.Destroy;
+begin
+ while FButtonList.Count > 0 do
+ begin
+ TfpgButton(FButtonList.Last).Free;
+ FButtonList.Remove(FButtonList.Last);
+ end;
+ inherited Destroy;
+end;
+
class procedure TfpgMessageDialog.About(const ATitle: string; const AText: string);
begin
writeln('** Implement TfpgMessageDialog.About');
@@ -1228,8 +1380,22 @@ end;
class function TfpgMessageDialog.Critical(const ATitle: string;
const AText: string; AButtons: TfpgMsgDlgButtons;
ADefaultButton: TfpgMsgDlgBtn): TfpgMsgDlgBtn;
+var
+ dlg: TfpgMessageDialog;
begin
writeln('** Implement TfpgMessageDialog.Critical');
+ dlg := TfpgMessageDialog.Create(nil);
+ try
+ dlg.FDialogType := mtWarning;
+ dlg.FButtons := AButtons;
+ dlg.Text := AText;
+ dlg.WindowTitle := ATitle;
+ dlg.FDefaultButton := ADefaultButton;
+ dlg.PrepareLayout;
+ Result := TfpgMsgDlgBtn(dlg.ShowModal);
+ finally
+ dlg.Free;
+ end;
end;
class function TfpgMessageDialog.Information(const ATitle: string;
@@ -1238,12 +1404,15 @@ class function TfpgMessageDialog.Information(const ATitle: string;
var
dlg: TfpgMessageDialog;
begin
-// writeln('** Implement TfpgMessageDialog.Information');
+ writeln('** Implement TfpgMessageDialog.Information');
dlg := TfpgMessageDialog.Create(nil);
try
- dlg.FDialogType := mtInformation;
- dlg.Text := AText;
- dlg.WindowTitle := ATitle;
+ dlg.FDialogType := mtInformation;
+ dlg.FButtons := AButtons;
+ dlg.Text := AText;
+ dlg.WindowTitle := ATitle;
+ dlg.FDefaultButton := ADefaultButton;
+ dlg.PrepareLayout;
dlg.ShowModal;
finally
dlg.Free;
@@ -1257,29 +1426,43 @@ var
dlg: TfpgMessageDialog;
begin
writeln('** Implement TfpgMessageDialog.Question');
-{
dlg := TfpgMessageDialog.Create(nil);
try
- dlg.FDialogType := mtConfirmation;
- dlg.Text := AText;
- dlg.WindowTitle := ATitle;
- Result := dlg.ShowModal;
+ dlg.FDialogType := mtConfirmation;
+ dlg.FButtons := AButtons;
+ dlg.Text := AText;
+ dlg.WindowTitle := ATitle;
+ dlg.FDefaultButton := ADefaultButton;
+ dlg.PrepareLayout;
+ Result := TfpgMsgDlgBtn(dlg.ShowModal);
finally
dlg.Free;
end;
-}
end;
class function TfpgMessageDialog.Warning(const ATitle: string;
const AText: string; AButtons: TfpgMsgDlgButtons;
ADefaultButton: TfpgMsgDlgBtn): TfpgMsgDlgBtn;
+var
+ dlg: TfpgMessageDialog;
begin
writeln('** Implement TfpgMessageDialog.Warning');
+ dlg := TfpgMessageDialog.Create(nil);
+ try
+ dlg.FDialogType := mtWarning;
+ dlg.FButtons := AButtons;
+ dlg.Text := AText;
+ dlg.WindowTitle := ATitle;
+ dlg.FDefaultButton := ADefaultButton;
+ dlg.PrepareLayout;
+ Result := TfpgMsgDlgBtn(dlg.ShowModal);
+ finally
+ dlg.Free;
+ end;
end;
procedure TfpgMessageDialog.AfterCreate;
begin
- writeln('TfpgMessageDialgo.AfterCreate');
{@VFD_BODY_BEGIN: fpgMessageDialog}
Name := 'fpgMessageDialog';
SetPosition(303, 245, 447, 400);
@@ -1291,7 +1474,7 @@ begin
with lblName1 do
begin
Name := 'lblName1';
- SetPosition(116, 20, 312, 16);
+ SetPosition(116, 20, 312, Font.Height);
Text := 'Label';
FontDesc := '#Label2';
end;