1 // Copyright (c) 2013 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file.
5 #ifndef ANDROID_WEBVIEW_BROWSER_BROWSER_VIEW_RENDERER_H_
6 #define ANDROID_WEBVIEW_BROWSER_BROWSER_VIEW_RENDERER_H_
8 #include "android_webview/browser/global_tile_manager.h"
9 #include "android_webview/browser/global_tile_manager_client.h"
10 #include "android_webview/browser/parent_compositor_draw_constraints.h"
11 #include "android_webview/browser/shared_renderer_state.h"
12 #include "base/android/scoped_java_ref.h"
13 #include "base/callback.h"
14 #include "base/cancelable_callback.h"
15 #include "base/values.h"
16 #include "content/public/browser/android/synchronous_compositor.h"
17 #include "content/public/browser/android/synchronous_compositor_client.h"
18 #include "skia/ext/refptr.h"
19 #include "ui/gfx/rect.h"
20 #include "ui/gfx/vector2d_f.h"
25 struct AwDrawSWFunctionTable
;
28 class ContentViewCore
;
29 struct SynchronousCompositorMemoryPolicy
;
33 namespace android_webview
{
35 class BrowserViewRendererClient
;
37 // Delegate to perform rendering actions involving Java objects.
38 class BrowserViewRendererJavaHelper
{
40 static BrowserViewRendererJavaHelper
* GetInstance();
42 typedef base::Callback
<bool(SkCanvas
*)> RenderMethod
;
44 // Try obtaining the native SkCanvas from |java_canvas| and call
45 // |render_source| with it. If that fails, allocate an auxilary bitmap
46 // for |render_source| to render into, then copy the bitmap into
48 virtual bool RenderViaAuxilaryBitmapIfNeeded(
50 const gfx::Vector2d
& scroll_correction
,
51 const gfx::Size
& auxiliary_bitmap_size
,
52 RenderMethod render_source
) = 0;
55 virtual ~BrowserViewRendererJavaHelper() {}
58 // Interface for all the WebView-specific content rendering operations.
59 // Provides software and hardware rendering and the Capture Picture API.
60 class BrowserViewRenderer
: public content::SynchronousCompositorClient
,
61 public GlobalTileManagerClient
{
63 static void CalculateTileMemoryPolicy(bool use_zero_copy
);
66 BrowserViewRendererClient
* client
,
67 SharedRendererState
* shared_renderer_state
,
68 content::WebContents
* web_contents
,
69 const scoped_refptr
<base::SingleThreadTaskRunner
>& ui_task_runner
);
71 virtual ~BrowserViewRenderer();
73 // Main handler for view drawing: performs a SW draw immediately, or sets up
74 // a subsequent GL Draw (via BrowserViewRendererClient::RequestDrawGL) and
75 // returns true. A false return value indicates nothing was or will be drawn.
76 // |java_canvas| is the target of the draw. |is_hardware_canvas| indicates
77 // a GL Draw maybe possible on this canvas. |scroll| if the view's current
78 // scroll offset. |clip| is the canvas's clip bounds. |global_visible_rect|
79 // is the intersection of the view size and the window in window coordinates.
80 bool OnDraw(jobject java_canvas
,
81 bool is_hardware_canvas
,
82 const gfx::Vector2d
& scroll
,
83 const gfx::Rect
& global_visible_rect
);
85 // CapturePicture API methods.
86 skia::RefPtr
<SkPicture
> CapturePicture(int width
, int height
);
87 void EnableOnNewPicture(bool enabled
);
91 // View update notifications.
92 void SetIsPaused(bool paused
);
93 void SetViewVisibility(bool visible
);
94 void SetWindowVisibility(bool visible
);
95 void OnSizeChanged(int width
, int height
);
96 void OnAttachedToWindow(int width
, int height
);
97 void OnDetachedFromWindow();
99 // Sets the scale for logical<->physical pixel conversions.
100 void SetDipScale(float dip_scale
);
102 // Set the root layer scroll offset to |new_value|.
103 void ScrollTo(gfx::Vector2d new_value
);
105 // Android views hierarchy gluing.
106 bool IsVisible() const;
107 gfx::Rect
GetScreenRect() const;
108 bool attached_to_window() const { return attached_to_window_
; }
109 bool hardware_enabled() const { return hardware_enabled_
; }
110 void ReleaseHardware();
112 // Set the memory policy in shared renderer state and request the tiles from
113 // GlobalTileManager. The actually amount of memory allowed by
114 // GlobalTileManager may not be equal to what's requested in |policy|.
115 void RequestMemoryPolicy(content::SynchronousCompositorMemoryPolicy
& policy
);
117 void TrimMemory(const int level
, const bool visible
);
119 // SynchronousCompositorClient overrides.
120 virtual void DidInitializeCompositor(
121 content::SynchronousCompositor
* compositor
) OVERRIDE
;
122 virtual void DidDestroyCompositor(content::SynchronousCompositor
* compositor
)
124 virtual void SetContinuousInvalidate(bool invalidate
) OVERRIDE
;
125 virtual void DidUpdateContent() OVERRIDE
;
126 virtual gfx::Vector2dF
GetTotalRootLayerScrollOffset() OVERRIDE
;
127 virtual void UpdateRootLayerState(
128 const gfx::Vector2dF
& total_scroll_offset_dip
,
129 const gfx::Vector2dF
& max_scroll_offset_dip
,
130 const gfx::SizeF
& scrollable_size_dip
,
131 float page_scale_factor
,
132 float min_page_scale_factor
,
133 float max_page_scale_factor
) OVERRIDE
;
134 virtual bool IsExternalFlingActive() const OVERRIDE
;
135 virtual void DidOverscroll(gfx::Vector2dF accumulated_overscroll
,
136 gfx::Vector2dF latest_overscroll_delta
,
137 gfx::Vector2dF current_fling_velocity
) OVERRIDE
;
139 // GlobalTileManagerClient overrides.
140 virtual size_t GetNumTiles() const OVERRIDE
;
141 virtual void SetNumTiles(size_t num_tiles
,
142 bool effective_immediately
) OVERRIDE
;
144 void UpdateParentDrawConstraints();
147 void SetTotalRootLayerScrollOffset(gfx::Vector2dF new_value_dip
);
148 // Checks the continuous invalidate and block invalidate state, and schedule
149 // invalidates appropriately. If |force_invalidate| is true, then send a view
150 // invalidate regardless of compositor expectation.
151 void EnsureContinuousInvalidation(bool force_invalidate
);
152 bool OnDrawSoftware(jobject java_canvas
);
153 bool CompositeSW(SkCanvas
* canvas
);
155 scoped_ptr
<base::Value
> RootLayerStateAsValue(
156 const gfx::Vector2dF
& total_scroll_offset_dip
,
157 const gfx::SizeF
& scrollable_size_dip
);
159 bool OnDrawHardware(jobject java_canvas
);
160 void ReturnUnusedResource(scoped_ptr
<DrawGLInput
> input
);
161 void ReturnResourceFromParent();
163 // If we call up view invalidate and OnDraw is not called before a deadline,
164 // then we keep ticking the SynchronousCompositor so it can make progress.
165 // Do this in a two stage tick due to native MessageLoop favors delayed task,
166 // so ensure delayed task is inserted only after the draw task returns.
167 void PostFallbackTick();
168 void FallbackTickFired();
170 // Force invoke the compositor to run produce a 1x1 software frame that is
171 // immediately discarded. This is a hack to force invoke parts of the
172 // compositor that are not directly exposed here.
173 void ForceFakeCompositeSW();
175 void EnforceMemoryPolicyImmediately(
176 content::SynchronousCompositorMemoryPolicy policy
);
178 gfx::Vector2d
max_scroll_offset() const;
180 content::SynchronousCompositorMemoryPolicy
CalculateDesiredMemoryPolicy();
181 // For debug tracing or logging. Return the string representation of this
182 // view renderer's state and the |draw_info| if provided.
183 std::string
ToString(AwDrawGLInfo
* draw_info
) const;
185 BrowserViewRendererClient
* client_
;
186 SharedRendererState
* shared_renderer_state_
;
187 content::WebContents
* web_contents_
;
188 scoped_refptr
<base::SingleThreadTaskRunner
> ui_task_runner_
;
190 content::SynchronousCompositor
* compositor_
;
194 bool window_visible_
; // Only applicable if |attached_to_window_| is true.
195 bool attached_to_window_
;
196 bool hardware_enabled_
;
198 float page_scale_factor_
;
199 bool on_new_picture_enable_
;
202 gfx::Vector2d last_on_draw_scroll_offset_
;
203 gfx::Rect last_on_draw_global_visible_rect_
;
205 // The draw constraints from the parent compositor. These are only used for
207 ParentCompositorDrawConstraints parent_draw_constraints_
;
209 // When true, we should continuously invalidate and keep drawing, for example
210 // to drive animation. This value is set by the compositor and should always
211 // reflect the expectation of the compositor and not be reused for other
213 bool compositor_needs_continuous_invalidate_
;
215 // Used to block additional invalidates while one is already pending.
216 bool block_invalidates_
;
218 base::CancelableClosure post_fallback_tick_
;
219 base::CancelableClosure fallback_tick_fired_
;
224 // Current scroll offset in CSS pixels.
225 gfx::Vector2dF scroll_offset_dip_
;
227 // Max scroll offset in CSS pixels.
228 gfx::Vector2dF max_scroll_offset_dip_
;
230 // Used to prevent rounding errors from accumulating enough to generate
231 // visible skew (especially noticeable when scrolling up and down in the same
232 // spot over a period of time).
233 gfx::Vector2dF overscroll_rounding_error_
;
235 GlobalTileManager::Key tile_manager_key_
;
236 content::SynchronousCompositorMemoryPolicy memory_policy_
;
238 // The following 2 are used to construct a memory policy and set the memory
239 // policy on the shared_renderer_state_ atomically.
243 DISALLOW_COPY_AND_ASSIGN(BrowserViewRenderer
);
246 } // namespace android_webview
248 #endif // ANDROID_WEBVIEW_BROWSER_BROWSER_VIEW_RENDERER_H_