type ICefWindowDelegate = interface(ICefPanelDelegate)
Implement this interface to handle window events. The functions of this interface will be called on the browser process UI thread unless otherwise indicated.
UNKNOWN
<see href="https://bitbucket.org/chromiumembedded/cef/src/master/include/capi/views/cef_window_delegate_capi.h">CEF source file: /include/capi/views/cef_window_delegate_capi.h (cef_window_delegate_t))
procedure OnWindowCreated(const window_: ICefWindow); |
|
procedure OnWindowClosing(const window_: ICefWindow); |
|
procedure OnWindowDestroyed(const window_: ICefWindow); |
|
procedure OnWindowActivationChanged(const window_: ICefWindow; active: boolean); |
|
procedure OnWindowBoundsChanged(const window_: ICefWindow; const new_bounds: TCefRect); |
|
procedure OnWindowFullscreenTransition(const window_: ICefWindow; is_completed: boolean); |
|
procedure OnGetParentWindow(const window_: ICefWindow; var is_menu, can_activate_menu: boolean; var aResult : ICefWindow); |
|
procedure OnIsWindowModalDialog(const window_: ICefWindow; var aResult: boolean); |
|
procedure OnGetInitialBounds(const window_: ICefWindow; var aResult : TCefRect); |
|
procedure OnGetInitialShowState(const window_: ICefWindow; var aResult : TCefShowState); |
|
procedure OnIsFrameless(const window_: ICefWindow; var aResult : boolean); |
|
procedure OnWithStandardWindowButtons(const window_: ICefWindow; var aResult : boolean); |
|
procedure OnGetTitlebarHeight(const window_: ICefWindow; var titlebar_height: Single; var aResult : boolean); |
|
procedure OnAcceptsFirstMouse(const window_: ICefWindow; var aResult: TCefState); |
|
procedure OnCanResize(const window_: ICefWindow; var aResult : boolean); |
|
procedure OnCanMaximize(const window_: ICefWindow; var aResult : boolean); |
|
procedure OnCanMinimize(const window_: ICefWindow; var aResult : boolean); |
|
procedure OnCanClose(const window_: ICefWindow; var aResult : boolean); |
|
procedure OnAccelerator(const window_: ICefWindow; command_id: Integer; var aResult : boolean); |
|
procedure OnKeyEvent(const window_: ICefWindow; const event: TCefKeyEvent; var aResult : boolean); |
|
procedure OnThemeColorsChanged(const window_: ICefWindow; chrome_theme: Integer); |
|
procedure OnGetWindowRuntimeStyle(var aResult: TCefRuntimeStyle); |
|
procedure OnGetLinuxWindowProperties(const window_: ICefWindow; var properties: TLinuxWindowProperties; var aResult: boolean); |
procedure OnWindowCreated(const window_: ICefWindow); |
|
Called when |window| is created. Attributes
|
procedure OnWindowClosing(const window_: ICefWindow); |
|
Called when |window| is closing. |
procedure OnWindowDestroyed(const window_: ICefWindow); |
|
Called when |window| is destroyed. Release all references to |window| and do not attempt to execute any functions on |window| after this callback returns. |
procedure OnWindowActivationChanged(const window_: ICefWindow; active: boolean); |
|
Called when |window| is activated or deactivated. |
procedure OnWindowBoundsChanged(const window_: ICefWindow; const new_bounds: TCefRect); |
|
Called when |window| bounds have changed. |new_bounds| will be in DIP screen coordinates. |
procedure OnWindowFullscreenTransition(const window_: ICefWindow; is_completed: boolean); |
|
Called when |window| is transitioning to or from fullscreen mode. On MacOS the transition occurs asynchronously with |is_competed| set to false (0) when the transition starts and true (1) after the transition completes. On other platforms the transition occurs synchronously with |is_completed| set to true (1) after the transition completes. With Alloy style you must also implement ICefDisplayHandler.OnFullscreenModeChange to handle fullscreen transitions initiated by browser content. |
procedure OnGetParentWindow(const window_: ICefWindow; var is_menu, can_activate_menu: boolean; var aResult : ICefWindow); |
|
Return the parent for |window| or NULL if the |window| does not have a parent. Windows with parents will not get a taskbar button. Set |is_menu| to true (1) if |window| will be displayed as a menu, in which case it will not be clipped to the parent window bounds. Set |can_activate_menu| to false (0) if |is_menu| is true (1) and |window| should not be activated (given keyboard focus) when displayed. |
procedure OnIsWindowModalDialog(const window_: ICefWindow; var aResult: boolean); |
|
Return true (1) if |window| should be created as a window modal dialog. Only called when a Window is returned via get_parent_window() with |is_menu| set to false (0). All controls in the parent Window will be disabled while |window| is visible. This functionality is not supported by all Linux window managers. Alternately, use ICefWindow.ShowAsBrowserModalDialog() for a browser modal dialog that works on all platforms. |
procedure OnGetInitialBounds(const window_: ICefWindow; var aResult : TCefRect); |
|
Return the initial bounds for |window| in density independent pixel (DIP) coordinates. If this function returns an NULL CefRect then GetPreferredSize() will be called to retrieve the size, and the window will be placed on the screen with origin (0,0). This function can be used in combination with ICefView.GetBoundsInScreen() to restore the previous window bounds. |
procedure OnGetInitialShowState(const window_: ICefWindow; var aResult : TCefShowState); |
|
Return the initial show state for |window|. |
procedure OnIsFrameless(const window_: ICefWindow; var aResult : boolean); |
|
Return true (1) if |window| should be created without a frame or title bar. The window will be resizable if can_resize() returns true (1). Use ICefWindow.SetDraggableRegions() to specify draggable regions. |
procedure OnWithStandardWindowButtons(const window_: ICefWindow; var aResult : boolean); |
|
Return true (1) if |window| should be created with standard window buttons like close, minimize and zoom. This function is only supported on macOS. |
procedure OnGetTitlebarHeight(const window_: ICefWindow; var titlebar_height: Single; var aResult : boolean); |
|
Return whether the titlebar height should be overridden, and sets the height of the titlebar in |titlebar_height|. On macOS, it can also be used to adjust the vertical position of the traffic light buttons in frameless windows. The buttons will be positioned halfway down the titlebar at a height of |titlebar_height| / 2. |
procedure OnAcceptsFirstMouse(const window_: ICefWindow; var aResult: TCefState); |
|
Return whether the view should accept the initial mouse-down event, allowing it to respond to click-through behavior. If STATE_ENABLED is returned, the view will be sent a mouseDown: message for an initial mouse- down event, activating the view with one click, instead of clicking first to make the window active and then clicking the view. This function is only supported on macOS. For more details, refer to the documentation of acceptsFirstMouse. |
procedure OnCanResize(const window_: ICefWindow; var aResult : boolean); |
|
Return true (1) if |window| can be resized. |
procedure OnCanMaximize(const window_: ICefWindow; var aResult : boolean); |
|
Return true (1) if |window| can be maximized. |
procedure OnCanMinimize(const window_: ICefWindow; var aResult : boolean); |
|
Return true (1) if |window| can be minimized. |
procedure OnCanClose(const window_: ICefWindow; var aResult : boolean); |
|
Return true (1) if |window| can be closed. This will be called for user- initiated window close actions and when ICefWindow.close() is called. |
procedure OnAccelerator(const window_: ICefWindow; command_id: Integer; var aResult : boolean); |
|
Called when a keyboard accelerator registered with ICefWindow.SetAccelerator is triggered. Return true (1) if the accelerator was handled or false (0) otherwise. |
procedure OnKeyEvent(const window_: ICefWindow; const event: TCefKeyEvent; var aResult : boolean); |
|
Called after all other controls in the window have had a chance to handle the event. |event| contains information about the keyboard event. Return true (1) if the keyboard event was handled or false (0) otherwise. |
procedure OnThemeColorsChanged(const window_: ICefWindow; chrome_theme: Integer); |
|
Called after the native/OS or Chrome theme for |window| has changed. |chrome_theme| will be true (1) if the notification is for a Chrome theme. Native/OS theme colors are configured globally and do not need to be customized for each Window individually. An example of a native/OS theme change that triggers this callback is when the user switches between dark and light mode during application lifespan. Native/OS theme changes can be disabled by passing the `–force-dark-mode` or `–force-light-mode` command-line flag. Chrome theme colors will be applied and this callback will be triggered if/when a BrowserView is added to the Window's component hierarchy. Chrome theme colors can be configured on a per-RequestContext basis using ICefRequestContext.SetChromeColorScheme or (Chrome style only) by visiting chrome://settings/manageProfile. Any theme changes using those mechanisms will also trigger this callback. Chrome theme colors will be persisted and restored from disk cache. This callback is not triggered on Window creation so clients that wish to customize the initial native/OS theme must call ICefWindow.SetThemeColor and ICefWindow.ThemeChanged before showing the first Window. Theme colors will be reset to standard values before this callback is called for the first affected Window. Call ICefWindow.SetThemeColor from inside this callback to override a standard color or add a custom color. ICefViewDelegate.OnThemeChanged will be called after this callback for the complete |window| component hierarchy. |
procedure OnGetWindowRuntimeStyle(var aResult: TCefRuntimeStyle); |
|
Optionally change the runtime style for this Window. See TCefRuntimeStyle documentation for details. |
procedure OnGetLinuxWindowProperties(const window_: ICefWindow; var properties: TLinuxWindowProperties; var aResult: boolean); |
|
Return Linux-specific window properties for correctly handling by window managers. |