// Copyright 2012 The Chromium Authors
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#ifndef ANDROID_WEBVIEW_BROWSER_RENDERER_HOST_AW_RENDER_VIEW_HOST_EXT_H_
#define ANDROID_WEBVIEW_BROWSER_RENDERER_HOST_AW_RENDER_VIEW_HOST_EXT_H_
#include "base/memory/raw_ptr.h"
#include "content/public/browser/web_contents_observer.h"
#include "android_webview/common/mojom/frame.mojom.h"
#include "base/functional/callback_forward.h"
#include "content/public/browser/global_routing_id.h"
#include "content/public/browser/render_frame_host_receiver_set.h"
#include "mojo/public/cpp/bindings/associated_remote.h"
#include "mojo/public/cpp/bindings/pending_associated_receiver.h"
#include "third_party/skia/include/core/SkColor.h"
#include "ui/gfx/geometry/point_f.h"
#include "ui/gfx/geometry/size.h"
#include "ui/gfx/geometry/size_f.h"
namespace android_webview {
class AwRenderViewHostExtClient {
public:
// Called when the RenderView page scale changes.
virtual void OnWebLayoutPageScaleFactorChanged(float page_scale_factor) = 0;
virtual void OnWebLayoutContentsSizeChanged(
const gfx::Size& contents_size) = 0;
protected:
virtual ~AwRenderViewHostExtClient() {}
};
// Provides RenderViewHost wrapper functionality for sending WebView-specific
// IPC messages to the renderer and from there to WebKit.
class AwRenderViewHostExt : public content::WebContentsObserver,
mojom::FrameHost {
public:
// Binds the Mojo receiver for the FrameHost endpoint to the
// AwRenderViewHostExt associated with the RenderFrameHost.
static void BindFrameHost(
mojo::PendingAssociatedReceiver<mojom::FrameHost> receiver,
content::RenderFrameHost* rfh);
// To send receive messages to a RenderView we take the WebContents instance,
// as it internally handles RenderViewHost instances changing underneath us.
AwRenderViewHostExt(
AwRenderViewHostExtClient* client, content::WebContents* contents);
AwRenderViewHostExt(const AwRenderViewHostExt&) = delete;
AwRenderViewHostExt& operator=(const AwRenderViewHostExt&) = delete;
~AwRenderViewHostExt() override;
// |result| will be invoked with the outcome of the request.
using DocumentHasImagesResult = base::OnceCallback<void(bool)>;
void DocumentHasImages(DocumentHasImagesResult result);
// Do a hit test at the view port coordinates and asynchronously update
// |last_hit_test_data_|. Width and height in |touch_area| are in density
// independent pixels used by blink::WebView.
void RequestNewHitTestDataAt(const gfx::PointF& touch_center,
const gfx::SizeF& touch_area);
// Return |last_hit_test_data_|. Note that this is unavoidably racy;
// the corresponding public WebView API is as well.
mojom::HitTestDataPtr TakeLastHitTestData();
// Sets the zoom factor for text only. Used in layout modes other than
// Text Autosizing.
void SetTextZoomFactor(float factor);
void ResetScrollAndScaleState();
// Sets the initial page scale. This overrides initial scale set by
// the meta viewport tag.
void SetInitialPageScale(double page_scale_factor);
void SetWillSuppressErrorPage(bool suppress);
void SmoothScroll(int target_x, int target_y, base::TimeDelta duration);
private:
// content::WebContentsObserver implementation.
void DidStartNavigation(
content::NavigationHandle* navigation_handle) override;
void DidFinishNavigation(
content::NavigationHandle* navigation_handle) override;
void OnPageScaleFactorChanged(float page_scale_factor) override;
// mojom::FrameHost overrides:
void UpdateHitTestData(
android_webview::mojom::HitTestDataPtr hit_test_data) override;
void ContentsSizeChanged(const gfx::Size& contents_size) override;
void ShouldOverrideUrlLoading(
const std::u16string& url,
bool has_user_gesture,
bool is_redirect,
bool is_main_frame,
ShouldOverrideUrlLoadingCallback callback) override;
mojom::LocalMainFrame* GetLocalMainFrameRemote();
raw_ptr<AwRenderViewHostExtClient> client_;
// Authoritative copy of hit test data on the browser side. This is updated
// as a result of DoHitTest called explicitly or when the FocusedNodeChanged
// is called in AwRenderViewExt.
android_webview::mojom::HitTestDataPtr last_hit_test_data_;
// Some WebView users might want to show their own error pages / logic.
bool will_suppress_error_page_ = false;
content::GlobalRenderFrameHostId main_frame_global_id_;
content::RenderFrameHostReceiverSet<mojom::FrameHost> frame_host_receivers_;
// Associated channel to the webview LocalMainFrame extensions.
mojo::AssociatedRemote<mojom::LocalMainFrame> local_main_frame_remote_;
};
} // namespace android_webview
#endif // ANDROID_WEBVIEW_BROWSER_RENDERER_HOST_AW_RENDER_VIEW_HOST_EXT_H_