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_RENDERER_HOST_OFFSCREEN_CANVAS_PROVIDER_IMPL_H_ | 5 #ifndef CONTENT_BROWSER_RENDERER_HOST_OFFSCREEN_CANVAS_PROVIDER_IMPL_H_ |
| 6 #define CONTENT_BROWSER_RENDERER_HOST_OFFSCREEN_CANVAS_PROVIDER_IMPL_H_ | 6 #define CONTENT_BROWSER_RENDERER_HOST_OFFSCREEN_CANVAS_PROVIDER_IMPL_H_ |
| 7 | 7 |
| 8 #include <memory> | |
| 9 #include <unordered_map> | |
| 10 | |
| 8 #include "cc/surfaces/frame_sink_id.h" | 11 #include "cc/surfaces/frame_sink_id.h" |
| 12 #include "content/common/content_export.h" | |
| 9 #include "mojo/public/cpp/bindings/binding_set.h" | 13 #include "mojo/public/cpp/bindings/binding_set.h" |
| 10 #include "third_party/WebKit/public/platform/modules/offscreencanvas/offscreen_c anvas_surface.mojom.h" | 14 #include "third_party/WebKit/public/platform/modules/offscreencanvas/offscreen_c anvas_surface.mojom.h" |
| 11 | 15 |
| 12 namespace content { | 16 namespace content { |
| 13 | 17 |
| 18 class OffscreenCanvasSurfaceImpl; | |
| 19 | |
| 14 // Creates OffscreenCanvasSurfaces and MojoCompositorFrameSinks for a renderer. | 20 // Creates OffscreenCanvasSurfaces and MojoCompositorFrameSinks for a renderer. |
| 15 class OffscreenCanvasProviderImpl | 21 class CONTENT_EXPORT OffscreenCanvasProviderImpl |
| 16 : public blink::mojom::OffscreenCanvasProvider { | 22 : public blink::mojom::OffscreenCanvasProvider { |
| 17 public: | 23 public: |
| 18 explicit OffscreenCanvasProviderImpl(uint32_t renderer_client_id); | 24 explicit OffscreenCanvasProviderImpl(uint32_t renderer_client_id); |
| 19 ~OffscreenCanvasProviderImpl() override; | 25 ~OffscreenCanvasProviderImpl() override; |
| 20 | 26 |
| 21 void Add(blink::mojom::OffscreenCanvasProviderRequest request); | 27 void Add(blink::mojom::OffscreenCanvasProviderRequest request); |
| 22 | 28 |
| 29 void DestroyOffscreenCanvasSurface(const cc::FrameSinkId& frame_sink_id); | |
|
Fady Samuel
2017/04/28 04:58:00
Should this be passed by value to avoid use-after-
kylechar
2017/05/01 19:07:48
Done.
| |
| 30 | |
| 23 // blink::mojom::OffscreenCanvasProvider implementation. | 31 // blink::mojom::OffscreenCanvasProvider implementation. |
| 24 void CreateOffscreenCanvasSurface( | 32 void CreateOffscreenCanvasSurface( |
| 25 const cc::FrameSinkId& parent_frame_sink_id, | 33 const cc::FrameSinkId& parent_frame_sink_id, |
| 26 const cc::FrameSinkId& frame_sink_id, | 34 const cc::FrameSinkId& frame_sink_id, |
| 27 blink::mojom::OffscreenCanvasSurfaceClientPtr client, | 35 blink::mojom::OffscreenCanvasSurfaceClientPtr client, |
| 28 blink::mojom::OffscreenCanvasSurfaceRequest request) override; | 36 blink::mojom::OffscreenCanvasSurfaceRequest request) override; |
| 29 void CreateCompositorFrameSink( | 37 void CreateCompositorFrameSink( |
| 30 const cc::FrameSinkId& frame_sink_id, | 38 const cc::FrameSinkId& frame_sink_id, |
| 31 cc::mojom::MojoCompositorFrameSinkClientPtr client, | 39 cc::mojom::MojoCompositorFrameSinkClientPtr client, |
| 32 cc::mojom::MojoCompositorFrameSinkRequest request) override; | 40 cc::mojom::MojoCompositorFrameSinkRequest request) override; |
| 33 | 41 |
| 34 private: | 42 private: |
| 43 friend class OffscreenCanvasProviderImplTest; | |
| 44 | |
| 35 // FrameSinkIds for offscreen canvas must use the renderer client id. | 45 // FrameSinkIds for offscreen canvas must use the renderer client id. |
| 36 const uint32_t renderer_client_id_; | 46 const uint32_t renderer_client_id_; |
| 37 | 47 |
| 38 mojo::BindingSet<blink::mojom::OffscreenCanvasProvider> bindings_; | 48 mojo::BindingSet<blink::mojom::OffscreenCanvasProvider> bindings_; |
| 39 | 49 |
| 50 std::unordered_map<cc::FrameSinkId, | |
| 51 std::unique_ptr<OffscreenCanvasSurfaceImpl>, | |
| 52 cc::FrameSinkIdHash> | |
| 53 surfaces_; | |
|
Fady Samuel
2017/04/28 04:58:00
I hate how we're overloading the term surface here
kylechar
2017/05/01 19:07:48
Agreed. I think it should be OffscreenCanvasSurfac
| |
| 54 | |
| 40 DISALLOW_COPY_AND_ASSIGN(OffscreenCanvasProviderImpl); | 55 DISALLOW_COPY_AND_ASSIGN(OffscreenCanvasProviderImpl); |
| 41 }; | 56 }; |
| 42 | 57 |
| 43 } // namespace content | 58 } // namespace content |
| 44 | 59 |
| 45 #endif // CONTENT_BROWSER_RENDERER_HOST_OFFSCREEN_CANVAS_PROVIDER_IMPL_H_ | 60 #endif // CONTENT_BROWSER_RENDERER_HOST_OFFSCREEN_CANVAS_PROVIDER_IMPL_H_ |
| OLD | NEW |