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_H_ | 5 #ifndef CC_SURFACES_SURFACE_H_ |
6 #define CC_SURFACES_SURFACE_H_ | 6 #define CC_SURFACES_SURFACE_H_ |
7 | 7 |
8 #include "base/macros.h" | 8 #include "base/macros.h" |
9 #include "base/memory/scoped_ptr.h" | 9 #include "base/memory/scoped_ptr.h" |
| 10 #include "cc/surfaces/surface_id.h" |
10 #include "cc/surfaces/surfaces_export.h" | 11 #include "cc/surfaces/surfaces_export.h" |
11 #include "ui/gfx/size.h" | 12 #include "ui/gfx/size.h" |
12 | 13 |
13 namespace cc { | 14 namespace cc { |
14 class CompositorFrame; | 15 class CompositorFrame; |
15 class SurfaceManager; | 16 class SurfaceManager; |
16 class SurfaceClient; | 17 class SurfaceClient; |
17 | 18 |
18 class CC_SURFACES_EXPORT Surface { | 19 class CC_SURFACES_EXPORT Surface { |
19 public: | 20 public: |
20 Surface(SurfaceManager* manager, | 21 Surface(SurfaceManager* manager, |
21 SurfaceClient* client, | 22 SurfaceClient* client, |
22 const gfx::Size& size); | 23 const gfx::Size& size); |
23 ~Surface(); | 24 ~Surface(); |
24 | 25 |
25 const gfx::Size& size() const { return size_; } | 26 const gfx::Size& size() const { return size_; } |
26 int surface_id() const { return surface_id_; } | 27 SurfaceId surface_id() const { return surface_id_; } |
27 | 28 |
28 void QueueFrame(scoped_ptr<CompositorFrame> frame); | 29 void QueueFrame(scoped_ptr<CompositorFrame> frame); |
29 // Returns the most recent frame that is eligible to be rendered. | 30 // Returns the most recent frame that is eligible to be rendered. |
30 CompositorFrame* GetEligibleFrame(); | 31 CompositorFrame* GetEligibleFrame(); |
31 | 32 |
32 private: | 33 private: |
33 SurfaceManager* manager_; | 34 SurfaceManager* manager_; |
34 SurfaceClient* client_; | 35 SurfaceClient* client_; |
35 gfx::Size size_; | 36 gfx::Size size_; |
36 int surface_id_; | 37 SurfaceId surface_id_; |
37 // TODO(jamesr): Support multiple frames in flight. | 38 // TODO(jamesr): Support multiple frames in flight. |
38 scoped_ptr<CompositorFrame> current_frame_; | 39 scoped_ptr<CompositorFrame> current_frame_; |
39 | 40 |
40 DISALLOW_COPY_AND_ASSIGN(Surface); | 41 DISALLOW_COPY_AND_ASSIGN(Surface); |
41 }; | 42 }; |
42 | 43 |
43 } // namespace cc | 44 } // namespace cc |
44 | 45 |
45 #endif // CC_SURFACES_SURFACE_H_ | 46 #endif // CC_SURFACES_SURFACE_H_ |
OLD | NEW |