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

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

Issue 465853004: Moving RenderSurface creation outside of CalcDrawProps (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Fixed formatting Created 6 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 2012 The Chromium Authors. All rights reserved. 1 // Copyright 2012 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/layer_impl.h" 5 #include "cc/layers/layer_impl.h"
6 6
7 #include "base/debug/trace_event.h" 7 #include "base/debug/trace_event.h"
8 #include "base/debug/trace_event_argument.h" 8 #include "base/debug/trace_event_argument.h"
9 #include "base/json/json_reader.h" 9 #include "base/json/json_reader.h"
10 #include "base/strings/stringprintf.h" 10 #include "base/strings/stringprintf.h"
(...skipping 42 matching lines...) Expand 10 before | Expand all | Expand 10 after
53 double_sided_(true), 53 double_sided_(true),
54 should_flatten_transform_(true), 54 should_flatten_transform_(true),
55 layer_property_changed_(false), 55 layer_property_changed_(false),
56 masks_to_bounds_(false), 56 masks_to_bounds_(false),
57 contents_opaque_(false), 57 contents_opaque_(false),
58 is_root_for_isolated_group_(false), 58 is_root_for_isolated_group_(false),
59 use_parent_backface_visibility_(false), 59 use_parent_backface_visibility_(false),
60 draw_checkerboard_for_missing_tiles_(false), 60 draw_checkerboard_for_missing_tiles_(false),
61 draws_content_(false), 61 draws_content_(false),
62 hide_layer_and_subtree_(false), 62 hide_layer_and_subtree_(false),
63 force_render_surface_(false),
64 transform_is_invertible_(true), 63 transform_is_invertible_(true),
65 is_container_for_fixed_position_layers_(false), 64 is_container_for_fixed_position_layers_(false),
66 background_color_(0), 65 background_color_(0),
67 opacity_(1.0), 66 opacity_(1.0),
68 blend_mode_(SkXfermode::kSrcOver_Mode), 67 blend_mode_(SkXfermode::kSrcOver_Mode),
69 num_descendants_that_draw_content_(0), 68 num_descendants_that_draw_content_(0),
70 draw_depth_(0.f), 69 draw_depth_(0.f),
71 needs_push_properties_(false), 70 needs_push_properties_(false),
72 num_dependents_need_push_properties_(0), 71 num_dependents_need_push_properties_(0),
73 sorting_context_id_(0), 72 sorting_context_id_(0),
(...skipping 123 matching lines...) Expand 10 before | Expand all | Expand 10 after
197 void LayerImpl::SetClipChildren(std::set<LayerImpl*>* children) { 196 void LayerImpl::SetClipChildren(std::set<LayerImpl*>* children) {
198 if (clip_children_.get() == children) 197 if (clip_children_.get() == children)
199 return; 198 return;
200 clip_children_.reset(children); 199 clip_children_.reset(children);
201 SetNeedsPushProperties(); 200 SetNeedsPushProperties();
202 } 201 }
203 202
204 void LayerImpl::PassCopyRequests(ScopedPtrVector<CopyOutputRequest>* requests) { 203 void LayerImpl::PassCopyRequests(ScopedPtrVector<CopyOutputRequest>* requests) {
205 if (requests->empty()) 204 if (requests->empty())
206 return; 205 return;
207 206 DCHECK(render_surface());
208 bool was_empty = copy_requests_.empty(); 207 bool was_empty = copy_requests_.empty();
209 copy_requests_.insert_and_take(copy_requests_.end(), requests); 208 copy_requests_.insert_and_take(copy_requests_.end(), requests);
210 requests->clear(); 209 requests->clear();
211 210
212 if (was_empty && layer_tree_impl()->IsActiveTree()) 211 if (was_empty && layer_tree_impl()->IsActiveTree())
213 layer_tree_impl()->AddLayerWithCopyOutputRequest(this); 212 layer_tree_impl()->AddLayerWithCopyOutputRequest(this);
214 NoteLayerPropertyChangedForSubtree(); 213 NoteLayerPropertyChangedForSubtree();
215 } 214 }
216 215
217 void LayerImpl::TakeCopyRequestsAndTransformToTarget( 216 void LayerImpl::TakeCopyRequestsAndTransformToTarget(
218 ScopedPtrVector<CopyOutputRequest>* requests) { 217 ScopedPtrVector<CopyOutputRequest>* requests) {
219 DCHECK(!copy_requests_.empty()); 218 DCHECK(!copy_requests_.empty());
220 DCHECK(layer_tree_impl()->IsActiveTree()); 219 DCHECK(layer_tree_impl()->IsActiveTree());
220 DCHECK(render_target() == this);
enne (OOO) 2014/12/16 19:08:48 DCHECK_EQ, to differentiate NULL vs different
enne (OOO) 2014/12/16 19:08:48 DCHECK_EQ, to differentiate NULL vs different
awoloszyn 2014/12/16 21:54:29 Done.
221 221
222 size_t first_inserted_request = requests->size(); 222 size_t first_inserted_request = requests->size();
223 requests->insert_and_take(requests->end(), &copy_requests_); 223 requests->insert_and_take(requests->end(), &copy_requests_);
224 copy_requests_.clear(); 224 copy_requests_.clear();
225 225
226 for (size_t i = first_inserted_request; i < requests->size(); ++i) { 226 for (size_t i = first_inserted_request; i < requests->size(); ++i) {
227 CopyOutputRequest* request = requests->at(i); 227 CopyOutputRequest* request = requests->at(i);
228 if (!request->has_area()) 228 if (!request->has_area())
229 continue; 229 continue;
230 230
231 gfx::Rect request_in_layer_space = request->area(); 231 gfx::Rect request_in_layer_space = request->area();
232 gfx::Rect request_in_content_space = 232 gfx::Rect request_in_content_space =
233 LayerRectToContentRect(request_in_layer_space); 233 LayerRectToContentRect(request_in_layer_space);
234 request->set_area(MathUtil::MapEnclosingClippedRect( 234 request->set_area(MathUtil::MapEnclosingClippedRect(
235 draw_properties_.target_space_transform, request_in_content_space)); 235 draw_properties_.target_space_transform, request_in_content_space));
236 } 236 }
237 237
238 layer_tree_impl()->RemoveLayerWithCopyOutputRequest(this); 238 layer_tree_impl()->RemoveLayerWithCopyOutputRequest(this);
239 } 239 }
240 240
241 void LayerImpl::CreateRenderSurface() {
242 DCHECK(!draw_properties_.render_surface);
243 draw_properties_.render_surface =
244 make_scoped_ptr(new RenderSurfaceImpl(this));
245 draw_properties_.render_target = this;
246 }
247
248 void LayerImpl::ClearRenderSurface() {
249 draw_properties_.render_surface = nullptr;
250 }
251
252 void LayerImpl::ClearRenderSurfaceLayerList() { 241 void LayerImpl::ClearRenderSurfaceLayerList() {
253 if (draw_properties_.render_surface) 242 if (render_surface_)
254 draw_properties_.render_surface->layer_list().clear(); 243 render_surface_->layer_list().clear();
255 } 244 }
256 245
257 void LayerImpl::PopulateSharedQuadState(SharedQuadState* state) const { 246 void LayerImpl::PopulateSharedQuadState(SharedQuadState* state) const {
258 state->SetAll( 247 state->SetAll(
259 draw_properties_.target_space_transform, draw_properties_.content_bounds, 248 draw_properties_.target_space_transform, draw_properties_.content_bounds,
260 draw_properties_.visible_content_rect, draw_properties_.clip_rect, 249 draw_properties_.visible_content_rect, draw_properties_.clip_rect,
261 draw_properties_.is_clipped, draw_properties_.opacity, 250 draw_properties_.is_clipped, draw_properties_.opacity,
262 draw_properties_.blend_mode, sorting_context_id_); 251 draw_properties_.blend_mode, sorting_context_id_);
263 } 252 }
264 253
(...skipping 247 matching lines...) Expand 10 before | Expand all | Expand 10 after
512 501
513 void LayerImpl::PushPropertiesTo(LayerImpl* layer) { 502 void LayerImpl::PushPropertiesTo(LayerImpl* layer) {
514 layer->SetTransformOrigin(transform_origin_); 503 layer->SetTransformOrigin(transform_origin_);
515 layer->SetBackgroundColor(background_color_); 504 layer->SetBackgroundColor(background_color_);
516 layer->SetBounds(bounds_); 505 layer->SetBounds(bounds_);
517 layer->SetContentBounds(content_bounds()); 506 layer->SetContentBounds(content_bounds());
518 layer->SetContentsScale(contents_scale_x(), contents_scale_y()); 507 layer->SetContentsScale(contents_scale_x(), contents_scale_y());
519 layer->SetDoubleSided(double_sided_); 508 layer->SetDoubleSided(double_sided_);
520 layer->SetDrawCheckerboardForMissingTiles( 509 layer->SetDrawCheckerboardForMissingTiles(
521 draw_checkerboard_for_missing_tiles_); 510 draw_checkerboard_for_missing_tiles_);
522 layer->SetForceRenderSurface(force_render_surface_);
523 layer->SetDrawsContent(DrawsContent()); 511 layer->SetDrawsContent(DrawsContent());
524 layer->SetHideLayerAndSubtree(hide_layer_and_subtree_); 512 layer->SetHideLayerAndSubtree(hide_layer_and_subtree_);
513 layer->SetHasRenderSurface(!!render_surface());
525 layer->SetFilters(filters()); 514 layer->SetFilters(filters());
526 layer->SetBackgroundFilters(background_filters()); 515 layer->SetBackgroundFilters(background_filters());
527 layer->SetMasksToBounds(masks_to_bounds_); 516 layer->SetMasksToBounds(masks_to_bounds_);
528 layer->SetShouldScrollOnMainThread(should_scroll_on_main_thread_); 517 layer->SetShouldScrollOnMainThread(should_scroll_on_main_thread_);
529 layer->SetHaveWheelEventHandlers(have_wheel_event_handlers_); 518 layer->SetHaveWheelEventHandlers(have_wheel_event_handlers_);
530 layer->SetHaveScrollEventHandlers(have_scroll_event_handlers_); 519 layer->SetHaveScrollEventHandlers(have_scroll_event_handlers_);
531 layer->SetNonFastScrollableRegion(non_fast_scrollable_region_); 520 layer->SetNonFastScrollableRegion(non_fast_scrollable_region_);
532 layer->SetTouchEventHandlerRegion(touch_event_handler_region_); 521 layer->SetTouchEventHandlerRegion(touch_event_handler_region_);
533 layer->SetContentsOpaque(contents_opaque_); 522 layer->SetContentsOpaque(contents_opaque_);
534 layer->SetOpacity(opacity_); 523 layer->SetOpacity(opacity_);
(...skipping 197 matching lines...) Expand 10 before | Expand all | Expand 10 after
732 const char* LayerImpl::LayerTypeAsString() const { 721 const char* LayerImpl::LayerTypeAsString() const {
733 return "cc::LayerImpl"; 722 return "cc::LayerImpl";
734 } 723 }
735 724
736 void LayerImpl::ResetAllChangeTrackingForSubtree() { 725 void LayerImpl::ResetAllChangeTrackingForSubtree() {
737 layer_property_changed_ = false; 726 layer_property_changed_ = false;
738 727
739 update_rect_ = gfx::Rect(); 728 update_rect_ = gfx::Rect();
740 damage_rect_ = gfx::RectF(); 729 damage_rect_ = gfx::RectF();
741 730
742 if (draw_properties_.render_surface) 731 if (render_surface_)
743 draw_properties_.render_surface->ResetPropertyChangedFlag(); 732 render_surface_->ResetPropertyChangedFlag();
744 733
745 if (mask_layer_) 734 if (mask_layer_)
746 mask_layer_->ResetAllChangeTrackingForSubtree(); 735 mask_layer_->ResetAllChangeTrackingForSubtree();
747 736
748 if (replica_layer_) { 737 if (replica_layer_) {
749 // This also resets the replica mask, if it exists. 738 // This also resets the replica mask, if it exists.
750 replica_layer_->ResetAllChangeTrackingForSubtree(); 739 replica_layer_->ResetAllChangeTrackingForSubtree();
751 } 740 }
752 741
753 for (size_t i = 0; i < children_.size(); ++i) 742 for (size_t i = 0; i < children_.size(); ++i)
(...skipping 834 matching lines...) Expand 10 before | Expand all | Expand 10 after
1588 } 1577 }
1589 1578
1590 void LayerImpl::NotifyAnimationFinished( 1579 void LayerImpl::NotifyAnimationFinished(
1591 base::TimeTicks monotonic_time, 1580 base::TimeTicks monotonic_time,
1592 Animation::TargetProperty target_property, 1581 Animation::TargetProperty target_property,
1593 int group) { 1582 int group) {
1594 if (target_property == Animation::ScrollOffset) 1583 if (target_property == Animation::ScrollOffset)
1595 layer_tree_impl_->InputScrollAnimationFinished(); 1584 layer_tree_impl_->InputScrollAnimationFinished();
1596 } 1585 }
1597 1586
1587 void LayerImpl::SetHasRenderSurface(bool should_have_render_surface) {
1588 if (!!render_surface() == should_have_render_surface)
1589 return;
1590
1591 SetNeedsPushProperties();
1592 layer_tree_impl()->set_needs_update_draw_properties();
1593 if (should_have_render_surface) {
1594 render_surface_ = make_scoped_ptr(new RenderSurfaceImpl(this));
1595 return;
1596 }
1597 render_surface_.reset();
1598 }
1599
1598 } // namespace cc 1600 } // namespace cc
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698