1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
android_webview / browser / renderer_host / aw_render_view_host_ext.h [blame]
// 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);
// 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_