// Copyright 2014 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_BROWSER_COMPOSITOR_BROWSER_COMPOSITOR_VIEW_MAC_H_ #define CONTENT_BROWSER_COMPOSITOR_BROWSER_COMPOSITOR_VIEW_MAC_H_ #include #include "cc/output/software_frame_data.h" #include "skia/ext/platform_canvas.h" #include "ui/compositor/compositor.h" #include "ui/events/latency_info.h" #include "ui/gfx/geometry/size.h" namespace content { class BrowserCompositorViewMacInternal; // The interface through which BrowserCompositorViewMac calls back into // RenderWidgetHostViewMac (or any other structure that wishes to draw a // NSView backed by a ui::Compositor). class BrowserCompositorViewMacClient { public: // Drawing is usually throttled by the rate at which CoreAnimation draws // frames to the screen. This can be used to disable throttling. virtual bool BrowserCompositorViewShouldAckImmediately() const = 0; // Called when a frame is drawn, and used to pass latency info back to the // renderer (if any). virtual void BrowserCompositorViewFrameSwapped( const std::vector& latency_info) = 0; // Used to install the ui::Compositor-backed NSView as a child of its parent // view. virtual NSView* BrowserCompositorSuperview() = 0; // Used to install the root ui::Layer into the ui::Compositor. virtual ui::Layer* BrowserCompositorRootLayer() = 0; }; // The class to hold a ui::Compositor-backed NSView. Because a ui::Compositor // is expensive in terms of resources and re-allocating a ui::Compositor is // expensive in terms of work, this class is largely used to manage recycled // instances of BrowserCompositorViewCocoa, which actually is a NSView and // has a ui::Compositor instance. class BrowserCompositorViewMac { public: // This will install the NSView which is drawn by the ui::Compositor into // the NSView provided by the client. explicit BrowserCompositorViewMac(BrowserCompositorViewMacClient* client); ~BrowserCompositorViewMac(); // The ui::Compositor being used to render the NSView. ui::Compositor* GetCompositor() const; // The client (used by the BrowserCompositorViewCocoa to access the client). BrowserCompositorViewMacClient* GetClient() const { return client_; } // Return true if the last frame swapped has a size in DIP of |dip_size|. bool HasFrameOfSize(const gfx::Size& dip_size) const; // Mark a bracket in which new frames are pumped in a restricted nested run // loop because the the target window is resizing or because the view is being // shown after previously being hidden. void BeginPumpingFrames(); void EndPumpingFrames(); static void GotAcceleratedFrame( gfx::AcceleratedWidget widget, uint64 surface_handle, int surface_id, const std::vector& latency_info, gfx::Size pixel_size, float scale_factor, int gpu_host_id, int gpu_route_id); static void GotSoftwareFrame( gfx::AcceleratedWidget widget, cc::SoftwareFrameData* frame_data, float scale_factor, SkCanvas* canvas); private: BrowserCompositorViewMacClient* client_; scoped_ptr internal_view_; }; // A class to keep around whenever a BrowserCompositorViewMac may be created. // While at least one instance of this class exists, a spare // BrowserCompositorViewCocoa will be kept around to be recycled so that the // next BrowserCompositorViewMac to be created will be be created quickly. class BrowserCompositorViewPlaceholderMac { public: BrowserCompositorViewPlaceholderMac(); ~BrowserCompositorViewPlaceholderMac(); }; } // namespace content #endif // CONTENT_BROWSER_COMPOSITOR_BROWSER_COMPOSITOR_VIEW_MAC_H_