diff options
-rw-r--r-- | gfx/gdi/gfx_gdi.pas | 12 | ||||
-rw-r--r-- | gfx/gfxbase.pas | 2 | ||||
-rw-r--r-- | prototypes/newmultihandle/gui_button.inc | 81 |
3 files changed, 73 insertions, 22 deletions
diff --git a/gfx/gdi/gfx_gdi.pas b/gfx/gdi/gfx_gdi.pas index a6107d24..64622ab8 100644 --- a/gfx/gdi/gfx_gdi.pas +++ b/gfx/gdi/gfx_gdi.pas @@ -200,7 +200,7 @@ type procedure SetClientSize(const ASize: TSize); override; procedure SetMinMaxClientSize(const AMinSize, AMaxSize: TSize); override; procedure Show; override; - procedure Invalidate(const ARect: TRect); override; + procedure Invalidate; override; procedure PaintInvalidRegion; override; procedure CaptureMouse; override; procedure ReleaseMouse; override; @@ -1512,15 +1512,9 @@ begin end; -procedure TGDIWindow.Invalidate(const ARect: TRect); -var - Rect: Windows.Rect; +procedure TGDIWindow.Invalidate; begin - Rect.Left := ARect.Left; - Rect.Top := ARect.Top; - Rect.Right := ARect.Right; - Rect.Bottom := ARect.Bottom; - Windows.InvalidateRect(Handle, Rect, False); + Windows.InvalidateRect(Handle, nil, True); end; diff --git a/gfx/gfxbase.pas b/gfx/gfxbase.pas index 80362d35..4d9c2e90 100644 --- a/gfx/gfxbase.pas +++ b/gfx/gfxbase.pas @@ -523,7 +523,7 @@ type procedure SetClientSize(const ASize: TSize); virtual; procedure SetMinMaxClientSize(const AMinSize, AMaxSize: TSize); virtual; procedure Show; virtual; abstract; - procedure Invalidate(const ARect: TRect); virtual; abstract; + procedure Invalidate; virtual; abstract; procedure PaintInvalidRegion; virtual; abstract; procedure CaptureMouse; virtual; abstract; procedure ReleaseMouse; virtual; abstract; diff --git a/prototypes/newmultihandle/gui_button.inc b/prototypes/newmultihandle/gui_button.inc index 997faee9..e79b8748 100644 --- a/prototypes/newmultihandle/gui_button.inc +++ b/prototypes/newmultihandle/gui_button.inc @@ -7,12 +7,21 @@ type { TFButton } TFButton = class(TFWidget) + private + FIsPressed: Boolean; public Text: string; constructor Create(AParent: TFCustomWindow); override; constructor Create(ACaption: string; AParent: TFCustomWindow); - procedure EvPaint; override; + procedure EvFocusIn; override; + procedure EvFocusOut; override; + procedure EvKeyPressed(AKey: Word); override; + procedure EvKeyReleased(AKey: Word); override; + procedure EvMouseEnter(const AMousePos: TPoint); override; + procedure EvMouseLeave; override; + procedure EvMousePressed(AButton: TMouseButton; const AMousePos: TPoint); override; procedure EvMouseReleased(AButton: TMouseButton; const AMousePos: TPoint); override; + procedure EvPaint; override; end; @@ -34,11 +43,67 @@ begin Text := ACaption; end; +procedure TFButton.EvFocusIn; +begin + inherited EvFocusIn; +end; + +procedure TFButton.EvFocusOut; +begin + inherited EvFocusOut; +end; + +procedure TFButton.EvKeyPressed(AKey: Word); +begin + inherited EvKeyPressed(AKey); +end; + +procedure TFButton.EvKeyReleased(AKey: Word); +begin + inherited EvKeyReleased(AKey); +end; + +procedure TFButton.EvMouseEnter(const AMousePos: TPoint); +begin + inherited EvMouseEnter(AMousePos); +end; + +procedure TFButton.EvMouseLeave; +begin + FIsPressed := False; + + Invalidate; + + inherited EvMouseLeave; +end; + +procedure TFButton.EvMousePressed(AButton: TMouseButton; const AMousePos: TPoint + ); +begin + FIsPressed := True; + + Invalidate; + + inherited EvMousePressed(AButton, AMousePos); +end; + +procedure TFButton.EvMouseReleased(AButton: TMouseButton; + const AMousePos: TPoint); +begin + FIsPressed := False; + + Invalidate; + + inherited EvMouseReleased(AButton, AMousePos); +end; + procedure TFButton.EvPaint; var rt: TRect; Flags: TFButtonFlags; begin + WriteLn('Paint event'); + rt.Left := 0; rt.Top := 0; rt.Right := Width; @@ -48,10 +113,10 @@ begin Flags := []; - { if FDown then - Include(lBtnFlags, btnIsPressed); + if FIsPressed then + Include(Flags, fbfIsPressed); - if FFocused and (not FEmbedded) then +{ if FFocused and (not FEmbedded) then Include(lBtnFlags, btnHasFocus); if FEmbedded then @@ -64,13 +129,5 @@ begin inherited EvPaint(); end; -procedure TFButton.EvMouseReleased(AButton: TMouseButton; - const AMousePos: TPoint); -begin - WriteLn('Mouse released on child window'); - - inherited EvMouseReleased(AButton, AMousePos); -end; - {$endif} |