OLD | NEW |
---|---|
1 // Copyright 2014 The Chromium Authors. All rights reserved. | 1 // Copyright 2014 The Chromium Authors. All rights reserved. |
2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
4 | 4 |
5 #ifndef CC_SURFACES_SURFACE_DISPLAY_OUTPUT_SURFACE_H_ | 5 #ifndef CC_SURFACES_DIRECT_COMPOSITOR_FRAME_SINK_H_ |
6 #define CC_SURFACES_SURFACE_DISPLAY_OUTPUT_SURFACE_H_ | 6 #define CC_SURFACES_DIRECT_COMPOSITOR_FRAME_SINK_H_ |
7 | 7 |
8 #include "base/macros.h" | 8 #include "base/macros.h" |
9 #include "base/threading/thread_checker.h" | 9 #include "base/threading/thread_checker.h" |
10 #include "cc/output/output_surface.h" | 10 #include "cc/output/compositor_frame_sink.h" |
11 #include "cc/surfaces/display_client.h" | 11 #include "cc/surfaces/display_client.h" |
12 #include "cc/surfaces/surface_factory.h" | 12 #include "cc/surfaces/surface_factory.h" |
13 #include "cc/surfaces/surface_factory_client.h" | 13 #include "cc/surfaces/surface_factory_client.h" |
14 #include "cc/surfaces/surfaces_export.h" | 14 #include "cc/surfaces/surfaces_export.h" |
15 | 15 |
16 namespace cc { | 16 namespace cc { |
17 class Display; | 17 class Display; |
18 class SurfaceIdAllocator; | 18 class SurfaceIdAllocator; |
19 class SurfaceManager; | 19 class SurfaceManager; |
20 | 20 |
21 // This class is maps a compositor OutputSurface to the surface system's Display | 21 // This class submits compositor frames to an in-process Display, with the |
22 // concept, allowing a compositor client to submit frames for a native root | 22 // client's frame being the root surface of the Display. |
23 // window or physical display. | 23 class CC_SURFACES_EXPORT DirectCompositorFrameSink |
24 class CC_SURFACES_EXPORT SurfaceDisplayOutputSurface | 24 : public CompositorFrameSink, |
25 : public OutputSurface, | |
26 public SurfaceFactoryClient, | 25 public SurfaceFactoryClient, |
27 public NON_EXPORTED_BASE(DisplayClient) { | 26 public NON_EXPORTED_BASE(DisplayClient) { |
28 public: | 27 public: |
29 // The underlying Display and SurfaceManager must outlive this class. | 28 // The underlying Display and SurfaceManager must outlive this class. |
enne (OOO)
2016/09/14 00:35:44
(and allocator?)
| |
30 SurfaceDisplayOutputSurface( | 29 DirectCompositorFrameSink( |
31 SurfaceManager* surface_manager, | 30 SurfaceManager* surface_manager, |
32 SurfaceIdAllocator* allocator, | 31 SurfaceIdAllocator* allocator, |
33 Display* display, | 32 Display* display, |
34 scoped_refptr<ContextProvider> context_provider, | 33 scoped_refptr<ContextProvider> context_provider, |
35 scoped_refptr<ContextProvider> worker_context_provider); | 34 scoped_refptr<ContextProvider> worker_context_provider); |
36 SurfaceDisplayOutputSurface( | 35 DirectCompositorFrameSink( |
37 SurfaceManager* surface_manager, | 36 SurfaceManager* surface_manager, |
38 SurfaceIdAllocator* allocator, | 37 SurfaceIdAllocator* allocator, |
39 Display* display, | 38 Display* display, |
40 scoped_refptr<VulkanContextProvider> vulkan_context_provider); | 39 scoped_refptr<VulkanContextProvider> vulkan_context_provider); |
41 ~SurfaceDisplayOutputSurface() override; | 40 ~DirectCompositorFrameSink() override; |
42 | 41 |
43 // OutputSurface implementation. | 42 // CompositorFrameSink implementation. |
44 void SwapBuffers(CompositorFrame frame) override; | 43 void SwapBuffers(CompositorFrame frame) override; |
45 bool BindToClient(OutputSurfaceClient* client) override; | 44 bool BindToClient(CompositorFrameSinkClient* client) override; |
46 void ForceReclaimResources() override; | 45 void ForceReclaimResources() override; |
47 void DetachFromClient() override; | 46 void DetachFromClient() override; |
48 void BindFramebuffer() override; | 47 void BindFramebuffer() override; |
49 uint32_t GetFramebufferCopyTextureFormat() override; | 48 uint32_t GetFramebufferCopyTextureFormat() override; |
50 | 49 |
51 // SurfaceFactoryClient implementation. | 50 // SurfaceFactoryClient implementation. |
52 void ReturnResources(const ReturnedResourceArray& resources) override; | 51 void ReturnResources(const ReturnedResourceArray& resources) override; |
53 void SetBeginFrameSource(BeginFrameSource* begin_frame_source) override; | 52 void SetBeginFrameSource(BeginFrameSource* begin_frame_source) override; |
54 | 53 |
55 // DisplayClient implementation. | 54 // DisplayClient implementation. |
56 void DisplayOutputSurfaceLost() override; | 55 void DisplayOutputSurfaceLost() override; |
57 void DisplayWillDrawAndSwap(bool will_draw_and_swap, | 56 void DisplayWillDrawAndSwap(bool will_draw_and_swap, |
58 const RenderPassList& render_passes) override; | 57 const RenderPassList& render_passes) override; |
59 void DisplayDidDrawAndSwap() override; | 58 void DisplayDidDrawAndSwap() override; |
60 | 59 |
61 private: | 60 private: |
62 void DidDrawCallback(); | 61 void DidDrawCallback(); |
63 | 62 |
64 // This class is only meant to be used on a single thread. | 63 // This class is only meant to be used on a single thread. |
65 base::ThreadChecker thread_checker_; | 64 base::ThreadChecker thread_checker_; |
66 | 65 |
67 SurfaceManager* surface_manager_; | 66 SurfaceManager* surface_manager_; |
68 SurfaceIdAllocator* surface_id_allocator_; | 67 SurfaceIdAllocator* surface_id_allocator_; |
69 Display* display_; | 68 Display* display_; |
70 SurfaceFactory factory_; | 69 SurfaceFactory factory_; |
71 SurfaceId delegated_surface_id_; | 70 SurfaceId delegated_surface_id_; |
72 gfx::Size last_swap_frame_size_; | 71 gfx::Size last_swap_frame_size_; |
73 bool output_surface_lost_ = false; | 72 bool is_lost_ = false; |
74 | 73 |
75 DISALLOW_COPY_AND_ASSIGN(SurfaceDisplayOutputSurface); | 74 DISALLOW_COPY_AND_ASSIGN(DirectCompositorFrameSink); |
76 }; | 75 }; |
77 | 76 |
78 } // namespace cc | 77 } // namespace cc |
79 | 78 |
80 #endif // CC_SURFACES_SURFACE_DISPLAY_OUTPUT_SURFACE_H_ | 79 #endif // CC_SURFACES_DIRECT_COMPOSITOR_FRAME_SINK_H_ |
OLD | NEW |