summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorFelipe Menteiro de Carvalho <sekelsenmat@users.sourceforge.net>2006-11-23 18:59:10 +0000
committerFelipe Menteiro de Carvalho <sekelsenmat@users.sourceforge.net>2006-11-23 18:59:10 +0000
commitdada2e72d6c0ca106db0a0dafa179e54a408ec73 (patch)
treef344d4c368f52727a5534645ffca54077f81c1cb
parent7a9b7aa63ec89922242ce4fca8a558a0abbe8b02 (diff)
downloadfpGUI-dada2e72d6c0ca106db0a0dafa179e54a408ec73.tar.xz
Implemented ProcessEvent and sending events to parent on Windows platform.
-rw-r--r--examples/gfx/eventtest/eventtest.lpi5
-rw-r--r--examples/gfx/subwindow/subwindow.lpi5
-rw-r--r--gfx/gdi/gfx_gdi.pas636
-rw-r--r--gfx/gfxbase.pas59
-rw-r--r--prototypes/multihandle/gui2Base.pas10
-rw-r--r--prototypes/multihandle/test.lpi5
6 files changed, 402 insertions, 318 deletions
diff --git a/examples/gfx/eventtest/eventtest.lpi b/examples/gfx/eventtest/eventtest.lpi
index 20cb4496..3562e167 100644
--- a/examples/gfx/eventtest/eventtest.lpi
+++ b/examples/gfx/eventtest/eventtest.lpi
@@ -1,7 +1,7 @@
<?xml version="1.0"?>
<CONFIG>
<ProjectOptions>
- <PathDelim Value="/"/>
+ <PathDelim Value="\"/>
<Version Value="5"/>
<General>
<Flags>
@@ -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="1">
@@ -39,6 +39,7 @@
</ProjectOptions>
<CompilerOptions>
<Version Value="5"/>
+ <PathDelim Value="\"/>
<CodeGeneration>
<Generate Value="Faster"/>
</CodeGeneration>
diff --git a/examples/gfx/subwindow/subwindow.lpi b/examples/gfx/subwindow/subwindow.lpi
index d2f61887..0a8d321c 100644
--- a/examples/gfx/subwindow/subwindow.lpi
+++ b/examples/gfx/subwindow/subwindow.lpi
@@ -1,7 +1,7 @@
<?xml version="1.0"?>
<CONFIG>
<ProjectOptions>
- <PathDelim Value="/"/>
+ <PathDelim Value="\"/>
<Version Value="5"/>
<General>
<SessionStorage Value="InProjectDir"/>
@@ -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="1">
@@ -38,6 +38,7 @@
</ProjectOptions>
<CompilerOptions>
<Version Value="5"/>
+ <PathDelim Value="\"/>
<CodeGeneration>
<Generate Value="Faster"/>
</CodeGeneration>
diff --git a/gfx/gdi/gfx_gdi.pas b/gfx/gdi/gfx_gdi.pas
index 6d3f858c..a98b9388 100644
--- a/gfx/gdi/gfx_gdi.pas
+++ b/gfx/gdi/gfx_gdi.pas
@@ -170,31 +170,6 @@ type
{ TGDIWindow }
TGDIWindow = class(TFCustomWindow)
- private
- { Messages }
- procedure WMCreate(var Msg: TMessage); message WM_CREATE;
- procedure WMDestroy(var Msg: TMessage); message WM_DESTROY;
- procedure WMGetMinMaxInfo(var Msg: TMessage); message WM_GETMINMAXINFO;
- procedure WMActivate(var Msg: TMessage); message WM_ACTIVATE;
- procedure WMPaint(var Msg: TMessage); message WM_PAINT;
- procedure WMShowWindow(var Msg: TMessage); message WM_SHOWWINDOW;
- procedure WMMove(var Msg: TMessage); message WM_MOVE;
- procedure WMSize(var Msg: TMessage); message WM_SIZE;
- { Input messages }
- procedure WMLButtonDown(var Msg: TMessage); message WM_LBUTTONDOWN;
- procedure WMLButtonUp(var Msg: TMessage); message WM_LBUTTONUP;
- procedure WMRButtonDown(var Msg: TMessage); message WM_RBUTTONDOWN;
- procedure WMRButtonUp(var Msg: TMessage); message WM_RBUTTONUP;
- procedure WMMButtonDown(var Msg: TMessage); message WM_MBUTTONDOWN;
- procedure WMMButtonUp(var Msg: TMessage); message WM_MBUTTONUP;
- procedure WMMouseMove(var Msg: TMessage); message WM_MOUSEMOVE;
- procedure WMMouseWheel(var Msg: TMessage); message WM_MOUSEWHEEL;
- procedure WMKeyDown(var Msg: TMessage); message WM_KEYDOWN;
- procedure WMKeyUp(var Msg: TMessage); message WM_KEYUP;
- procedure WMChar(var Msg: TMessage); message WM_CHAR;
- procedure WMSysKeyDown(var Msg: TMessage); message WM_SYSKEYDOWN;
- procedure WMSysKeyUp(var Msg: TMessage); message WM_SYSKEYUP;
- procedure WMSysChar(var Msg: TMessage); message WM_SYSCHAR;
protected
WindowClass: TWndClass;
WindowClassW: TWndClassW;
@@ -204,11 +179,10 @@ type
procedure SetTitle(const ATitle: String); override;
procedure DoSetCursor; override;
procedure UpdateWindowButtons;
- function DoMouseEnterLeaveCheck(const Msg: TMessage): Boolean;
+ function DoMouseEnterLeaveCheck(uMsg, wParam, lParam: Cardinal): Boolean;
public
- constructor Create(AParent: TFCustomWindow; AWindowOptions: TGfxWindowOptions); override;
+ constructor Create(AParent: TFCustomWindow; AWindowOptions: TFWindowOptions); override;
destructor Destroy; override;
- procedure DefaultHandler(var Message); override;
procedure SetPosition(const APosition: TPoint); override;
procedure SetSize(const ASize: TSize); override;
procedure SetMinMaxSize(const AMinSize, AMaxSize: TSize); override;
@@ -219,6 +193,7 @@ type
procedure PaintInvalidRegion; override;
procedure CaptureMouse; override;
procedure ReleaseMouse; override;
+ procedure ProcessEvent(AEvent: TFEvent); override;
end;
@@ -1036,8 +1011,13 @@ function fpGFXWindowProc(hwnd: HWND; uMsg: UINT; wParam: WPARAM;
lParam: LPARAM): LRESULT; stdcall;
var
Window: TGDIWindow;
- Msg: TMessage;
+ Event: TFEvent;
+ PaintStruct: TPaintStruct;
+ r: TRect;
+ OldCanvas: TFCustomCanvas;
begin
+ Event := TFEvent.Create;
+
if uMsg = WM_CREATE then
begin
Window := TGDIWindow(PCreateStruct(lParam)^.lpCreateParams);
@@ -1048,20 +1028,201 @@ begin
if Assigned(Window) then
begin
- Msg.msg := uMsg;
- Msg.wParam := wParam;
- Msg.lParam := lParam;
- Msg.Result := 0;
- Window.Dispatch(Msg);
- Result := Msg.Result;
+ Event.msg := uMsg;
+ Event.wParam := wParam;
+ Event.lParam := lParam;
+ Event.Result := 0;
+
+ case uMsg of
+ { Messages }
+ WM_CREATE:
+ begin
+ Event.EventType := etCreate;
+ Window.ProcessEvent(Event);
+ end;
+ WM_DESTROY:
+ begin
+ if Window.Handle <> 0 then Window.Free;
+ end;
+ WM_GetMinMaxInfo:
+ begin
+ if Window.FMinSize.cx > 0 then
+ PMinMaxInfo(lParam)^.ptMinTrackSize.x := Window.FMinSize.cx;
+ if Window.FMinSize.cy > 0 then
+ PMinMaxInfo(lParam)^.ptMinTrackSize.y := Window.FMinSize.cy;
+ if Window.FMaxSize.cx > 0 then
+ PMinMaxInfo(lParam)^.ptMaxTrackSize.x := Window.FMaxSize.cx;
+ if Window.FMaxSize.cy > 0 then
+ PMinMaxInfo(lParam)^.ptMaxTrackSize.y := Window.FMaxSize.cy;
+ end;
+ WM_Activate:
+ begin
+ if wParam = WA_INACTIVE then
+ begin
+ Event.EventType := etFocusOut;
+ Window.ProcessEvent(Event);
+ end
+ else
+ begin
+ Event.EventType := etFocusIn;
+ Window.ProcessEvent(Event);
+ end;
+ end;
+ WM_Paint:
+ begin
+ Event.EventType := etPaint;
+ Window.ProcessEvent(Event);
+ end;
+ WM_ShowWindow:
+ begin
+ if wParam <> 0 then
+ begin
+ Event.EventType := etFocusIn;
+ Window.ProcessEvent(Event);
+
+ Event.EventType := etShow;
+ Window.ProcessEvent(Event);
+ end
+ else
+ begin
+ Event.EventType := etHide;
+ Window.ProcessEvent(Event);
+ end;
+ end;
+ WM_Move:
+ begin
+ if (LoWord(lParam) <> Window.Left) or (HiWord(lParam) <> Window.Top) then
+ begin
+ Window.FLeft := LoWord(lParam);
+ Window.FTop := HiWord(lParam);
+
+ Event.EventType := etMove;
+ Window.ProcessEvent(Event);
+ end;
+ end;
+ WM_Size:
+ begin
+ if (LoWord(lParam) <> Window.ClientWidth) or (HiWord(lParam) <> Window.ClientHeight) then
+ begin
+ Windows.GetWindowRect(Window.Handle, r);
+ Window.FWidth := r.Right - r.Left;
+ Window.FHeight := r.Bottom - r.Top;
+ Windows.GetClientRect(Window.Handle, r);
+ Window.FClientWidth := LoWord(lParam);
+ Window.FClientHeight := HiWord(lParam);
+ TGDICanvas(Window.Canvas).Resized(Window.FWidth, Window.FHeight);
+
+ Event.EventType := etResize;
+ Window.ProcessEvent(Event);
+ end;
+ end;
+ { Input messages }
+ WM_LButtonDown:
+ begin
+ if Window.FMouseInWindow and not Window.FHasFocus then
+ Windows.SetActiveWindow(Window.Handle);
+
+ if Window.DoMouseEnterLeaveCheck(uMsg, wParam, lParam) then
+ begin
+ Event.EventType := etMousePressed;
+ Event.MouseButton := mbLeft;
+ Window.ProcessEvent(Event);
+ end;
+ end;
+ WM_LButtonUp:
+ begin
+ if Window.DoMouseEnterLeaveCheck(uMsg, wParam, lParam) then
+ begin
+ Event.EventType := etMouseReleased;
+ Event.MouseButton := mbLeft;
+ Window.ProcessEvent(Event);
+ end;
+ end;
+ WM_RButtonDown:
+ begin
+ if Window.FMouseInWindow and not Window.FHasFocus then
+ Windows.SetActiveWindow(Window.Handle);
+
+ if Window.DoMouseEnterLeaveCheck(uMsg, wParam, lParam) then
+ begin
+ Event.EventType := etMousePressed;
+ Event.MouseButton := mbRight;
+ Window.ProcessEvent(Event);
+ end;
+ end;
+ WM_RButtonUp:
+ begin
+ if Window.DoMouseEnterLeaveCheck(uMsg, wParam, lParam) then
+ begin
+ Event.EventType := etMouseReleased;
+ Event.MouseButton := mbRight;
+ Window.ProcessEvent(Event);
+ end;
+ end;
+ WM_MButtonDown:
+ begin
+ if Window.FMouseInWindow and not Window.FHasFocus then
+ Windows.SetActiveWindow(Window.Handle);
+
+ if Window.DoMouseEnterLeaveCheck(uMsg, wParam, lParam) then
+ begin
+ Event.EventType := etMousePressed;
+ Event.MouseButton := mbMiddle;
+ Window.ProcessEvent(Event);
+ end;
+ end;
+ WM_MButtonUp:
+ begin
+ if Window.DoMouseEnterLeaveCheck(uMsg, wParam, lParam) then
+ begin
+ Event.EventType := etMouseReleased;
+ Event.MouseButton := mbMiddle;
+ Window.ProcessEvent(Event);
+ end;
+ end;
+ WM_MouseMove:
+ begin
+ if Window.DoMouseEnterLeaveCheck(uMsg, wParam, lParam) then
+ begin
+ Event.EventType := etMouseMove;
+ Window.ProcessEvent(Event);
+ end;
+ end;
+ WM_MouseWheel:
+ begin
+ if Window.DoMouseEnterLeaveCheck(uMsg, wParam, lParam) then
+ begin
+ Event.EventType := etMouseWheel;
+ Window.ProcessEvent(Event);
+ end;
+ end;
+ WM_KeyDown, WM_SysKeyDown:
+ begin
+ Event.EventType := etKeyPressed;
+ Window.ProcessEvent(Event);
+ end;
+ WM_KeyUp, WM_SysKeyUp:
+ begin
+ end;
+ WM_Char, WM_SysChar:
+ begin
+ end;
+ else
+ if UnicodeEnabledOS then Result := Windows.DefWindowProcW(hwnd, uMsg, wParam, lParam)
+ else Result := Windows.DefWindowProc(hwnd, uMsg, wParam, lParam);
+ end;
+
+ if Result = 0 then Result := Event.Result;
end
else
if UnicodeEnabledOS then Result := Windows.DefWindowProcW(hwnd, uMsg, wParam, lParam)
else Result := Windows.DefWindowProc(hwnd, uMsg, wParam, lParam);
+
+ Event.Free;
end;
-constructor TGDIWindow.Create(AParent: TFCustomWindow; AWindowOptions: TGfxWindowOptions);
+constructor TGDIWindow.Create(AParent: TFCustomWindow; AWindowOptions: TFWindowOptions);
var
ParentHandle: HWND;
begin
@@ -1177,17 +1338,6 @@ begin
end;
-procedure TGDIWindow.DefaultHandler(var Message);
-begin
- if UnicodeEnabledOS then
- TMessage(Message).Result := Windows.DefWindowProcW(Handle,
- TMessage(Message).Msg, TMessage(Message).wParam, TMessage(Message).lParam)
- else
- TMessage(Message).Result := Windows.DefWindowProc(Handle,
- TMessage(Message).Msg, TMessage(Message).wParam, TMessage(Message).lParam)
-end;
-
-
procedure TGDIWindow.SetPosition(const APosition: TPoint);
begin
Windows.SetWindowPos(Handle, 0, APosition.x, APosition.y, 0, 0,
@@ -1315,6 +1465,133 @@ begin
end;
end;
+procedure TGDIWindow.ProcessEvent(AEvent: TFEvent);
+var
+ pt: Windows.POINT;
+ PaintStruct: TPaintStruct;
+ r: Windows.RECT;
+ OldCanvas: TFCustomCanvas;
+begin
+ case AEvent.EventType of
+ etCreate:
+ begin
+ if Assigned(OnCreate) then OnCreate(Self)
+ else if Assigned(Parent) then Parent.ProcessEvent(AEvent);
+ end;
+ etCanClose:
+ begin
+ end;
+ etClose:
+ begin
+ end;
+ etFocusIn:
+ begin
+ FHasFocus := True;
+ if Assigned(OnFocusIn) then OnFocusIn(Self);
+ end;
+ etFocusOut:
+ begin
+ FHasFocus := False;
+ if Assigned(OnFocusOut) then OnFocusOut(Self);
+ end;
+ etHide:
+ begin
+ if Assigned(OnHide) then OnHide(Self);
+ end;
+ etKeyPressed:
+ begin
+ if Assigned(OnKeyPressed) then OnKeyPressed(Self, VirtKeyToKeycode(AEvent.wParam), GetKeyboardShiftState)
+ else if Assigned(Parent) then Parent.ProcessEvent(AEvent);
+
+ if (AEvent.wParam = $2e {VK_DELETE}) then
+ begin
+ if Assigned(OnKeyChar) then OnKeyChar(Self, #127)
+ else if Assigned(Parent) then Parent.ProcessEvent(AEvent);
+ end;
+ end;
+ etKeyReleased:
+ begin
+ if Assigned(OnKeyReleased) then OnKeyReleased(Self, VirtKeyToKeycode(AEvent.wParam), GetKeyboardShiftState)
+ else if Assigned(Parent) then Parent.ProcessEvent(AEvent);
+ end;
+ etKeyChar:
+ begin
+ if Assigned(OnKeyChar) then OnKeyChar(Self, Chr(AEvent.wParam))
+ else if Assigned(Parent) then Parent.ProcessEvent(AEvent);
+ end;
+ etMouseEnter:
+ begin
+ if Assigned(OnMouseEnter) then
+ OnMouseEnter(Self, GetKeyboardShiftState, Point(LoWord(AEvent.lParam), HiWord(AEvent.lParam)))
+ else if Assigned(Parent) then Parent.ProcessEvent(AEvent);
+ end;
+ etMouseLeave:
+ begin
+ if Assigned(OnMouseLeave) then OnMouseLeave(Self)
+ else if Assigned(Parent) then Parent.ProcessEvent(AEvent);
+ end;
+ etMousePressed:
+ begin
+ if Assigned(OnMousePressed) then
+ OnMousePressed(Self, AEvent.MouseButton, GetKeyboardShiftState, Point(LoWord(AEvent.lparam), HiWord(AEvent.lParam)))
+ else if Assigned(Parent) then Parent.ProcessEvent(AEvent);
+ end;
+ etMouseReleased:
+ begin
+ if Assigned(OnMouseReleased) then
+ OnMouseReleased(Self, AEvent.MouseButton, GetKeyboardShiftState, Point(LoWord(AEvent.lparam), HiWord(AEvent.lParam)))
+ else if Assigned(Parent) then Parent.ProcessEvent(AEvent);
+ end;
+ etMouseMove:
+ begin
+ if Assigned(OnMouseMove) then
+ OnMouseMove(Self, GetKeyboardShiftState, Point(LoWord(AEvent.lparam), HiWord(AEvent.lParam)))
+ else if Assigned(Parent) then Parent.ProcessEvent(AEvent);
+ end;
+ etMouseWheel:
+ begin
+ if Assigned(OnMouseWheel) then
+ begin
+ pt.x := LoWord(AEvent.lparam);
+ pt.y := HiWord(AEvent.lparam);
+ Windows.ScreenToClient(Handle, pt);
+ OnMouseWheel(Self, GetKeyboardShiftState, SmallInt(HiWord(AEvent.wParam)) / -120.0,
+ Point(pt.x, pt.y));
+ end
+ else if Assigned(Parent) then Parent.ProcessEvent(AEvent);
+ end;
+ etPaint:
+ begin
+ Windows.BeginPaint(Handle, @PaintStruct);
+ if Assigned(OnPaint) then
+ begin
+ r.Left := PaintStruct.rcPaint.Left;
+ r.Top := PaintStruct.rcPaint.Top;
+ r.Right := PaintStruct.rcPaint.Right;
+ r.Bottom := PaintStruct.rcPaint.Bottom;
+
+ OldCanvas := Canvas;
+ FCanvas := TGDICanvas.Create(PaintStruct.hdc);
+ OnPaint(Self, r);
+ Canvas.Free;
+ FCanvas := OldCanvas;
+ end;
+ Windows.EndPaint(Handle, @PaintStruct);
+ end;
+ etMove:
+ begin
+ if Assigned(OnMove) then OnMove(Self);
+ end;
+ etResize:
+ begin
+ if Assigned(OnResize) then OnResize(Self);
+ end;
+ etShow:
+ begin
+ if Assigned(OnShow) then OnShow(Self);
+ end;
+ end;
+end;
function TGDIWindow.GetTitle: String;
var
@@ -1350,7 +1627,7 @@ end;
procedure TGDIWindow.DoSetCursor;
const
- CursorTable: array[TGfxCursor] of Integer = (
+ CursorTable: array[TFCursor] of Integer = (
32512, // crDefault
0, // crNone
32512, // crArrow
@@ -1398,17 +1675,17 @@ begin
end;
end;
-function TGDIWindow.DoMouseEnterLeaveCheck(const Msg: TMessage): Boolean;
+function TGDIWindow.DoMouseEnterLeaveCheck(uMsg, wParam, lParam: Cardinal): Boolean;
function CursorInDifferentWindow: Boolean;
var
pt: Windows.POINT;
begin
- pt.x := Msg.lParamLo;
- pt.y := Msg.lParamHi;
+ pt.x := LoWord(lParam);
+ pt.y := HiWord(lParam);
// only WM_MOUSEWHEEL uses screen coordinates!!!
- if Msg.Msg <> WM_MOUSEWHEEL then
+ if uMsg <> WM_MOUSEWHEEL then
Windows.ClientToScreen(Handle, pt);
Result := WindowFromPoint(pt) <> Handle;
@@ -1416,21 +1693,27 @@ function TGDIWindow.DoMouseEnterLeaveCheck(const Msg: TMessage): Boolean;
var
pt: Windows.POINT;
+ Event: TFEvent;
begin
if not FMouseInWindow then
begin
FMouseInWindow := True;
DoSetCursor;
Windows.SetCapture(Handle);
- if Assigned(OnMouseEnter) then
- OnMouseEnter(Self, GetKeyboardShiftState,
- Point(Msg.lParamLo, Msg.lParamHi));
- Result := Msg.Msg <> WM_MOUSEMOVE;
+ Event := TFEvent.Create;
+ try
+ Event.lParam := lParam;
+ Event.EventType := etMouseEnter;
+ ProcessEvent(Event);
+ finally
+ Event.Free;
+ end;
+ Result := uMsg <> WM_MOUSEMOVE;
end else
begin
- pt.x := Msg.lParamLo;
- pt.y := Msg.lParamHi;
- if Msg.Msg = WM_MOUSEWHEEL then
+ pt.x := LoWord(lParam);
+ pt.y := HiWord(lParam);
+ if uMsg = WM_MOUSEWHEEL then
Windows.ScreenToClient(Handle, pt);
if (pt.x < 0) or (pt.y < 0) or (pt.x >= ClientWidth) or
(pt.y >= ClientHeight) or CursorInDifferentWindow then
@@ -1439,240 +1722,19 @@ begin
if (not FHasMouseCapture) and (not FMouseInWindow) then
begin
Windows.ReleaseCapture;
- if Assigned(OnMouseLeave) then
- OnMouseLeave(Self);
+ Event := TFEvent.Create;
+ try
+ Event.EventType := etMouseLeave;
+ ProcessEvent(Event);
+ finally
+ Event.Free;
+ end;
Result := False;
end else
Result := True;
end;
end;
-
-// private methods
-
-procedure TGDIWindow.WMCreate(var Msg: TMessage);
-begin
- if Assigned(OnCreate) then
- OnCreate(Self);
-end;
-
-
-procedure TGDIWindow.WMDestroy(var Msg: TMessage);
-begin
- if Handle <> 0 then
- Self.Free;
-end;
-
-
-procedure TGDIWindow.WMGetMinMaxInfo(var Msg: TMessage);
-begin
- with PMinMaxInfo(Msg.lParam)^ do
- begin
- if FMinSize.cx > 0 then
- ptMinTrackSize.x := FMinSize.cx;
- if FMinSize.cy > 0 then
- ptMinTrackSize.y := FMinSize.cy;
- if FMaxSize.cx > 0 then
- ptMaxTrackSize.x := FMaxSize.cx;
- if FMaxSize.cy > 0 then
- ptMaxTrackSize.y := FMaxSize.cy;
- end;
-end;
-
-
-procedure TGDIWindow.WMActivate(var Msg: TMessage);
-begin
- if Msg.wParam = WA_INACTIVE then
- begin
- FHasFocus := False;
- if Assigned(OnFocusOut) then
- OnFocusOut(Self);
- end else
- begin
- FHasFocus := True;
- if Assigned(OnFocusIn) then
- OnFocusIn(Self);
- end;
-end;
-
-
-procedure TGDIWindow.WMPaint(var Msg: TMessage);
-var
- PaintStruct: TPaintStruct;
- r: TRect;
- OldCanvas: TFCustomCanvas;
-begin
- Windows.BeginPaint(Handle, @PaintStruct);
- if Assigned(OnPaint) then
- begin
- r.Left := PaintStruct.rcPaint.Left;
- r.Top := PaintStruct.rcPaint.Top;
- r.Right := PaintStruct.rcPaint.Right;
- r.Bottom := PaintStruct.rcPaint.Bottom;
-
- OldCanvas := Canvas;
- FCanvas := TGDICanvas.Create(PaintStruct.hdc);
- OnPaint(Self, r);
- Canvas.Free;
- FCanvas := OldCanvas;
- end;
- Windows.EndPaint(Handle, @PaintStruct);
-end;
-
-
-procedure TGDIWindow.WMShowWindow(var Msg: TMessage);
-begin
- if Msg.wParam <> 0 then
- begin
- if Assigned(OnFocusIn) then
- OnFocusIn(Self);
- if Assigned(OnShow) then
- OnShow(Self);
- end else
- if Assigned(OnHide) then
- OnHide(Self);
-end;
-
-
-procedure TGDIWindow.WMMove(var Msg: TMessage);
-begin
- if (Msg.lParamLo <> Left) or (Msg.lParamHi <> Top) then
- begin
- FLeft := Msg.lParamLo;
- FTop := Msg.lParamHi;
- if Assigned(OnMove) then
- OnMove(Self);
- end;
-end;
-
-
-procedure TGDIWindow.WMSize(var Msg: TMessage);
-var
- r: Windows.Rect;
-begin
- if (Msg.lParamLo <> ClientWidth) or (Msg.lParamHi <> ClientHeight) then
- begin
- Windows.GetWindowRect(Handle, r);
- FWidth := r.Right - r.Left;
- FHeight := r.Bottom - r.Top;
- Windows.GetClientRect(Handle, r);
- FClientWidth := Msg.lParamLo;
- FClientHeight := Msg.lParamHi;
- TGDICanvas(Canvas).Resized(FWidth, FHeight);
- if Assigned(OnResize) then
- OnResize(Self);
- end;
-end;
-
-
-procedure TGDIWindow.WMLButtonDown(var Msg: TMessage);
-begin
- if FMouseInWindow and not FHasFocus then
- Windows.SetActiveWindow(Handle);
- if DoMouseEnterLeaveCheck(Msg) and Assigned(OnMousePressed) then
- OnMousePressed(Self, mbLeft, GetKeyboardShiftState,
- Point(Msg.lParamLo, Msg.lParamHi));
-end;
-
-
-procedure TGDIWindow.WMLButtonUp(var Msg: TMessage);
-begin
- if DoMouseEnterLeaveCheck(Msg) and Assigned(OnMouseReleased) then
- OnMouseReleased(Self, mbLeft, GetKeyboardShiftState,
- Point(Msg.lParamLo, Msg.lParamHi));
-end;
-
-
-procedure TGDIWindow.WMRButtonDown(var Msg: TMessage);
-begin
- if FMouseInWindow and not FHasFocus then
- Windows.SetActiveWindow(Handle);
- if DoMouseEnterLeaveCheck(Msg) and Assigned(OnMousePressed) then
- OnMousePressed(Self, mbRight, GetKeyboardShiftState,
- Point(Msg.lParamLo, Msg.lParamHi));
-end;
-
-
-procedure TGDIWindow.WMRButtonUp(var Msg: TMessage);
-begin
- if DoMouseEnterLeaveCheck(Msg) and Assigned(OnMouseReleased) then
- OnMouseReleased(Self, mbRight, GetKeyboardShiftState,
- Point(Msg.lParamLo, Msg.lParamHi));
-end;
-
-
-procedure TGDIWindow.WMMButtonDown(var Msg: TMessage);
-begin
- if FMouseInWindow and not FHasFocus then
- Windows.SetActiveWindow(Handle);
- if DoMouseEnterLeaveCheck(Msg) and Assigned(OnMousePressed) then
- OnMousePressed(Self, mbMiddle, GetKeyboardShiftState,
- Point(Msg.lParamLo, Msg.lParamHi));
-end;
-
-procedure TGDIWindow.WMMButtonUp(var Msg: TMessage);
-begin
- if DoMouseEnterLeaveCheck(Msg) and Assigned(OnMouseReleased) then
- OnMouseReleased(Self, mbMiddle, GetKeyboardShiftState,
- Point(Msg.lParamLo, Msg.lParamHi));
-end;
-
-procedure TGDIWindow.WMMouseMove(var Msg: TMessage);
-begin
- if DoMouseEnterLeaveCheck(Msg) and Assigned(OnMouseMove) then
- OnMouseMove(Self, GetKeyboardShiftState, Point(Msg.lParamLo, Msg.lParamHi));
-end;
-
-procedure TGDIWindow.WMMouseWheel(var Msg: TMessage);
-var
- pt: Windows.POINT;
-begin
- if DoMouseEnterLeaveCheck(Msg) and Assigned(OnMouseWheel) then
- begin
- pt.x := Msg.lParamLo;
- pt.y := Msg.lParamHi;
- Windows.ScreenToClient(Handle, pt);
- OnMouseWheel(Self, GetKeyboardShiftState, SmallInt(Msg.wParamHi) / -120.0,
- Point(pt.x, pt.y));
- end;
-end;
-
-procedure TGDIWindow.WMKeyDown(var Msg: TMessage);
-begin
- if Assigned(OnKeyPressed) then
- OnKeyPressed(Self, VirtKeyToKeycode(Msg.wParam), GetKeyboardShiftState);
- if (Msg.wParam = $2e {VK_DELETE}) and Assigned(OnKeyChar) then
- OnKeyChar(Self, #127);
-end;
-
-procedure TGDIWindow.WMKeyUp(var Msg: TMessage);
-begin
- if Assigned(OnKeyReleased) then
- OnKeyReleased(Self, VirtKeyToKeycode(Msg.wParam), GetKeyboardShiftState);
-end;
-
-procedure TGDIWindow.WMChar(var Msg: TMessage);
-begin
- if Assigned(OnKeyChar) then
- OnKeyChar(Self, Chr(Msg.wParam));
-end;
-
-procedure TGDIWindow.WMSysKeyDown(var Msg: TMessage);
-begin
- WMKeyDown(Msg);
-end;
-
-procedure TGDIWindow.WMSysKeyUp(var Msg: TMessage);
-begin
- WMKeyUp(Msg);
-end;
-
-procedure TGDIWindow.WMSysChar(var Msg: TMessage);
-begin
- WMChar(Msg);
-end;
-
-
{ Helpers }
function RectToWinRect(const ARect: TRect): Windows.Rect;
diff --git a/gfx/gfxbase.pas b/gfx/gfxbase.pas
index 968c9c42..becc425b 100644
--- a/gfx/gfxbase.pas
+++ b/gfx/gfxbase.pas
@@ -79,20 +79,20 @@ type
TGfxFormatType = (
ftInvalid,
- ftMono, // Monochrome
- ftPal8, // 8 bpp using palette
+ ftMono, // Monochrome
+ ftPal8, // 8 bpp using palette
ftPal8A, // 8 bpp using palette with alpha values > 0
ftRGB16, // 15/16 bpp RGB
ftRGBA16, // 16 bpp RGBA
ftRGB32, // 32 bpp RGB
- ftRGBA32); // 32 bpp RGBA
+ ftRGBA32); // 32 bpp RGBA
TGfxPixelFormat = record
case FormatType: TGfxFormatType of
ftRGB16, ftRGBA16, ftRGB32, ftRGBA32: (
- RedMask: TGfxPixel;
- GreenMask: TGfxPixel;
+ RedMask: TGfxPixel;
+ GreenMask: TGfxPixel;
BlueMask: TGfxPixel;
AlphaMask: TGfxPixel); // only used for RGBA types
end;
@@ -219,14 +219,34 @@ type
TFCustomApplication = class;
TFCustomWindow = class;
- TGfxWindowOption = (
+ TFWindowOption = (
woWindow, woBorderless, woPopup, woToolWindow, woChildWindow,
woX11SkipWMHints);
- TGfxWindowOptions = set of TGfxWindowOption;
+ TFWindowOptions = set of TFWindowOption;
- TGfxCursor = (crDefault, crNone, crArrow, crCross, crIBeam, crSize, crSizeNS,
+ TFCursor = (crDefault, crNone, crArrow, crCross, crIBeam, crSize, crSizeNS,
crSizeWE, cpUpArrow, crHourGlass, crNoDrop, crHelp);
+ TMouseButton = (mbLeft, mbRight, mbMiddle);
+
+ { TFEvent }
+
+ TFEventType = (etCreate, etCanClose, etClose, etFocusIn, etFocusOut,
+ etHide, etKeyPressed, etKeyReleased, etKeyChar,
+ etMouseEnter, etMouseLeave, etMousePressed, etMouseReleased,
+ etMouseMove, etMouseWheel, etPaint, etMove, etResize, etShow);
+
+ TFEvent = class
+ public
+ { Window Manager fields }
+ Msg: Cardinal;
+ wparam: Cardinal;
+ lparam: Cardinal;
+ Result: Cardinal;
+ MouseButton: TMouseButton;
+ { fpGUI fields }
+ EventType: TFEventType;
+ end;
{ TFCustomFont }
@@ -409,7 +429,6 @@ type
TGfxKeyEvent = procedure(Sender: TObject; AKey: Word; AShift: TShiftState) of object;
TGfxKeyCharEvent = procedure(Sender: TObject; AKeyChar: Char) of object;
// Mouse
- TMouseButton = (mbLeft, mbRight, mbMiddle);
TGfxMouseButtonEvent = procedure(Sender: TObject; AButton: TMouseButton; AShift: TShiftState; const AMousePos: TPoint) of object;
TGfxMouseMoveEvent = procedure(Sender: TObject; AShift: TShiftState; const AMousePos: TPoint) of object;
TGfxMouseWheelEvent = procedure(Sender: TObject; AShift: TShiftState; AWheelDelta: Single; const AMousePos: TPoint) of object;
@@ -419,7 +438,7 @@ type
TFCustomWindow = class
private
- FCursor: TGfxCursor;
+ FCursor: TFCursor;
FOnCreate: TNotifyEvent;
FOnCanClose: TGfxCanCloseEvent;
FOnClose: TNotifyEvent;
@@ -441,8 +460,8 @@ type
FOnShow: TNotifyEvent;
procedure SetWidth(AWidth: Integer);
procedure SetHeight(AHeight: Integer);
- procedure SetCursor(ACursor: TGfxCursor);
- procedure SetWindowOptions(const AValue: TGfxWindowOptions); virtual;
+ procedure SetCursor(ACursor: TFCursor);
+ procedure SetWindowOptions(const AValue: TFWindowOptions); virtual;
protected
FHandle: Cardinal;
FParent: TFCustomWindow;
@@ -453,14 +472,14 @@ type
FHeight: Integer;
FClientWidth: Integer;
FClientHeight: Integer;
- FWindowOptions: TGfxWindowOptions;
+ FWindowOptions: TFWindowOptions;
FChildWindows: TList;
FMinSize, FMaxSize: TSize;
function GetTitle: String; virtual;
procedure SetTitle(const ATitle: String); virtual;
procedure DoSetCursor; virtual; abstract;
public
- constructor Create(AParent: TFCustomWindow; AWindowOptions: TGfxWindowOptions); virtual;
+ constructor Create(AParent: TFCustomWindow; AWindowOptions: TFWindowOptions); virtual;
destructor Destroy; override;
function CanClose: Boolean; virtual;
procedure SetPosition(const APosition: TPoint); virtual;
@@ -475,8 +494,9 @@ type
procedure PaintInvalidRegion; virtual; abstract;
procedure CaptureMouse; virtual; abstract;
procedure ReleaseMouse; virtual; abstract;
+ procedure ProcessEvent(AEvent: TFEvent); virtual; abstract;
- property WindowOptions: TGfxWindowOptions read FWindowOptions write SetWindowOptions;
+ property WindowOptions: TFWindowOptions read FWindowOptions write SetWindowOptions;
property Canvas: TFCustomCanvas read FCanvas;
property Handle: Cardinal read FHandle;
property ChildWindows: TList read FChildWindows;
@@ -487,8 +507,9 @@ type
property Height: Integer read FHeight write SetHeight;
property ClientWidth: Integer read FClientWidth;
property ClientHeight: Integer read FClientHeight;
- property Cursor: TGfxCursor read FCursor write SetCursor;
+ property Cursor: TFCursor read FCursor write SetCursor;
property Title: String read GetTitle write SetTitle;
+ property Parent: TFCustomWindow read FParent;
// Event handlers
property OnCreate: TNotifyEvent read FOnCreate write FOnCreate;
property OnCanClose: TGfxCanCloseEvent read FOnCanClose write FOnCanClose;
@@ -969,7 +990,7 @@ begin
end;
constructor TFCustomWindow.Create(AParent: TFCustomWindow;
- AWindowOptions: TGfxWindowOptions);
+ AWindowOptions: TFWindowOptions);
begin
inherited Create;
@@ -998,7 +1019,7 @@ begin
SetSize(Size(Width, AHeight));
end;
-procedure TFCustomWindow.SetCursor(ACursor: TGfxCursor);
+procedure TFCustomWindow.SetCursor(ACursor: TFCursor);
begin
if ACursor <> Cursor then
begin
@@ -1007,7 +1028,7 @@ begin
end;
end;
-procedure TFCustomWindow.SetWindowOptions(const AValue: TGfxWindowOptions);
+procedure TFCustomWindow.SetWindowOptions(const AValue: TFWindowOptions);
begin
if FWindowOptions=AValue then exit;
FWindowOptions:=AValue;
diff --git a/prototypes/multihandle/gui2Base.pas b/prototypes/multihandle/gui2Base.pas
index e0b0812e..3af4326c 100644
--- a/prototypes/multihandle/gui2Base.pas
+++ b/prototypes/multihandle/gui2Base.pas
@@ -54,7 +54,7 @@ type
property OnPainting: TNotifyEvent read FOnPainting write FOnPainting;
property Color: TGfxColor read FColor write SetColor;
public
- constructor Create(AParent: TFCustomWindow; AWindowOptions: TGfxWindowOptions); override;
+ constructor Create(AParent: TFCustomWindow; AWindowOptions: TFWindowOptions); override;
constructor Create; virtual;
property OnClick: TNotifyEvent read FOnClick write FOnClick;
end;
@@ -66,7 +66,7 @@ type
procedure PopupWindowClick(Sender: TObject);
procedure Paint; override;
public
- constructor Create(AParent: TFCustomWindow; AWindowOptions: TGfxWindowOptions); override;
+ constructor Create(AParent: TFCustomWindow; AWindowOptions: TFWindowOptions); override;
constructor Create; override;
end;
@@ -251,8 +251,7 @@ begin
Canvas.FillRect(r);
end;
-constructor TForm.Create(AParent: TFCustomWindow;
- AWindowOptions: TGfxWindowOptions);
+constructor TForm.Create(AParent: TFCustomWindow; AWindowOptions: TFWindowOptions);
begin
inherited Create(AParent, AWindowOptions);
FColor := colWhite;
@@ -346,8 +345,7 @@ begin
inherited Paint;
end;
-constructor TPopupWindow.Create(AParent: TFCustomWindow;
- AWindowOptions: TGfxWindowOptions);
+constructor TPopupWindow.Create(AParent: TFCustomWindow; AWindowOptions: TFWindowOptions);
begin
inherited Create(AParent, AWindowOptions);
// SetPosition();
diff --git a/prototypes/multihandle/test.lpi b/prototypes/multihandle/test.lpi
index af9f5e1e..7422b477 100644
--- a/prototypes/multihandle/test.lpi
+++ b/prototypes/multihandle/test.lpi
@@ -1,7 +1,7 @@
<?xml version="1.0"?>
<CONFIG>
<ProjectOptions>
- <PathDelim Value="/"/>
+ <PathDelim Value="\"/>
<Version Value="5"/>
<General>
<Flags>
@@ -23,7 +23,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="1">
@@ -41,6 +41,7 @@
</ProjectOptions>
<CompilerOptions>
<Version Value="5"/>
+ <PathDelim Value="\"/>
<CodeGeneration>
<Generate Value="Faster"/>
</CodeGeneration>