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

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

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
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 #include "cc/layers/surface_layer.h" 5 #include "cc/layers/surface_layer.h"
6 6
7 #include <stdint.h> 7 #include <stdint.h>
8 8
9 #include "base/macros.h" 9 #include "base/macros.h"
10 #include "base/trace_event/trace_event.h" 10 #include "base/trace_event/trace_event.h"
11 #include "cc/layers/surface_layer_impl.h" 11 #include "cc/layers/surface_layer_impl.h"
12 #include "cc/output/swap_promise.h" 12 #include "cc/output/swap_promise.h"
13 #include "cc/surfaces/surface_info.h"
13 #include "cc/surfaces/surface_sequence_generator.h" 14 #include "cc/surfaces/surface_sequence_generator.h"
14 #include "cc/trees/layer_tree_host.h" 15 #include "cc/trees/layer_tree_host.h"
15 #include "cc/trees/swap_promise_manager.h" 16 #include "cc/trees/swap_promise_manager.h"
16 17
17 namespace cc { 18 namespace cc {
18 19
19 class SatisfySwapPromise : public SwapPromise { 20 class SatisfySwapPromise : public SwapPromise {
20 public: 21 public:
21 SatisfySwapPromise(SurfaceSequence sequence, 22 SatisfySwapPromise(SurfaceSequence sequence,
22 const SurfaceLayer::SatisfyCallback& satisfy_callback) 23 const SurfaceLayer::SatisfyCallback& satisfy_callback)
(...skipping 21 matching lines...) Expand all
44 45
45 scoped_refptr<SurfaceLayer> SurfaceLayer::Create( 46 scoped_refptr<SurfaceLayer> SurfaceLayer::Create(
46 const SatisfyCallback& satisfy_callback, 47 const SatisfyCallback& satisfy_callback,
47 const RequireCallback& require_callback) { 48 const RequireCallback& require_callback) {
48 return make_scoped_refptr( 49 return make_scoped_refptr(
49 new SurfaceLayer(satisfy_callback, require_callback)); 50 new SurfaceLayer(satisfy_callback, require_callback));
50 } 51 }
51 52
52 SurfaceLayer::SurfaceLayer(const SatisfyCallback& satisfy_callback, 53 SurfaceLayer::SurfaceLayer(const SatisfyCallback& satisfy_callback,
53 const RequireCallback& require_callback) 54 const RequireCallback& require_callback)
54 : surface_scale_(1.f), 55 : satisfy_callback_(satisfy_callback),
55 satisfy_callback_(satisfy_callback),
56 require_callback_(require_callback) {} 56 require_callback_(require_callback) {}
57 57
58 SurfaceLayer::~SurfaceLayer() { 58 SurfaceLayer::~SurfaceLayer() {
59 DCHECK(!layer_tree_host()); 59 DCHECK(!layer_tree_host());
60 DCHECK(!destroy_sequence_.is_valid()); 60 DCHECK(!destroy_sequence_.is_valid());
61 } 61 }
62 62
63 void SurfaceLayer::SetSurfaceId(const SurfaceId& surface_id, 63 void SurfaceLayer::SetSurfaceInfo(SurfaceInfo surface_info) {
64 float scale,
65 const gfx::Size& size) {
66 SatisfyDestroySequence(); 64 SatisfyDestroySequence();
67 surface_id_ = surface_id; 65
68 surface_size_ = size; 66 surface_info_ = surface_info;
69 surface_scale_ = scale;
70 CreateNewDestroySequence(); 67 CreateNewDestroySequence();
71 68
72 UpdateDrawsContent(HasDrawableContent()); 69 UpdateDrawsContent(HasDrawableContent());
73 SetNeedsPushProperties(); 70 SetNeedsPushProperties();
74 } 71 }
75 72
76 std::unique_ptr<LayerImpl> SurfaceLayer::CreateLayerImpl( 73 std::unique_ptr<LayerImpl> SurfaceLayer::CreateLayerImpl(
77 LayerTreeImpl* tree_impl) { 74 LayerTreeImpl* tree_impl) {
78 return SurfaceLayerImpl::Create(tree_impl, id()); 75 return SurfaceLayerImpl::Create(tree_impl, id());
79 } 76 }
80 77
81 bool SurfaceLayer::HasDrawableContent() const { 78 bool SurfaceLayer::HasDrawableContent() const {
82 return surface_id_.is_valid() && Layer::HasDrawableContent(); 79 return surface_info_.id().is_valid() && Layer::HasDrawableContent();
83 } 80 }
84 81
85 void SurfaceLayer::SetLayerTreeHost(LayerTreeHost* host) { 82 void SurfaceLayer::SetLayerTreeHost(LayerTreeHost* host) {
86 if (layer_tree_host() == host) { 83 if (layer_tree_host() == host) {
87 Layer::SetLayerTreeHost(host); 84 Layer::SetLayerTreeHost(host);
88 return; 85 return;
89 } 86 }
90 87
91 SatisfyDestroySequence(); 88 SatisfyDestroySequence();
92 Layer::SetLayerTreeHost(host); 89 Layer::SetLayerTreeHost(host);
93 CreateNewDestroySequence(); 90 CreateNewDestroySequence();
94 } 91 }
95 92
96 void SurfaceLayer::PushPropertiesTo(LayerImpl* layer) { 93 void SurfaceLayer::PushPropertiesTo(LayerImpl* layer) {
97 Layer::PushPropertiesTo(layer); 94 Layer::PushPropertiesTo(layer);
98 TRACE_EVENT0("cc", "SurfaceLayer::PushPropertiesTo"); 95 TRACE_EVENT0("cc", "SurfaceLayer::PushPropertiesTo");
99 SurfaceLayerImpl* layer_impl = static_cast<SurfaceLayerImpl*>(layer); 96 SurfaceLayerImpl* layer_impl = static_cast<SurfaceLayerImpl*>(layer);
100 97
101 layer_impl->SetSurfaceId(surface_id_); 98 layer_impl->SetSurfaceInfo(surface_info_);
102 layer_impl->SetSurfaceSize(surface_size_);
103 layer_impl->SetSurfaceScale(surface_scale_);
104 } 99 }
105 100
106 void SurfaceLayer::CreateNewDestroySequence() { 101 void SurfaceLayer::CreateNewDestroySequence() {
107 DCHECK(!destroy_sequence_.is_valid()); 102 DCHECK(!destroy_sequence_.is_valid());
108 if (layer_tree_host()) { 103 if (layer_tree_host()) {
109 destroy_sequence_ = layer_tree_host() 104 destroy_sequence_ = layer_tree_host()
110 ->GetSurfaceSequenceGenerator() 105 ->GetSurfaceSequenceGenerator()
111 ->CreateSurfaceSequence(); 106 ->CreateSurfaceSequence();
112 require_callback_.Run(surface_id_, destroy_sequence_); 107 require_callback_.Run(surface_info_.id(), destroy_sequence_);
113 } 108 }
114 } 109 }
115 110
116 void SurfaceLayer::SatisfyDestroySequence() { 111 void SurfaceLayer::SatisfyDestroySequence() {
117 if (!layer_tree_host()) 112 if (!layer_tree_host())
118 return; 113 return;
119 DCHECK(destroy_sequence_.is_valid()); 114 DCHECK(destroy_sequence_.is_valid());
120 std::unique_ptr<SatisfySwapPromise> satisfy( 115 std::unique_ptr<SatisfySwapPromise> satisfy(
121 new SatisfySwapPromise(destroy_sequence_, satisfy_callback_)); 116 new SatisfySwapPromise(destroy_sequence_, satisfy_callback_));
122 layer_tree_host()->GetSwapPromiseManager()->QueueSwapPromise( 117 layer_tree_host()->GetSwapPromiseManager()->QueueSwapPromise(
123 std::move(satisfy)); 118 std::move(satisfy));
124 destroy_sequence_ = SurfaceSequence(); 119 destroy_sequence_ = SurfaceSequence();
125 } 120 }
126 121
127 } // namespace cc 122 } // namespace cc
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698