WebViewRenderProcessClient

public abstract class WebViewRenderProcessClient


Used to receive callbacks on WebView renderer events. WebViewRenderProcessClient instances may be set or retrieved via setWebViewRenderProcessClient and getWebViewRenderProcessClient. Instances may be attached to multiple WebViews, and thus a single renderer event may cause a callback to be called multiple times with different WebView parameters.

Summary

Public constructors

Public methods

abstract void

Called once when an unresponsive renderer currently associated with view becomes responsive.

abstract void

Called when the renderer currently associated with view becomes unresponsive as a result of a long running blocking task such as the execution of JavaScript.

Public constructors

WebViewRenderProcessClient

Added in 1.1.0
public WebViewRenderProcessClient()

Public methods

onRenderProcessResponsive

Added in 1.1.0
public abstract void onRenderProcessResponsive(
    @NonNull WebView view,
    @Nullable WebViewRenderProcess renderer
)

Called once when an unresponsive renderer currently associated with view becomes responsive.

After a WebView renderer becomes unresponsive, which is notified to the application by onRenderProcessUnresponsive, it is possible for the blocking renderer task to complete, returning the renderer to a responsive state. In that case, this method is called once to indicate responsiveness.

No action is taken by WebView as a result of this method call.

Parameters
@NonNull WebView view

The android.webkit.WebView for which responsiveness was detected.

@Nullable WebViewRenderProcess renderer

The WebViewRenderProcess that has become responsive, or null if WebView is running in single process mode.

onRenderProcessUnresponsive

Added in 1.1.0
public abstract void onRenderProcessUnresponsive(
    @NonNull WebView view,
    @Nullable WebViewRenderProcess renderer
)

Called when the renderer currently associated with view becomes unresponsive as a result of a long running blocking task such as the execution of JavaScript.

If a WebView fails to process an input event, or successfully navigate to a new URL within a reasonable time frame, the renderer is considered to be unresponsive, and this callback will be called.

This callback will continue to be called at regular intervals as long as the renderer remains unresponsive. If the renderer becomes responsive again, onRenderProcessResponsive will be called once, and this method will not subsequently be called unless another period of unresponsiveness is detected.

The minimum interval between successive calls to onRenderProcessUnresponsive is 5 seconds.

No action is taken by WebView as a result of this method call. Applications may choose to terminate the associated renderer via the object that is passed to this callback, if in multiprocess mode, however this must be accompanied by correctly handling onRenderProcessGone for this WebView, and all other WebViews associated with the same renderer. Failure to do so will result in application termination.

Parameters
@NonNull WebView view

The android.webkit.WebView for which unresponsiveness was detected.

@Nullable WebViewRenderProcess renderer

The WebViewRenderProcess that has become unresponsive, or null if WebView is running in single process mode.