Chromium Embedded Framework (CEF)
113.1.0+gfdb5b77+chromium-113.0.5672.53
|
Implement this interface to handle events related to CefFrame life span. More...
#include "include/cef_frame_handler.h"
Public Member Functions | |
virtual void | OnFrameCreated (CefRefPtr< CefBrowser > browser, CefRefPtr< CefFrame > frame) |
Called when a new frame is created. More... | |
virtual void | OnFrameAttached (CefRefPtr< CefBrowser > browser, CefRefPtr< CefFrame > frame, bool reattached) |
Called when a frame can begin routing commands to/from the associated renderer process. More... | |
virtual void | OnFrameDetached (CefRefPtr< CefBrowser > browser, CefRefPtr< CefFrame > frame) |
Called when a frame loses its connection to the renderer process and will be destroyed. More... | |
virtual void | OnMainFrameChanged (CefRefPtr< CefBrowser > browser, CefRefPtr< CefFrame > old_frame, CefRefPtr< CefFrame > new_frame) |
Called when the main frame changes due to (a) initial browser creation, (b) final browser destruction, (c) cross-origin navigation or (d) re-navigation after renderer process termination (due to crashes, etc). More... | |
Public Member Functions inherited from CefBaseRefCounted | |
virtual void | AddRef () const =0 |
Called to increment the reference count for the object. More... | |
virtual bool | Release () const =0 |
Called to decrement the reference count for the object. More... | |
virtual bool | HasOneRef () const =0 |
Returns true if the reference count is 1. More... | |
virtual bool | HasAtLeastOneRef () const =0 |
Returns true if the reference count is at least 1. More... | |
Additional Inherited Members | |
Protected Member Functions inherited from CefBaseRefCounted | |
virtual | ~CefBaseRefCounted () |
Implement this interface to handle events related to CefFrame life span.
The order of callbacks is:
(1) During initial CefBrowserHost creation and navigation of the main frame:
(2) During further CefBrowserHost navigation/loading of the main frame and/or sub-frames:
(3) During final CefBrowserHost destruction of the main frame:
Cross-origin navigation and/or loading receives special handling.
When the main frame navigates to a different origin the OnMainFrameChanged callback (2) will be executed with the old and new main frame objects.
When a new sub-frame is loaded in, or an existing sub-frame is navigated to, a different origin from the parent frame, a temporary sub-frame object will first be created in the parent's renderer process. That temporary sub-frame will then be discarded after the real cross-origin sub-frame is created in the new/target renderer process. The client will receive cross-origin navigation callbacks (2) for the transition from the temporary sub-frame to the real sub-frame. The temporary sub-frame will not recieve or execute commands during this transitional period (any sent commands will be discarded).
When a new popup browser is created in a different origin from the parent browser, a temporary main frame object for the popup will first be created in the parent's renderer process. That temporary main frame will then be discarded after the real cross-origin main frame is created in the new/target renderer process. The client will recieve creation and initial navigation callbacks (1) for the temporary main frame, followed by cross-origin navigation callbacks (2) for the transition from the temporary main frame to the real main frame. The temporary main frame may receive and execute commands during this transitional period (any sent commands may be executed, but the behavior is potentially undesirable since they execute in the parent browser's renderer process and not the new/target renderer process).
Callbacks will not be executed for placeholders that may be created during pre-commit navigation for sub-frames that do not yet exist in the renderer process. Placeholders will have CefFrame::GetIdentifier() == -4.
The methods of this class will be called on the UI thread unless otherwise indicated.
|
inlinevirtual |
Called when a frame can begin routing commands to/from the associated renderer process.
|reattached| will be true if the frame was re-attached after exiting the BackForwardCache. Any commands that were queued have now been dispatched.
|
inlinevirtual |
Called when a new frame is created.
This will be the first notification that references |frame|. Any commands that require transport to the associated renderer process (LoadRequest, SendProcessMessage, GetSource, etc.) will be queued until OnFrameAttached is called for |frame|.
|
inlinevirtual |
Called when a frame loses its connection to the renderer process and will be destroyed.
Any pending or future commands will be discarded and CefFrame::IsValid() will now return false for |frame|. If called after CefLifeSpanHandler::OnBeforeClose() during browser destruction then CefBrowser::IsValid() will return false for |browser|.
|
inlinevirtual |
Called when the main frame changes due to (a) initial browser creation, (b) final browser destruction, (c) cross-origin navigation or (d) re-navigation after renderer process termination (due to crashes, etc).
|old_frame| will be NULL and |new_frame| will be non-NULL when a main frame is assigned to |browser| for the first time. |old_frame| will be non-NULL and |new_frame| will be NULL and when a main frame is removed from |browser| for the last time. Both |old_frame| and |new_frame| will be non-NULL for cross-origin navigations or re-navigation after renderer process termination. This method will be called after OnFrameCreated() for |new_frame| and/or after OnFrameDetached() for |old_frame|. If called after CefLifeSpanHandler::OnBeforeClose() during browser destruction then CefBrowser::IsValid() will return false for |browser|.