Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(272)

Side by Side Diff: content/browser/renderer_host/offscreen_canvas_compositor_frame_sink.h

Issue 2479563005: Create manager to track OffscreenCanvasSurfaceImpl instances (Closed)
Patch Set: remove compositorframesink from manager Created 4 years, 1 month ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
OLDNEW
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_COMPOSITOR_FRAME_SINK_H_ 5 #ifndef CONTENT_BROWSER_RENDERER_HOST_OFFSCREEN_CANVAS_COMPOSITOR_FRAME_SINK_H_
6 #define CONTENT_BROWSER_RENDERER_HOST_OFFSCREEN_CANVAS_COMPOSITOR_FRAME_SINK_H_ 6 #define CONTENT_BROWSER_RENDERER_HOST_OFFSCREEN_CANVAS_COMPOSITOR_FRAME_SINK_H_
7 7
8 #include "cc/surfaces/surface_factory.h" 8 #include "cc/surfaces/surface_factory.h"
9 #include "cc/surfaces/surface_factory_client.h" 9 #include "cc/surfaces/surface_factory_client.h"
10 #include "third_party/WebKit/public/platform/modules/offscreencanvas/offscreen_c anvas_surface.mojom.h" 10 #include "third_party/WebKit/public/platform/modules/offscreencanvas/offscreen_c anvas_surface.mojom.h"
11 11
12 namespace content { 12 namespace content {
13 13
14 class OffscreenCanvasCompositorFrameSink 14 class CONTENT_EXPORT OffscreenCanvasCompositorFrameSink
15 : public cc::mojom::MojoCompositorFrameSink, 15 : public cc::mojom::MojoCompositorFrameSink,
16 public cc::SurfaceFactoryClient { 16 public cc::SurfaceFactoryClient {
17 public: 17 public:
18 OffscreenCanvasCompositorFrameSink( 18 OffscreenCanvasCompositorFrameSink(
19 const cc::SurfaceId& surface_id, 19 const cc::SurfaceId& surface_id,
20 cc::mojom::MojoCompositorFrameSinkClientPtr client); 20 cc::mojom::MojoCompositorFrameSinkClientPtr client);
21 ~OffscreenCanvasCompositorFrameSink() override; 21 ~OffscreenCanvasCompositorFrameSink() override;
22 22
23 static void Create(const cc::SurfaceId& surface_id, 23 static void Create(const cc::SurfaceId& surface_id,
24 cc::mojom::MojoCompositorFrameSinkClientPtr client, 24 cc::mojom::MojoCompositorFrameSinkClientPtr client,
25 cc::mojom::MojoCompositorFrameSinkRequest request); 25 cc::mojom::MojoCompositorFrameSinkRequest request);
26 26
27 // cc::mojom::MojoCompositorFrameSink implementation. 27 // cc::mojom::MojoCompositorFrameSink implementation.
28 void SubmitCompositorFrame(cc::CompositorFrame frame) override; 28 void SubmitCompositorFrame(cc::CompositorFrame frame) override;
29 void SetNeedsBeginFrame(bool needs_begin_frame) override; 29 void SetNeedsBeginFrame(bool needs_begin_frame) override;
30 30
31 // cc::SurfaceFactoryClient implementation. 31 // cc::SurfaceFactoryClient implementation.
32 void ReturnResources(const cc::ReturnedResourceArray& resources) override; 32 void ReturnResources(const cc::ReturnedResourceArray& resources) override;
33 void WillDrawSurface(const cc::LocalFrameId& id, 33 void WillDrawSurface(const cc::LocalFrameId& id,
34 const gfx::Rect& damage_rect) override; 34 const gfx::Rect& damage_rect) override;
35 void SetBeginFrameSource(cc::BeginFrameSource* begin_frame_source) override; 35 void SetBeginFrameSource(cc::BeginFrameSource* begin_frame_source) override;
36 36
37 const cc::FrameSinkId& frame_sink_id() const {
38 return surface_id_.frame_sink_id();
39 }
40
41 base::WeakPtr<OffscreenCanvasCompositorFrameSink> GetWeakPtr() {
Fady Samuel 2016/11/14 21:15:40 Why does this need a weak ptr?
xlai (Olivia) 2016/11/15 17:16:18 Done. My mistake of not doing a clean delete after
42 return weak_factory_.GetWeakPtr();
43 }
44
37 private: 45 private:
38 void DidReceiveCompositorFrameAck(); 46 void DidReceiveCompositorFrameAck();
39 47
40 cc::SurfaceId surface_id_; 48 cc::SurfaceId surface_id_;
41 std::unique_ptr<cc::SurfaceFactory> surface_factory_; 49 std::unique_ptr<cc::SurfaceFactory> surface_factory_;
42 cc::mojom::MojoCompositorFrameSinkClientPtr client_; 50 cc::mojom::MojoCompositorFrameSinkClientPtr client_;
43 int ack_pending_count_ = 0; 51 int ack_pending_count_ = 0;
44 cc::ReturnedResourceArray surface_returned_resources_; 52 cc::ReturnedResourceArray surface_returned_resources_;
45 53
54 base::WeakPtrFactory<OffscreenCanvasCompositorFrameSink> weak_factory_;
55
46 DISALLOW_COPY_AND_ASSIGN(OffscreenCanvasCompositorFrameSink); 56 DISALLOW_COPY_AND_ASSIGN(OffscreenCanvasCompositorFrameSink);
47 }; 57 };
48 58
49 } // namespace content 59 } // namespace content
50 60
51 #endif // CONTENT_BROWSER_RENDERER_HOST_OFFSCREEN_CANVAS_COMPOSITOR_FRAME_SINK_ H_ 61 #endif // CONTENT_BROWSER_RENDERER_HOST_OFFSCREEN_CANVAS_COMPOSITOR_FRAME_SINK_ H_
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698