OLD | NEW |
---|---|
1 // Copyright 2016 The Chromium Authors. All rights reserved. | 1 // Copyright 2016 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 CONTENT_BROWSER_COMPOSITOR_MUS_BROWSER_COMPOSITOR_OUTPUT_SURFACE_H_ | 5 #ifndef CONTENT_BROWSER_COMPOSITOR_MUS_BROWSER_COMPOSITOR_OUTPUT_SURFACE_H_ |
6 #define CONTENT_BROWSER_COMPOSITOR_MUS_BROWSER_COMPOSITOR_OUTPUT_SURFACE_H_ | 6 #define CONTENT_BROWSER_COMPOSITOR_MUS_BROWSER_COMPOSITOR_OUTPUT_SURFACE_H_ |
7 | 7 |
8 #include <memory> | 8 #include <memory> |
9 #include <vector> | 9 #include <vector> |
10 | 10 |
11 #include "base/macros.h" | 11 #include "base/macros.h" |
12 #include "cc/output/compositor_frame_sink_client.h" | |
12 #include "content/browser/compositor/gpu_browser_compositor_output_surface.h" | 13 #include "content/browser/compositor/gpu_browser_compositor_output_surface.h" |
13 #include "gpu/command_buffer/common/mailbox.h" | 14 #include "gpu/command_buffer/common/mailbox.h" |
14 #include "gpu/ipc/common/surface_handle.h" | 15 #include "gpu/ipc/common/surface_handle.h" |
15 #include "services/ui/public/cpp/window_surface_client.h" | 16 #include "services/ui/public/cpp/window_surface_client.h" |
16 | 17 |
17 namespace ui { | 18 namespace ui { |
18 class Window; | 19 class Window; |
19 class WindowSurface; | 20 class CompositorFrameSink; |
rjkroege
2016/10/20 21:33:17
alphabetical order
Fady Samuel
2016/10/20 23:04:10
Done.
| |
20 } | 21 } |
21 | 22 |
22 namespace content { | 23 namespace content { |
23 | 24 |
24 // Adapts a WebGraphicsContext3DCommandBufferImpl into a | 25 // Adapts a WebGraphicsContext3DCommandBufferImpl into a |
25 // cc::OutputSurface that also handles vsync parameter updates | 26 // cc::OutputSurface that also handles vsync parameter updates |
26 // arriving from the GPU process. | 27 // arriving from the GPU process. |
27 class MusBrowserCompositorOutputSurface | 28 class MusBrowserCompositorOutputSurface |
28 : public GpuBrowserCompositorOutputSurface, | 29 : public GpuBrowserCompositorOutputSurface, |
29 public ui::WindowSurfaceClient { | 30 public cc::CompositorFrameSinkClient { |
30 public: | 31 public: |
31 MusBrowserCompositorOutputSurface( | 32 MusBrowserCompositorOutputSurface( |
32 ui::Window* window, | 33 ui::Window* window, |
33 scoped_refptr<ContextProviderCommandBuffer> context, | 34 scoped_refptr<ContextProviderCommandBuffer> context, |
34 scoped_refptr<ui::CompositorVSyncManager> vsync_manager, | 35 scoped_refptr<ui::CompositorVSyncManager> vsync_manager, |
35 cc::SyntheticBeginFrameSource* begin_frame_source, | 36 cc::SyntheticBeginFrameSource* begin_frame_source, |
36 std::unique_ptr<display_compositor::CompositorOverlayCandidateValidator> | 37 std::unique_ptr<display_compositor::CompositorOverlayCandidateValidator> |
37 overlay_candidate_validator); | 38 overlay_candidate_validator); |
38 | 39 |
39 ~MusBrowserCompositorOutputSurface() override; | 40 ~MusBrowserCompositorOutputSurface() override; |
40 | 41 |
41 protected: | 42 protected: |
42 // cc::OutputSurface implementation. | 43 // cc::OutputSurface implementation. |
43 void SwapBuffers(cc::OutputSurfaceFrame frame) override; | 44 void SwapBuffers(cc::OutputSurfaceFrame frame) override; |
44 bool BindToClient(cc::OutputSurfaceClient* client) override; | 45 bool BindToClient(cc::OutputSurfaceClient* client) override; |
45 | 46 |
46 // ui::WindowSurfaceClient: | 47 // ui::CompositorFrameSinkClient: |
rjkroege
2016/10/20 21:33:17
either it's in ui or cc. So this line is wrong?
Fady Samuel
2016/10/20 23:04:10
heh, cc:: fixed.
| |
47 void OnResourcesReturned(ui::WindowSurface* surface, | 48 void SetBeginFrameSource(cc::BeginFrameSource* source) override; |
48 const cc::ReturnedResourceArray& resources) override; | 49 void ReclaimResources(const cc::ReturnedResourceArray& resources) override; |
50 void SetTreeActivationCallback(const base::Closure& callback) override; | |
51 void DidReceiveCompositorFrameAck() override; | |
52 void DidLoseCompositorFrameSink() override; | |
53 void OnDraw(const gfx::Transform& transform, | |
54 const gfx::Rect& viewport, | |
55 bool resourceless_software_draw) override; | |
56 void SetMemoryPolicy(const cc::ManagedMemoryPolicy& policy) override; | |
57 void SetExternalTilePriorityConstraints( | |
58 const gfx::Rect& viewport_rect, | |
59 const gfx::Transform& transform) override; | |
49 | 60 |
50 private: | 61 private: |
51 uint32_t AllocateResourceId(); | 62 uint32_t AllocateResourceId(); |
52 void FreeResourceId(uint32_t id); | 63 void FreeResourceId(uint32_t id); |
53 const gpu::Mailbox& GetMailboxFromResourceId(uint32_t id); | 64 const gpu::Mailbox& GetMailboxFromResourceId(uint32_t id); |
54 | 65 |
55 ui::Window* ui_window_; | 66 ui::Window* ui_window_; |
56 std::unique_ptr<ui::WindowSurface> ui_window_surface_; | 67 std::unique_ptr<ui::CompositorFrameSink> ui_compositor_frame_sink_; |
57 std::vector<uint32_t> free_resource_ids_; | 68 std::vector<uint32_t> free_resource_ids_; |
58 std::vector<gpu::Mailbox> mailboxes_; | 69 std::vector<gpu::Mailbox> mailboxes_; |
59 | 70 |
60 DISALLOW_COPY_AND_ASSIGN(MusBrowserCompositorOutputSurface); | 71 DISALLOW_COPY_AND_ASSIGN(MusBrowserCompositorOutputSurface); |
61 }; | 72 }; |
62 | 73 |
63 } // namespace content | 74 } // namespace content |
64 | 75 |
65 #endif // CONTENT_BROWSER_COMPOSITOR_MUS_BROWSER_COMPOSITOR_OUTPUT_SURFACE_H_ | 76 #endif // CONTENT_BROWSER_COMPOSITOR_MUS_BROWSER_COMPOSITOR_OUTPUT_SURFACE_H_ |
OLD | NEW |