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

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

Issue 2495373003: Match html canvas which is transferred to OffscreenCanvas to CSS style (Closed)
Patch Set: fix compilation error Created 4 years 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"
(...skipping 33 matching lines...) Expand 10 before | Expand all | Expand 10 after
44 44
45 scoped_refptr<SurfaceLayer> SurfaceLayer::Create( 45 scoped_refptr<SurfaceLayer> SurfaceLayer::Create(
46 const SatisfyCallback& satisfy_callback, 46 const SatisfyCallback& satisfy_callback,
47 const RequireCallback& require_callback) { 47 const RequireCallback& require_callback) {
48 return make_scoped_refptr( 48 return make_scoped_refptr(
49 new SurfaceLayer(satisfy_callback, require_callback)); 49 new SurfaceLayer(satisfy_callback, require_callback));
50 } 50 }
51 51
52 SurfaceLayer::SurfaceLayer(const SatisfyCallback& satisfy_callback, 52 SurfaceLayer::SurfaceLayer(const SatisfyCallback& satisfy_callback,
53 const RequireCallback& require_callback) 53 const RequireCallback& require_callback)
54 : surface_scale_(1.f), 54 : satisfy_callback_(satisfy_callback),
55 satisfy_callback_(satisfy_callback),
56 require_callback_(require_callback) {} 55 require_callback_(require_callback) {}
57 56
58 SurfaceLayer::~SurfaceLayer() { 57 SurfaceLayer::~SurfaceLayer() {
59 DCHECK(!layer_tree_host()); 58 DCHECK(!layer_tree_host());
60 DCHECK(!destroy_sequence_.is_valid()); 59 DCHECK(!destroy_sequence_.is_valid());
61 } 60 }
62 61
63 void SurfaceLayer::SetSurfaceId(const SurfaceId& surface_id, 62 void SurfaceLayer::SetSurfaceId(const SurfaceId& surface_id,
64 float scale, 63 float scale,
65 const gfx::Size& size) { 64 const gfx::Size& size,
65 bool stretch_content_to_fill_bounds) {
66 SatisfyDestroySequence(); 66 SatisfyDestroySequence();
67 surface_id_ = surface_id; 67 surface_id_ = surface_id;
68 surface_size_ = size; 68 surface_size_ = size;
69 surface_scale_ = scale; 69 surface_scale_ = scale;
70 stretch_content_to_fill_bounds_ = stretch_content_to_fill_bounds;
70 CreateNewDestroySequence(); 71 CreateNewDestroySequence();
71 72
72 UpdateDrawsContent(HasDrawableContent()); 73 UpdateDrawsContent(HasDrawableContent());
73 SetNeedsPushProperties(); 74 SetNeedsPushProperties();
74 } 75 }
75 76
76 std::unique_ptr<LayerImpl> SurfaceLayer::CreateLayerImpl( 77 std::unique_ptr<LayerImpl> SurfaceLayer::CreateLayerImpl(
77 LayerTreeImpl* tree_impl) { 78 LayerTreeImpl* tree_impl) {
78 return SurfaceLayerImpl::Create(tree_impl, id()); 79 return SurfaceLayerImpl::Create(tree_impl, id());
79 } 80 }
(...skipping 14 matching lines...) Expand all
94 } 95 }
95 96
96 void SurfaceLayer::PushPropertiesTo(LayerImpl* layer) { 97 void SurfaceLayer::PushPropertiesTo(LayerImpl* layer) {
97 Layer::PushPropertiesTo(layer); 98 Layer::PushPropertiesTo(layer);
98 TRACE_EVENT0("cc", "SurfaceLayer::PushPropertiesTo"); 99 TRACE_EVENT0("cc", "SurfaceLayer::PushPropertiesTo");
99 SurfaceLayerImpl* layer_impl = static_cast<SurfaceLayerImpl*>(layer); 100 SurfaceLayerImpl* layer_impl = static_cast<SurfaceLayerImpl*>(layer);
100 101
101 layer_impl->SetSurfaceId(surface_id_); 102 layer_impl->SetSurfaceId(surface_id_);
102 layer_impl->SetSurfaceSize(surface_size_); 103 layer_impl->SetSurfaceSize(surface_size_);
103 layer_impl->SetSurfaceScale(surface_scale_); 104 layer_impl->SetSurfaceScale(surface_scale_);
105 layer_impl->SetStretchContentToFillBounds(stretch_content_to_fill_bounds_);
104 } 106 }
105 107
106 void SurfaceLayer::CreateNewDestroySequence() { 108 void SurfaceLayer::CreateNewDestroySequence() {
107 DCHECK(!destroy_sequence_.is_valid()); 109 DCHECK(!destroy_sequence_.is_valid());
108 if (layer_tree_host()) { 110 if (layer_tree_host()) {
109 destroy_sequence_ = layer_tree_host() 111 destroy_sequence_ = layer_tree_host()
110 ->GetSurfaceSequenceGenerator() 112 ->GetSurfaceSequenceGenerator()
111 ->CreateSurfaceSequence(); 113 ->CreateSurfaceSequence();
112 require_callback_.Run(surface_id_, destroy_sequence_); 114 require_callback_.Run(surface_id_, destroy_sequence_);
113 } 115 }
114 } 116 }
115 117
116 void SurfaceLayer::SatisfyDestroySequence() { 118 void SurfaceLayer::SatisfyDestroySequence() {
117 if (!layer_tree_host()) 119 if (!layer_tree_host())
118 return; 120 return;
119 DCHECK(destroy_sequence_.is_valid()); 121 DCHECK(destroy_sequence_.is_valid());
120 std::unique_ptr<SatisfySwapPromise> satisfy( 122 std::unique_ptr<SatisfySwapPromise> satisfy(
121 new SatisfySwapPromise(destroy_sequence_, satisfy_callback_)); 123 new SatisfySwapPromise(destroy_sequence_, satisfy_callback_));
122 layer_tree_host()->GetSwapPromiseManager()->QueueSwapPromise( 124 layer_tree_host()->GetSwapPromiseManager()->QueueSwapPromise(
123 std::move(satisfy)); 125 std::move(satisfy));
124 destroy_sequence_ = SurfaceSequence(); 126 destroy_sequence_ = SurfaceSequence();
125 } 127 }
126 128
127 } // namespace cc 129 } // namespace cc
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698