OLD | NEW |
1 // Copyright 2011 The Chromium Authors. All rights reserved. | 1 // Copyright 2011 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/trees/layer_tree_host.h" | 5 #include "cc/trees/layer_tree_host.h" |
6 | 6 |
7 #include <algorithm> | 7 #include <algorithm> |
8 #include <stack> | 8 #include <stack> |
9 #include <string> | 9 #include <string> |
10 | 10 |
(...skipping 80 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
91 bitmap_ = make_scoped_ptr(new UIResourceBitmap(*request.bitmap_.get())); | 91 bitmap_ = make_scoped_ptr(new UIResourceBitmap(*request.bitmap_.get())); |
92 } else { | 92 } else { |
93 bitmap_.reset(); | 93 bitmap_.reset(); |
94 } | 94 } |
95 | 95 |
96 return *this; | 96 return *this; |
97 } | 97 } |
98 | 98 |
99 UIResourceRequest::~UIResourceRequest() {} | 99 UIResourceRequest::~UIResourceRequest() {} |
100 | 100 |
101 scoped_ptr<LayerTreeHost> LayerTreeHost::Create( | 101 scoped_ptr<LayerTreeHost> LayerTreeHost::CreateThreaded( |
102 LayerTreeHostClient* client, | 102 LayerTreeHostClient* client, |
103 SharedBitmapManager* manager, | 103 SharedBitmapManager* manager, |
104 const LayerTreeSettings& settings, | 104 const LayerTreeSettings& settings, |
105 scoped_refptr<base::SingleThreadTaskRunner> impl_task_runner) { | 105 scoped_refptr<base::SingleThreadTaskRunner> impl_task_runner) { |
| 106 DCHECK(impl_task_runner); |
106 scoped_ptr<LayerTreeHost> layer_tree_host( | 107 scoped_ptr<LayerTreeHost> layer_tree_host( |
107 new LayerTreeHost(client, manager, settings)); | 108 new LayerTreeHost(client, manager, settings)); |
108 if (!layer_tree_host->Initialize(impl_task_runner)) | 109 if (!layer_tree_host->InitializeThreaded(impl_task_runner)) |
109 return scoped_ptr<LayerTreeHost>(); | 110 return scoped_ptr<LayerTreeHost>(); |
110 return layer_tree_host.Pass(); | 111 return layer_tree_host.Pass(); |
111 } | 112 } |
112 | 113 |
113 LayerTreeHost::LayerTreeHost(LayerTreeHostClient* client, | 114 scoped_ptr<LayerTreeHost> LayerTreeHost::CreateSingleThreaded( |
114 SharedBitmapManager* manager, | 115 LayerTreeHostClient* client, |
115 const LayerTreeSettings& settings) | 116 LayerTreeHostSingleThreadClient* single_thread_client, |
| 117 SharedBitmapManager* manager, |
| 118 const LayerTreeSettings& settings) { |
| 119 scoped_ptr<LayerTreeHost> layer_tree_host( |
| 120 new LayerTreeHost(client, manager, settings)); |
| 121 if (!layer_tree_host->InitializeSingleThreaded(single_thread_client)) |
| 122 return scoped_ptr<LayerTreeHost>(); |
| 123 return layer_tree_host.Pass(); |
| 124 } |
| 125 |
| 126 |
| 127 LayerTreeHost::LayerTreeHost( |
| 128 LayerTreeHostClient* client, |
| 129 SharedBitmapManager* manager, |
| 130 const LayerTreeSettings& settings) |
116 : next_ui_resource_id_(1), | 131 : next_ui_resource_id_(1), |
117 animating_(false), | 132 animating_(false), |
118 needs_full_tree_sync_(true), | 133 needs_full_tree_sync_(true), |
119 needs_filter_context_(false), | 134 needs_filter_context_(false), |
120 client_(client), | 135 client_(client), |
121 source_frame_number_(0), | 136 source_frame_number_(0), |
122 rendering_stats_instrumentation_(RenderingStatsInstrumentation::Create()), | 137 rendering_stats_instrumentation_(RenderingStatsInstrumentation::Create()), |
123 micro_benchmark_controller_(this), | 138 micro_benchmark_controller_(this), |
124 output_surface_can_be_initialized_(true), | 139 output_surface_can_be_initialized_(true), |
125 output_surface_lost_(true), | 140 output_surface_lost_(true), |
(...skipping 14 matching lines...) Expand all Loading... |
140 total_frames_used_for_lcd_text_metrics_(0), | 155 total_frames_used_for_lcd_text_metrics_(0), |
141 tree_id_(GetNextTreeId()), | 156 tree_id_(GetNextTreeId()), |
142 next_commit_forces_redraw_(false), | 157 next_commit_forces_redraw_(false), |
143 shared_bitmap_manager_(manager) { | 158 shared_bitmap_manager_(manager) { |
144 if (settings_.accelerated_animation_enabled) | 159 if (settings_.accelerated_animation_enabled) |
145 animation_registrar_ = AnimationRegistrar::Create(); | 160 animation_registrar_ = AnimationRegistrar::Create(); |
146 rendering_stats_instrumentation_->set_record_rendering_stats( | 161 rendering_stats_instrumentation_->set_record_rendering_stats( |
147 debug_state_.RecordRenderingStats()); | 162 debug_state_.RecordRenderingStats()); |
148 } | 163 } |
149 | 164 |
150 bool LayerTreeHost::Initialize( | 165 bool LayerTreeHost::InitializeThreaded( |
151 scoped_refptr<base::SingleThreadTaskRunner> impl_task_runner) { | 166 scoped_refptr<base::SingleThreadTaskRunner> impl_task_runner) { |
152 if (impl_task_runner.get()) | 167 return InitializeProxy(ThreadProxy::Create(this, impl_task_runner)); |
153 return InitializeProxy(ThreadProxy::Create(this, impl_task_runner)); | 168 } |
154 else | 169 |
155 return InitializeProxy(SingleThreadProxy::Create(this)); | 170 bool LayerTreeHost::InitializeSingleThreaded( |
| 171 LayerTreeHostSingleThreadClient* single_thread_client) { |
| 172 return InitializeProxy( |
| 173 SingleThreadProxy::Create(this, single_thread_client)); |
156 } | 174 } |
157 | 175 |
158 bool LayerTreeHost::InitializeForTesting(scoped_ptr<Proxy> proxy_for_testing) { | 176 bool LayerTreeHost::InitializeForTesting(scoped_ptr<Proxy> proxy_for_testing) { |
159 return InitializeProxy(proxy_for_testing.Pass()); | 177 return InitializeProxy(proxy_for_testing.Pass()); |
160 } | 178 } |
161 | 179 |
162 bool LayerTreeHost::InitializeProxy(scoped_ptr<Proxy> proxy) { | 180 bool LayerTreeHost::InitializeProxy(scoped_ptr<Proxy> proxy) { |
163 TRACE_EVENT0("cc", "LayerTreeHost::InitializeForReal"); | 181 TRACE_EVENT0("cc", "LayerTreeHost::InitializeForReal"); |
164 | 182 |
165 scoped_ptr<OutputSurface> output_surface(CreateOutputSurface()); | 183 scoped_ptr<OutputSurface> output_surface(CreateOutputSurface()); |
(...skipping 389 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
555 needs_full_tree_sync_ = true; | 573 needs_full_tree_sync_ = true; |
556 SetNeedsCommit(); | 574 SetNeedsCommit(); |
557 } | 575 } |
558 | 576 |
559 void LayerTreeHost::SetNeedsRedraw() { | 577 void LayerTreeHost::SetNeedsRedraw() { |
560 SetNeedsRedrawRect(gfx::Rect(device_viewport_size_)); | 578 SetNeedsRedrawRect(gfx::Rect(device_viewport_size_)); |
561 } | 579 } |
562 | 580 |
563 void LayerTreeHost::SetNeedsRedrawRect(gfx::Rect damage_rect) { | 581 void LayerTreeHost::SetNeedsRedrawRect(gfx::Rect damage_rect) { |
564 proxy_->SetNeedsRedraw(damage_rect); | 582 proxy_->SetNeedsRedraw(damage_rect); |
565 if (!proxy_->HasImplThread()) | |
566 client_->ScheduleComposite(); | |
567 } | 583 } |
568 | 584 |
569 bool LayerTreeHost::CommitRequested() const { | 585 bool LayerTreeHost::CommitRequested() const { |
570 return proxy_->CommitRequested(); | 586 return proxy_->CommitRequested(); |
571 } | 587 } |
572 | 588 |
573 bool LayerTreeHost::BeginMainFrameRequested() const { | 589 bool LayerTreeHost::BeginMainFrameRequested() const { |
574 return proxy_->BeginMainFrameRequested(); | 590 return proxy_->BeginMainFrameRequested(); |
575 } | 591 } |
576 | 592 |
(...skipping 155 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
732 } | 748 } |
733 | 749 |
734 void LayerTreeHost::Composite(base::TimeTicks frame_begin_time) { | 750 void LayerTreeHost::Composite(base::TimeTicks frame_begin_time) { |
735 if (!proxy_->HasImplThread()) | 751 if (!proxy_->HasImplThread()) |
736 static_cast<SingleThreadProxy*>(proxy_.get())->CompositeImmediately( | 752 static_cast<SingleThreadProxy*>(proxy_.get())->CompositeImmediately( |
737 frame_begin_time); | 753 frame_begin_time); |
738 else | 754 else |
739 SetNeedsCommit(); | 755 SetNeedsCommit(); |
740 } | 756 } |
741 | 757 |
742 void LayerTreeHost::ScheduleComposite() { | |
743 client_->ScheduleComposite(); | |
744 } | |
745 | |
746 bool LayerTreeHost::InitializeOutputSurfaceIfNeeded() { | 758 bool LayerTreeHost::InitializeOutputSurfaceIfNeeded() { |
747 if (!output_surface_can_be_initialized_) | 759 if (!output_surface_can_be_initialized_) |
748 return false; | 760 return false; |
749 | 761 |
750 if (output_surface_lost_) | 762 if (output_surface_lost_) |
751 proxy_->CreateAndInitializeOutputSurface(); | 763 proxy_->CreateAndInitializeOutputSurface(); |
752 return !output_surface_lost_; | 764 return !output_surface_lost_; |
753 } | 765 } |
754 | 766 |
755 bool LayerTreeHost::UpdateLayers(ResourceUpdateQueue* queue) { | 767 bool LayerTreeHost::UpdateLayers(ResourceUpdateQueue* queue) { |
(...skipping 518 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
1274 | 1286 |
1275 bool LayerTreeHost::ScheduleMicroBenchmark( | 1287 bool LayerTreeHost::ScheduleMicroBenchmark( |
1276 const std::string& benchmark_name, | 1288 const std::string& benchmark_name, |
1277 scoped_ptr<base::Value> value, | 1289 scoped_ptr<base::Value> value, |
1278 const MicroBenchmark::DoneCallback& callback) { | 1290 const MicroBenchmark::DoneCallback& callback) { |
1279 return micro_benchmark_controller_.ScheduleRun( | 1291 return micro_benchmark_controller_.ScheduleRun( |
1280 benchmark_name, value.Pass(), callback); | 1292 benchmark_name, value.Pass(), callback); |
1281 } | 1293 } |
1282 | 1294 |
1283 } // namespace cc | 1295 } // namespace cc |
OLD | NEW |