summaryrefslogtreecommitdiff
path: root/prototypes
diff options
context:
space:
mode:
Diffstat (limited to 'prototypes')
-rw-r--r--prototypes/newmultihandle/examples/helloworld.lpi7
-rw-r--r--prototypes/newmultihandle/examples/helloworld.lpr13
-rw-r--r--prototypes/newmultihandle/fpgui.pas2
-rw-r--r--prototypes/newmultihandle/fpguipackage.lpk11
-rw-r--r--prototypes/newmultihandle/gui_button.inc41
-rw-r--r--prototypes/newmultihandle/gui_edit.inc90
-rw-r--r--prototypes/newmultihandle/gui_style.inc13
7 files changed, 151 insertions, 26 deletions
diff --git a/prototypes/newmultihandle/examples/helloworld.lpi b/prototypes/newmultihandle/examples/helloworld.lpi
index 6cc38a28..779ed512 100644
--- a/prototypes/newmultihandle/examples/helloworld.lpi
+++ b/prototypes/newmultihandle/examples/helloworld.lpi
@@ -1,12 +1,12 @@
<?xml version="1.0"?>
<CONFIG>
<ProjectOptions>
- <PathDelim Value="/"/>
+ <PathDelim Value="\"/>
<Version Value="5"/>
<General>
<SessionStorage Value="InProjectDir"/>
<MainUnit Value="0"/>
- <IconPath Value="./"/>
+ <IconPath Value=".\"/>
<TargetFileExt Value=".exe"/>
</General>
<VersionInfo>
@@ -20,7 +20,7 @@
<RunParams>
<local>
<FormatVersion Value="1"/>
- <LaunchingApplication PathPlusParams="/usr/X11R6/bin/xterm -T 'Lazarus Run Output' -e $(LazarusDir)/tools/runwait.sh $(TargetCmdLine)"/>
+ <LaunchingApplication PathPlusParams="\usr\X11R6\bin\xterm -T 'Lazarus Run Output' -e $(LazarusDir)\tools\runwait.sh $(TargetCmdLine)"/>
</local>
</RunParams>
<RequiredPackages Count="2">
@@ -41,6 +41,7 @@
</ProjectOptions>
<CompilerOptions>
<Version Value="5"/>
+ <PathDelim Value="\"/>
<CodeGeneration>
<Generate Value="Faster"/>
</CodeGeneration>
diff --git a/prototypes/newmultihandle/examples/helloworld.lpr b/prototypes/newmultihandle/examples/helloworld.lpr
index 398ea421..ab364d59 100644
--- a/prototypes/newmultihandle/examples/helloworld.lpr
+++ b/prototypes/newmultihandle/examples/helloworld.lpr
@@ -12,6 +12,7 @@ type
TMainForm = class(TFWidget)
private
btnHello: TFButton;
+ txtEdit: TFEdit;
procedure FormPaint(Sender: TObject);
public
constructor Create(AParent: TFCustomWindow); override;
@@ -63,8 +64,8 @@ var
lSize: TSize;
lPoint: TPoint;
begin
-
inherited AfterConstruction;
+
// BorderWidth := 8;
// Text := 'fpGUI Application';
@@ -78,6 +79,16 @@ begin
btnHello.SetPosition(lPoint);
btnHello.Show;
+ { create the edit }
+ txtEdit := TFEdit.Create(self);
+ lSize.cx := 100;
+ lSize.cy := 25;
+ txtEdit.SetClientSize(lSize);
+ lPoint.x := 25;
+ lPoint.y := 100;
+ txtEdit.SetPosition(lPoint);
+ txtEdit.Show;
+
{ set a min and max size }
lSize.cx := 200;
lSize.cy := 300;
diff --git a/prototypes/newmultihandle/fpgui.pas b/prototypes/newmultihandle/fpgui.pas
index f94904dc..9649e21e 100644
--- a/prototypes/newmultihandle/fpgui.pas
+++ b/prototypes/newmultihandle/fpgui.pas
@@ -15,6 +15,7 @@ uses
{ Primary widgets includes }
{$include gui_button.inc}
+{$include gui_edit.inc}
var
{ Default Styles }
@@ -32,6 +33,7 @@ implementation
{ Primary widgets includes }
{$include gui_button.inc}
+{$include gui_edit.inc}
initialization
{ Default Styles }
diff --git a/prototypes/newmultihandle/fpguipackage.lpk b/prototypes/newmultihandle/fpguipackage.lpk
index b7c0eb0b..19788333 100644
--- a/prototypes/newmultihandle/fpguipackage.lpk
+++ b/prototypes/newmultihandle/fpguipackage.lpk
@@ -1,11 +1,13 @@
<?xml version="1.0"?>
<CONFIG>
<Package Version="2">
+ <PathDelim Value="\"/>
<Name Value="fpguipackage"/>
<CompilerOptions>
<Version Value="5"/>
+ <PathDelim Value="\"/>
<SearchPaths>
- <UnitOutputDirectory Value="lib/$(TargetCPU)-$(TargetOS)"/>
+ <UnitOutputDirectory Value="lib\$(TargetCPU)-$(TargetOS)"/>
</SearchPaths>
<CodeGeneration>
<Generate Value="Faster"/>
@@ -14,7 +16,7 @@
<CompilerPath Value="$(CompPath)"/>
</Other>
</CompilerOptions>
- <Files Count="4">
+ <Files Count="5">
<Item1>
<Filename Value="fpgui.pas"/>
<UnitName Value="fpgui"/>
@@ -31,6 +33,10 @@
<Filename Value="gui_style.inc"/>
<Type Value="Include"/>
</Item4>
+ <Item5>
+ <Filename Value="gui_edit.inc"/>
+ <Type Value="Include"/>
+ </Item5>
</Files>
<Type Value="RunAndDesignTime"/>
<RequiredPkgs Count="2">
@@ -47,6 +53,7 @@
</UsageOptions>
<PublishOptions>
<Version Value="2"/>
+ <DestinationDirectory Value="$(TestDir)\publishedpackage\"/>
<IgnoreBinaries Value="False"/>
</PublishOptions>
</Package>
diff --git a/prototypes/newmultihandle/gui_button.inc b/prototypes/newmultihandle/gui_button.inc
index b70c5795..2c619b9b 100644
--- a/prototypes/newmultihandle/gui_button.inc
+++ b/prototypes/newmultihandle/gui_button.inc
@@ -9,10 +9,9 @@ type
TFButton = class(TFWidget)
private
FIsPressed: Boolean;
- public
- Text: string;
- constructor Create(AParent: TFCustomWindow); override;
- constructor Create(ACaption: string; AParent: TFCustomWindow);
+ FText: string;
+ procedure SetText(const AValue: string);
+ protected
procedure EvFocusIn; override;
procedure EvFocusOut; override;
procedure EvKeyPressed(AKey: Word); override;
@@ -22,6 +21,12 @@ type
procedure EvMousePressed(AButton: TMouseButton; const AMousePos: TPoint); override;
procedure EvMouseReleased(AButton: TMouseButton; const AMousePos: TPoint); override;
procedure EvPaint; override;
+ public
+ { Constructors and Destructors }
+ constructor Create(AParent: TFCustomWindow); override;
+ constructor Create(ACaption: string; AParent: TFCustomWindow);
+ { Properties }
+ property Text: string read FText write SetText;
end;
@@ -31,6 +36,8 @@ constructor TFButton.Create(AParent: TFCustomWindow);
begin
inherited Create(AParent);
+ FDrawBackground := False;
+
SetClientSize(Size(100, 50));
end;
@@ -38,11 +45,16 @@ constructor TFButton.Create(ACaption: string; AParent: TFCustomWindow);
begin
Create(AParent);
- FDrawBackground := False;
-
Text := ACaption;
end;
+procedure TFButton.SetText(const AValue: string);
+begin
+ FText := AValue;
+
+ Invalidate;
+end;
+
procedure TFButton.EvFocusIn;
begin
inherited EvFocusIn;
@@ -103,16 +115,8 @@ end;
procedure TFButton.EvPaint;
var
- rt: TRect;
Flags: TFButtonFlags;
begin
- WriteLn('Paint event');
-
- rt.Left := 0;
- rt.Top := 0;
- rt.Right := Width;
- rt.Bottom := Height;
-
{ Prepare the flags }
Flags := [];
@@ -120,15 +124,12 @@ begin
if FIsPressed then
Include(Flags, fbfIsPressed);
-{ if FFocused and (not FEmbedded) then
- Include(lBtnFlags, btnHasFocus);
-
- if FEmbedded then
- Include(lBtnFlags, btnIsEmbedded); }
+{ if FFocused then
+ Include(lBtnFlags, btnHasFocus); }
{ Draw the button }
- GFDefaultStyle.DrawButtonFace(Canvas, rt, Flags);
+ GFDefaultStyle.DrawButtonFace(Canvas, Bounds(0, 0, Width, Height), Flags);
inherited EvPaint();
end;
diff --git a/prototypes/newmultihandle/gui_edit.inc b/prototypes/newmultihandle/gui_edit.inc
new file mode 100644
index 00000000..ab23f13d
--- /dev/null
+++ b/prototypes/newmultihandle/gui_edit.inc
@@ -0,0 +1,90 @@
+{%mainunit fpgui.pas}
+
+{$ifndef READ_IMPLEMENTATION}
+
+type
+
+ { TFEdit }
+
+ TFEdit = class(TFWidget)
+ private
+ FText: String;
+ procedure SetText(const AValue: String);
+ protected
+ procedure EvFocusIn; override;
+ procedure EvFocusOut; override;
+ procedure EvKeyPressed(AKey: Word); override;
+ procedure EvKeyReleased(AKey: Word); override;
+ procedure EvMousePressed(AButton: TMouseButton; const AMousePos: TPoint); override;
+ procedure EvMouseReleased(AButton: TMouseButton; const AMousePos: TPoint); override;
+ procedure EvPaint; override;
+ public
+ { Constructors and Destructors }
+ constructor Create(AParent: TFCustomWindow); override;
+ { Properties }
+ property Text: String read FText write SetText;
+ end;
+
+
+{$else}
+
+constructor TFEdit.Create(AParent: TFCustomWindow);
+begin
+ inherited Create(AParent);
+
+ FDrawBackground := False;
+
+ SetClientSize(Size(100, 50));
+end;
+
+procedure TFEdit.SetText(const AValue: String);
+begin
+ if FText = AValue then exit;
+
+ FText := AValue;
+
+ Invalidate;
+end;
+
+procedure TFEdit.EvFocusIn;
+begin
+ inherited EvFocusIn;
+end;
+
+procedure TFEdit.EvFocusOut;
+begin
+ inherited EvFocusOut;
+end;
+
+procedure TFEdit.EvKeyPressed(AKey: Word);
+begin
+ inherited EvKeyPressed(AKey);
+end;
+
+procedure TFEdit.EvKeyReleased(AKey: Word);
+begin
+ inherited EvKeyReleased(AKey);
+end;
+
+procedure TFEdit.EvMousePressed(AButton: TMouseButton; const AMousePos: TPoint);
+begin
+ inherited EvMousePressed(AButton, AMousePos);
+end;
+
+procedure TFEdit.EvMouseReleased(AButton: TMouseButton;
+ const AMousePos: TPoint);
+begin
+ inherited EvMouseReleased(AButton, AMousePos);
+end;
+
+procedure TFEdit.EvPaint;
+begin
+ { Draw the edit }
+
+ GFDefaultStyle.DrawEdit(Canvas, Bounds(0, 0, Width, Height));
+
+ inherited EvPaint();
+end;
+
+{$endif}
+
diff --git a/prototypes/newmultihandle/gui_style.inc b/prototypes/newmultihandle/gui_style.inc
index 84d3224e..f6aa7de1 100644
--- a/prototypes/newmultihandle/gui_style.inc
+++ b/prototypes/newmultihandle/gui_style.inc
@@ -15,6 +15,7 @@ type
procedure DrawButtonFace(ACanvas: TFCustomCanvas; ARect: TRect; AFlags: TFButtonFlags); virtual;
procedure DrawControlFrame(ACanvas: TFCustomCanvas; ARect: TRect); virtual;
procedure DrawDirectionArrow(ACanvas: TFCustomCanvas; ARect: TRect; direction: Integer); virtual;
+ procedure DrawEdit(ACanvas: TFCustomCanvas; ARect: TRect); virtual;
end;
const
@@ -22,6 +23,7 @@ const
colShadow2: TGfxColor = (Red: $40; Green: $40; Blue: $40; Alpha: $00);
colHilite1: TGfxColor = (Red: $E0; Green: $E0; Blue: $E0; Alpha: $00);
colHilite2: TGfxColor = (Red: $FF; Green: $FF; Blue: $FF; Alpha: $00);
+ colGrayBlue: TGfxColor = (Red: $7F; Green: $9D; Blue: $B9; Alpha: $00);
{$else}
@@ -86,5 +88,16 @@ procedure TFStyle.DrawDirectionArrow(ACanvas: TFCustomCanvas; ARect: TRect; dire
begin
end;
+procedure TFStyle.DrawEdit(ACanvas: TFCustomCanvas; ARect: TRect);
+begin
+ { Inner area }
+ ACanvas.SetColor(colWhite);
+ ACanvas.FillRect(ARect);
+
+ { Outer border }
+ ACanvas.SetColor(colGrayBlue);
+ ACanvas.DrawRect(ARect);
+end;
+
{$endif}