mirror of
https://github.com/salvadordf/CEF4Delphi.git
synced 2025-04-27 07:02:21 +02:00
Extracted base-class for TCefWindow with Chromium / Move WndProc
This commit is contained in:
parent
ff9d2a39a8
commit
c7fba0eb39
@ -69,11 +69,15 @@ type
|
|||||||
TCEFLinkedWinControlBase = class(TCEFWinControl)
|
TCEFLinkedWinControlBase = class(TCEFWinControl)
|
||||||
protected
|
protected
|
||||||
function GetChromium: TChromium; virtual; abstract;
|
function GetChromium: TChromium; virtual; abstract;
|
||||||
|
function GetUseSetFocus: Boolean; virtual;
|
||||||
|
|
||||||
{$IFDEF FPC}
|
{$IFDEF FPC}
|
||||||
procedure SetVisible(Value: Boolean); override;
|
procedure SetVisible(Value: Boolean); override;
|
||||||
{$ENDIF}
|
{$ENDIF}
|
||||||
function GetChildWindowHandle : {$IFNDEF MSWINDOWS}{$IFDEF FPC}LclType.{$ENDIF}{$ENDIF}THandle; override;
|
function GetChildWindowHandle : {$IFNDEF MSWINDOWS}{$IFDEF FPC}LclType.{$ENDIF}{$ENDIF}THandle; override;
|
||||||
|
{$IFDEF MSWINDOWS}
|
||||||
|
procedure WndProc(var aMessage: TMessage); override;
|
||||||
|
{$ENDIF}
|
||||||
|
|
||||||
property Chromium : TChromium read GetChromium;
|
property Chromium : TChromium read GetChromium;
|
||||||
public
|
public
|
||||||
@ -86,6 +90,11 @@ implementation
|
|||||||
|
|
||||||
{$IFDEF FPC}
|
{$IFDEF FPC}
|
||||||
|
|
||||||
|
function TCEFLinkedWinControlBase.GetUseSetFocus: Boolean;
|
||||||
|
begin
|
||||||
|
Result := True;
|
||||||
|
end;
|
||||||
|
|
||||||
procedure TCEFLinkedWinControlBase.SetVisible(Value: Boolean);
|
procedure TCEFLinkedWinControlBase.SetVisible(Value: Boolean);
|
||||||
{$IFDEF LINUX}
|
{$IFDEF LINUX}
|
||||||
var
|
var
|
||||||
@ -117,6 +126,41 @@ begin
|
|||||||
if (Result = 0) then Result := inherited GetChildWindowHandle;
|
if (Result = 0) then Result := inherited GetChildWindowHandle;
|
||||||
end;
|
end;
|
||||||
|
|
||||||
|
{$IFDEF MSWINDOWS}
|
||||||
|
procedure TCEFLinkedWinControlBase.WndProc(var aMessage: TMessage);
|
||||||
|
var
|
||||||
|
TempHandle : THandle;
|
||||||
|
begin
|
||||||
|
case aMessage.Msg of
|
||||||
|
WM_SETFOCUS:
|
||||||
|
begin
|
||||||
|
if GetUseSetFocus and (Chromium <> nil) then
|
||||||
|
Chromium.SetFocus(True)
|
||||||
|
else
|
||||||
|
begin
|
||||||
|
TempHandle := ChildWindowHandle;
|
||||||
|
if (TempHandle <> 0) then PostMessage(TempHandle, WM_SETFOCUS, aMessage.WParam, 0);
|
||||||
|
end;
|
||||||
|
|
||||||
|
inherited WndProc(aMessage);
|
||||||
|
end;
|
||||||
|
|
||||||
|
WM_ERASEBKGND:
|
||||||
|
if (ChildWindowHandle = 0) then inherited WndProc(aMessage);
|
||||||
|
|
||||||
|
CM_WANTSPECIALKEY:
|
||||||
|
if not(TWMKey(aMessage).CharCode in [VK_LEFT .. VK_DOWN, VK_RETURN, VK_ESCAPE]) then
|
||||||
|
aMessage.Result := 1
|
||||||
|
else
|
||||||
|
inherited WndProc(aMessage);
|
||||||
|
|
||||||
|
WM_GETDLGCODE : aMessage.Result := DLGC_WANTARROWS or DLGC_WANTCHARS;
|
||||||
|
|
||||||
|
else inherited WndProc(aMessage);
|
||||||
|
end;
|
||||||
|
end;
|
||||||
|
{$ENDIF}
|
||||||
|
|
||||||
procedure TCEFLinkedWinControlBase.UpdateSize;
|
procedure TCEFLinkedWinControlBase.UpdateSize;
|
||||||
begin
|
begin
|
||||||
{$IFDEF LINUX}
|
{$IFDEF LINUX}
|
||||||
|
@ -76,10 +76,9 @@ type
|
|||||||
FUseSetFocus : boolean;
|
FUseSetFocus : boolean;
|
||||||
|
|
||||||
function GetChromium: TChromium; override;
|
function GetChromium: TChromium; override;
|
||||||
|
function GetUseSetFocus: Boolean; override;
|
||||||
function GetBrowserInitialized : boolean;
|
function GetBrowserInitialized : boolean;
|
||||||
{$IFDEF MSWINDOWS}
|
{$IFDEF MSWINDOWS}
|
||||||
procedure WndProc(var aMessage: TMessage); override;
|
|
||||||
|
|
||||||
procedure OnCloseMsg(var aMessage : TMessage); message CEF_DOONCLOSE;
|
procedure OnCloseMsg(var aMessage : TMessage); message CEF_DOONCLOSE;
|
||||||
procedure OnAfterCreatedMsg(var aMessage : TMessage); message CEF_AFTERCREATED;
|
procedure OnAfterCreatedMsg(var aMessage : TMessage); message CEF_AFTERCREATED;
|
||||||
{$ENDIF}
|
{$ENDIF}
|
||||||
@ -186,41 +185,6 @@ begin
|
|||||||
end;
|
end;
|
||||||
end;
|
end;
|
||||||
|
|
||||||
{$IFDEF MSWINDOWS}
|
|
||||||
procedure TChromiumWindow.WndProc(var aMessage: TMessage);
|
|
||||||
var
|
|
||||||
TempHandle : THandle;
|
|
||||||
begin
|
|
||||||
case aMessage.Msg of
|
|
||||||
WM_SETFOCUS:
|
|
||||||
begin
|
|
||||||
if FUseSetFocus and (FChromium <> nil) then
|
|
||||||
FChromium.SetFocus(True)
|
|
||||||
else
|
|
||||||
begin
|
|
||||||
TempHandle := ChildWindowHandle;
|
|
||||||
if (TempHandle <> 0) then PostMessage(TempHandle, WM_SETFOCUS, aMessage.WParam, 0);
|
|
||||||
end;
|
|
||||||
|
|
||||||
inherited WndProc(aMessage);
|
|
||||||
end;
|
|
||||||
|
|
||||||
WM_ERASEBKGND:
|
|
||||||
if (ChildWindowHandle = 0) then inherited WndProc(aMessage);
|
|
||||||
|
|
||||||
CM_WANTSPECIALKEY:
|
|
||||||
if not(TWMKey(aMessage).CharCode in [VK_LEFT .. VK_DOWN, VK_RETURN, VK_ESCAPE]) then
|
|
||||||
aMessage.Result := 1
|
|
||||||
else
|
|
||||||
inherited WndProc(aMessage);
|
|
||||||
|
|
||||||
WM_GETDLGCODE : aMessage.Result := DLGC_WANTARROWS or DLGC_WANTCHARS;
|
|
||||||
|
|
||||||
else inherited WndProc(aMessage);
|
|
||||||
end;
|
|
||||||
end;
|
|
||||||
{$ENDIF}
|
|
||||||
|
|
||||||
function TChromiumWindow.GetBrowserInitialized : boolean;
|
function TChromiumWindow.GetBrowserInitialized : boolean;
|
||||||
begin
|
begin
|
||||||
Result := (FChromium <> nil) and FChromium.Initialized;
|
Result := (FChromium <> nil) and FChromium.Initialized;
|
||||||
@ -322,6 +286,11 @@ begin
|
|||||||
result := FChromium;
|
result := FChromium;
|
||||||
end;
|
end;
|
||||||
|
|
||||||
|
function TChromiumWindow.GetUseSetFocus: Boolean;
|
||||||
|
begin
|
||||||
|
Result := FUseSetFocus;
|
||||||
|
end;
|
||||||
|
|
||||||
|
|
||||||
// This is a workaround for the CEF issue #2026
|
// This is a workaround for the CEF issue #2026
|
||||||
// https://bitbucket.org/chromiumembedded/cef/issues/2026/multiple-major-keyboard-focus-issues-on
|
// https://bitbucket.org/chromiumembedded/cef/issues/2026/multiple-major-keyboard-focus-issues-on
|
||||||
|
@ -75,9 +75,6 @@ type
|
|||||||
function GetChromium: TChromium; override;
|
function GetChromium: TChromium; override;
|
||||||
procedure SetChromium(aValue : TChromium);
|
procedure SetChromium(aValue : TChromium);
|
||||||
|
|
||||||
{$IFDEF MSWINDOWS}
|
|
||||||
procedure WndProc(var aMessage: TMessage); override;
|
|
||||||
{$ENDIF}
|
|
||||||
procedure Notification(AComponent: TComponent; Operation: TOperation); override;
|
procedure Notification(AComponent: TComponent; Operation: TOperation); override;
|
||||||
|
|
||||||
public
|
public
|
||||||
@ -105,41 +102,6 @@ begin
|
|||||||
FChromium := nil;
|
FChromium := nil;
|
||||||
end;
|
end;
|
||||||
|
|
||||||
{$IFDEF MSWINDOWS}
|
|
||||||
procedure TCEFLinkedWindowParent.WndProc(var aMessage: TMessage);
|
|
||||||
var
|
|
||||||
TempHandle : THandle;
|
|
||||||
begin
|
|
||||||
case aMessage.Msg of
|
|
||||||
WM_SETFOCUS:
|
|
||||||
begin
|
|
||||||
if (FChromium <> nil) then
|
|
||||||
FChromium.SetFocus(True)
|
|
||||||
else
|
|
||||||
begin
|
|
||||||
TempHandle := ChildWindowHandle;
|
|
||||||
if (TempHandle <> 0) then PostMessage(TempHandle, WM_SETFOCUS, aMessage.WParam, 0);
|
|
||||||
end;
|
|
||||||
|
|
||||||
inherited WndProc(aMessage);
|
|
||||||
end;
|
|
||||||
|
|
||||||
WM_ERASEBKGND:
|
|
||||||
if (ChildWindowHandle = 0) then inherited WndProc(aMessage);
|
|
||||||
|
|
||||||
CM_WANTSPECIALKEY:
|
|
||||||
if not(TWMKey(aMessage).CharCode in [VK_LEFT .. VK_DOWN, VK_RETURN, VK_ESCAPE]) then
|
|
||||||
aMessage.Result := 1
|
|
||||||
else
|
|
||||||
inherited WndProc(aMessage);
|
|
||||||
|
|
||||||
WM_GETDLGCODE : aMessage.Result := DLGC_WANTARROWS or DLGC_WANTCHARS;
|
|
||||||
|
|
||||||
else inherited WndProc(aMessage);
|
|
||||||
end;
|
|
||||||
end;
|
|
||||||
{$ENDIF}
|
|
||||||
|
|
||||||
procedure TCEFLinkedWindowParent.Notification(AComponent: TComponent; Operation: TOperation);
|
procedure TCEFLinkedWindowParent.Notification(AComponent: TComponent; Operation: TOperation);
|
||||||
begin
|
begin
|
||||||
inherited Notification(AComponent, Operation);
|
inherited Notification(AComponent, Operation);
|
||||||
|
Loading…
x
Reference in New Issue
Block a user