Chromium Code Reviews| 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 |