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

Side by Side Diff: cc/layers/surface_layer.h

Issue 2514033002: Introducing SurfaceReferenceFactory (Closed)
Patch Set: 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
« no previous file with comments | « blimp/client/core/compositor/blimp_compositor.cc ('k') | cc/layers/surface_layer.cc » ('j') | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
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_LAYERS_SURFACE_LAYER_H_ 5 #ifndef CC_LAYERS_SURFACE_LAYER_H_
6 #define CC_LAYERS_SURFACE_LAYER_H_ 6 #define CC_LAYERS_SURFACE_LAYER_H_
7 7
8 #include "base/macros.h" 8 #include "base/macros.h"
9 #include "cc/base/cc_export.h" 9 #include "cc/base/cc_export.h"
10 #include "cc/layers/layer.h" 10 #include "cc/layers/layer.h"
11 #include "cc/surfaces/surface_id.h" 11 #include "cc/surfaces/surface_id.h"
12 #include "cc/surfaces/surface_info.h"
12 #include "cc/surfaces/surface_sequence.h" 13 #include "cc/surfaces/surface_sequence.h"
13 #include "ui/gfx/geometry/size.h" 14 #include "ui/gfx/geometry/size.h"
14 15
15 namespace cc { 16 namespace cc {
16 17
17 // A layer that renders a surface referencing the output of another compositor 18 // A layer that renders a surface referencing the output of another compositor
18 // instance or client. 19 // instance or client.
19 class CC_EXPORT SurfaceLayer : public Layer { 20 class CC_EXPORT SurfaceLayer : public Layer {
20 public: 21 public:
21 // This callback is run when a SurfaceSequence needs to be satisfied, but 22 // This callback is run when a SurfaceSequence needs to be satisfied, but
22 // the parent compositor is unable to. It can be called on either the main 23 // the parent compositor is unable to. It can be called on either the main
23 // or impl threads. 24 // or impl threads.
24 using SatisfyCallback = base::Callback<void(const SurfaceSequence&)>; 25 using SatisfyCallback = base::Callback<void(const SurfaceSequence&)>;
25 26
26 // This callback is run to require that a specific SurfaceSequence is 27 // This callback is run to require that a specific SurfaceSequence is
27 // received before a SurfaceId is destroyed. 28 // received before a SurfaceId is destroyed.
28 using RequireCallback = 29 using RequireCallback =
29 base::Callback<void(const SurfaceId&, const SurfaceSequence&)>; 30 base::Callback<void(const SurfaceId&, const SurfaceSequence&)>;
30 31
31 static scoped_refptr<SurfaceLayer> Create( 32 static scoped_refptr<SurfaceLayer> Create(
32 const SatisfyCallback& satisfy_callback, 33 const SatisfyCallback& satisfy_callback,
33 const RequireCallback& require_callback); 34 const RequireCallback& require_callback);
34 35
35 void SetSurfaceId(const SurfaceId& surface_id, 36 void SetSurfaceInfo(SurfaceInfo surface_info);
Fady Samuel 2016/11/21 15:59:03 void SetSurfaceInfo(std::unique_ptr<SurfaceInfo> s
36 float scale,
37 const gfx::Size& size);
38 37
39 // Layer overrides. 38 // Layer overrides.
40 std::unique_ptr<LayerImpl> CreateLayerImpl(LayerTreeImpl* tree_impl) override; 39 std::unique_ptr<LayerImpl> CreateLayerImpl(LayerTreeImpl* tree_impl) override;
41 void SetLayerTreeHost(LayerTreeHost* host) override; 40 void SetLayerTreeHost(LayerTreeHost* host) override;
42 void PushPropertiesTo(LayerImpl* layer) override; 41 void PushPropertiesTo(LayerImpl* layer) override;
43 42
44 SurfaceId surface_id() const { return surface_id_; } 43 SurfaceInfo surface_info() { return surface_info_; }
Fady Samuel 2016/11/21 15:59:03 This should be readonly. const SurfaceInfo& surfa
45 const gfx::Size& surface_size() const { return surface_size_; } 44 SurfaceId surface_id() const { return surface_info_.id(); }
46 float surface_scale() const { return surface_scale_; } 45 const gfx::Size& surface_size() const { return surface_info_.size(); }
46 float surface_scale() const { return surface_info_.scale(); }
47 47
48 const SatisfyCallback& satisfy_callback() const { return satisfy_callback_; } 48 const SatisfyCallback& satisfy_callback() const { return satisfy_callback_; }
49 const RequireCallback& require_callback() const { return require_callback_; } 49 const RequireCallback& require_callback() const { return require_callback_; }
50 50
51 protected: 51 protected:
52 SurfaceLayer(const SatisfyCallback& satisfy_callback, 52 SurfaceLayer(const SatisfyCallback& satisfy_callback,
53 const RequireCallback& require_callback); 53 const RequireCallback& require_callback);
54 bool HasDrawableContent() const override; 54 bool HasDrawableContent() const override;
55 55
56 private: 56 private:
57 ~SurfaceLayer() override; 57 ~SurfaceLayer() override;
58 void CreateNewDestroySequence(); 58 void CreateNewDestroySequence();
59 void SatisfyDestroySequence(); 59 void SatisfyDestroySequence();
60 60
61 SurfaceId surface_id_; 61 SurfaceInfo surface_info_;
62 gfx::Size surface_size_;
63 float surface_scale_;
64 SurfaceSequence destroy_sequence_; 62 SurfaceSequence destroy_sequence_;
65 SatisfyCallback satisfy_callback_; 63 SatisfyCallback satisfy_callback_;
66 RequireCallback require_callback_; 64 RequireCallback require_callback_;
67 65
68 DISALLOW_COPY_AND_ASSIGN(SurfaceLayer); 66 DISALLOW_COPY_AND_ASSIGN(SurfaceLayer);
69 }; 67 };
70 68
71 } // namespace cc 69 } // namespace cc
72 70
73 #endif // CC_LAYERS_SURFACE_LAYER_H_ 71 #endif // CC_LAYERS_SURFACE_LAYER_H_
OLDNEW
« no previous file with comments | « blimp/client/core/compositor/blimp_compositor.cc ('k') | cc/layers/surface_layer.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698