// Copyright (c) 2013 The Chromium Authors. All rights reserved. // Use of this source code is governed by a BSD-style license that can be // found in the LICENSE file. #ifndef CONTENT_RENDERER_GPU_RENDER_WIDGET_COMPOSITOR_H_ #define CONTENT_RENDERER_GPU_RENDER_WIDGET_COMPOSITOR_H_ #include "base/callback.h" #include "base/memory/weak_ptr.h" #include "base/time/time.h" #include "base/values.h" #include "cc/input/top_controls_state.h" #include "cc/output/managed_memory_policy.h" #include "cc/output/swap_promise.h" #include "cc/trees/layer_tree_host_client.h" #include "cc/trees/layer_tree_host_single_thread_client.h" #include "cc/trees/layer_tree_settings.h" #include "cc/trees/swap_promise_monitor.h" #include "content/common/content_export.h" #include "content/renderer/gpu/compositor_dependencies.h" #include "third_party/WebKit/public/platform/WebLayerTreeView.h" #include "third_party/skia/include/core/SkBitmap.h" #include "ui/gfx/geometry/rect.h" namespace ui { class LatencyInfo; } namespace cc { class CopyOutputRequest; class InputHandler; class Layer; class LayerTreeHost; } namespace content { class RenderWidget; class CONTENT_EXPORT RenderWidgetCompositor : NON_EXPORTED_BASE(public blink::WebLayerTreeView), NON_EXPORTED_BASE(public cc::LayerTreeHostClient), NON_EXPORTED_BASE(public cc::LayerTreeHostSingleThreadClient) { public: // Attempt to construct and initialize a compositor instance for the widget // with the given settings. Returns NULL if initialization fails. static scoped_ptr Create( RenderWidget* widget, CompositorDependencies* compositor_deps); ~RenderWidgetCompositor() override; void SetNeverVisible(); const base::WeakPtr& GetInputHandler(); bool BeginMainFrameRequested() const; void SetNeedsDisplayOnAllLayers(); void SetRasterizeOnlyVisibleContent(); void SetNeedsRedrawRect(gfx::Rect damage_rect); // Like setNeedsRedraw but forces the frame to be drawn, without early-outs. // Redraw will be forced after the next commit void SetNeedsForcedRedraw(); // Calling CreateLatencyInfoSwapPromiseMonitor() to get a scoped // LatencyInfoSwapPromiseMonitor. During the life time of the // LatencyInfoSwapPromiseMonitor, if SetNeedsCommit() or // SetNeedsUpdateLayers() is called on LayerTreeHost, the original latency // info will be turned into a LatencyInfoSwapPromise. scoped_ptr CreateLatencyInfoSwapPromiseMonitor( ui::LatencyInfo* latency); // Calling QueueSwapPromise() to directly queue a SwapPromise into // LayerTreeHost. void QueueSwapPromise(scoped_ptr swap_promise); int GetSourceFrameNumber() const; void SetNeedsUpdateLayers(); void SetNeedsCommit(); void NotifyInputThrottledUntilCommit(); const cc::Layer* GetRootLayer() const; int ScheduleMicroBenchmark( const std::string& name, scoped_ptr value, const base::Callback)>& callback); bool SendMessageToMicroBenchmark(int id, scoped_ptr value); void SetSurfaceIdNamespace(uint32_t surface_id_namespace); cc::ManagedMemoryPolicy GetGpuMemoryPolicy( const cc::ManagedMemoryPolicy& policy); // WebLayerTreeView implementation. void setRootLayer(const blink::WebLayer& layer) override; void clearRootLayer() override; void attachCompositorAnimationTimeline( blink::WebCompositorAnimationTimeline* compositor_timeline) override; void detachCompositorAnimationTimeline( blink::WebCompositorAnimationTimeline* compositor_timeline) override; virtual void setViewportSize( const blink::WebSize& unused_deprecated, const blink::WebSize& device_viewport_size); void setViewportSize(const blink::WebSize& device_viewport_size) override; virtual blink::WebFloatPoint adjustEventPointForPinchZoom( const blink::WebFloatPoint& point) const; void setDeviceScaleFactor(float device_scale) override; void setBackgroundColor(blink::WebColor color) override; void setHasTransparentBackground(bool transparent) override; void setVisible(bool visible) override; void setPageScaleFactorAndLimits(float page_scale_factor, float minimum, float maximum) override; void startPageScaleAnimation(const blink::WebPoint& destination, bool use_anchor, float new_page_scale, double duration_sec) override; void heuristicsForGpuRasterizationUpdated(bool matches_heuristics) override; void setNeedsAnimate() override; void setNeedsBeginFrame() override; void setNeedsCompositorUpdate() override; void didStopFlinging() override; void layoutAndPaintAsync( blink::WebLayoutAndPaintAsyncCallback* callback) override; void compositeAndReadbackAsync( blink::WebCompositeAndReadbackAsyncCallback* callback) override; void setDeferCommits(bool defer_commits) override; void registerForAnimations(blink::WebLayer* layer) override; void registerViewportLayers( const blink::WebLayer* overscrollElasticityLayer, const blink::WebLayer* pageScaleLayer, const blink::WebLayer* innerViewportScrollLayer, const blink::WebLayer* outerViewportScrollLayer) override; void clearViewportLayers() override; void registerSelection(const blink::WebSelection& selection) override; void clearSelection() override; int layerTreeId() const override; void setShowFPSCounter(bool show) override; void setShowPaintRects(bool show) override; void setShowDebugBorders(bool show) override; void setShowScrollBottleneckRects(bool show) override; void updateTopControlsState(blink::WebTopControlsState constraints, blink::WebTopControlsState current, bool animate) override; void setTopControlsHeight(float height, bool shrink) override; void setTopControlsShownRatio(float) override; // cc::LayerTreeHostClient implementation. void WillBeginMainFrame() override; void DidBeginMainFrame() override; void BeginMainFrame(const cc::BeginFrameArgs& args) override; void BeginMainFrameNotExpectedSoon() override; void Layout() override; void ApplyViewportDeltas(const gfx::Vector2dF& inner_delta, const gfx::Vector2dF& outer_delta, const gfx::Vector2dF& elastic_overscroll_delta, float page_scale, float top_controls_delta) override; void RequestNewOutputSurface() override; void DidInitializeOutputSurface() override; void DidFailToInitializeOutputSurface() override; void WillCommit() override; void DidCommit() override; void DidCommitAndDrawFrame() override; void DidCompleteSwapBuffers() override; void DidCompletePageScaleAnimation() override; void RecordFrameTimingEvents( scoped_ptr composite_events, scoped_ptr main_frame_events) override; // cc::LayerTreeHostSingleThreadClient implementation. void ScheduleAnimation() override; void DidPostSwapBuffers() override; void DidAbortSwapBuffers() override; enum { OUTPUT_SURFACE_RETRIES_BEFORE_FALLBACK = 4, MAX_OUTPUT_SURFACE_RETRIES = 5, }; protected: RenderWidgetCompositor(RenderWidget* widget, CompositorDependencies* compositor_deps); void Initialize(); cc::LayerTreeHost* layer_tree_host() { return layer_tree_host_.get(); } private: void LayoutAndUpdateLayers(); void InvokeLayoutAndPaintCallback(); bool CompositeIsSynchronous() const; void SynchronouslyComposite(); int num_failed_recreate_attempts_; RenderWidget* widget_; CompositorDependencies* compositor_deps_; scoped_ptr layer_tree_host_; bool never_visible_; blink::WebLayoutAndPaintAsyncCallback* layout_and_paint_async_callback_; scoped_ptr temporary_copy_output_request_; base::WeakPtrFactory weak_factory_; }; } // namespace content #endif // CONTENT_RENDERER_GPU_RENDER_WIDGET_COMPOSITOR_H_