OLD | NEW |
1 // Copyright 2016 The Chromium Authors. All rights reserved. | 1 // Copyright 2016 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/test/layer_tree_host_remote_for_testing.h" | 5 #include "cc/test/layer_tree_host_remote_for_testing.h" |
6 | 6 |
7 #include "base/memory/ptr_util.h" | 7 #include "base/memory/ptr_util.h" |
8 #include "cc/animation/animation_host.h" | 8 #include "cc/animation/animation_host.h" |
9 #include "cc/blimp/compositor_proto_state.h" | 9 #include "cc/blimp/compositor_proto_state.h" |
10 #include "cc/blimp/compositor_state_deserializer.h" | 10 #include "cc/blimp/compositor_state_deserializer.h" |
(...skipping 95 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
106 return base::MakeUnique<RemoteCompositorBridgeImpl>( | 106 return base::MakeUnique<RemoteCompositorBridgeImpl>( |
107 std::move(main_task_runner)); | 107 std::move(main_task_runner)); |
108 } | 108 } |
109 | 109 |
110 // static | 110 // static |
111 std::unique_ptr<LayerTreeHostRemoteForTesting> | 111 std::unique_ptr<LayerTreeHostRemoteForTesting> |
112 LayerTreeHostRemoteForTesting::Create( | 112 LayerTreeHostRemoteForTesting::Create( |
113 LayerTreeHostClient* client, | 113 LayerTreeHostClient* client, |
114 std::unique_ptr<AnimationHost> animation_host, | 114 std::unique_ptr<AnimationHost> animation_host, |
115 LayerTreeSettings const* settings, | 115 LayerTreeSettings const* settings, |
116 SharedBitmapManager* shared_bitmap_manager, | |
117 gpu::GpuMemoryBufferManager* gpu_memory_buffer_manager, | |
118 TaskGraphRunner* task_graph_runner, | 116 TaskGraphRunner* task_graph_runner, |
119 scoped_refptr<base::SingleThreadTaskRunner> main_task_runner, | 117 scoped_refptr<base::SingleThreadTaskRunner> main_task_runner, |
120 scoped_refptr<base::SingleThreadTaskRunner> impl_task_runner) { | 118 scoped_refptr<base::SingleThreadTaskRunner> impl_task_runner) { |
121 std::unique_ptr<FakeImageSerializationProcessor> | 119 std::unique_ptr<FakeImageSerializationProcessor> |
122 image_serialization_processor = | 120 image_serialization_processor = |
123 base::MakeUnique<FakeImageSerializationProcessor>(); | 121 base::MakeUnique<FakeImageSerializationProcessor>(); |
124 | 122 |
125 LayerTreeHostRemote::InitParams params; | 123 LayerTreeHostRemote::InitParams params; |
126 params.client = client; | 124 params.client = client; |
127 params.main_task_runner = main_task_runner; | 125 params.main_task_runner = main_task_runner; |
128 params.animation_host = std::move(animation_host); | 126 params.animation_host = std::move(animation_host); |
129 params.remote_compositor_bridge = | 127 params.remote_compositor_bridge = |
130 CreateRemoteCompositorBridge(main_task_runner); | 128 CreateRemoteCompositorBridge(main_task_runner); |
131 params.engine_picture_cache = | 129 params.engine_picture_cache = |
132 image_serialization_processor->CreateEnginePictureCache(); | 130 image_serialization_processor->CreateEnginePictureCache(); |
133 params.settings = settings; | 131 params.settings = settings; |
134 | 132 |
135 std::unique_ptr<LayerTreeHostRemoteForTesting> layer_tree_host = | 133 std::unique_ptr<LayerTreeHostRemoteForTesting> layer_tree_host = |
136 base::WrapUnique(new LayerTreeHostRemoteForTesting(¶ms)); | 134 base::WrapUnique(new LayerTreeHostRemoteForTesting(¶ms)); |
137 layer_tree_host->Initialize(shared_bitmap_manager, gpu_memory_buffer_manager, | 135 layer_tree_host->Initialize(task_graph_runner, main_task_runner, |
138 task_graph_runner, main_task_runner, | |
139 impl_task_runner, | 136 impl_task_runner, |
140 std::move(image_serialization_processor)); | 137 std::move(image_serialization_processor)); |
141 return layer_tree_host; | 138 return layer_tree_host; |
142 } | 139 } |
143 | 140 |
144 LayerTreeHostRemoteForTesting::LayerTreeHostRemoteForTesting(InitParams* params) | 141 LayerTreeHostRemoteForTesting::LayerTreeHostRemoteForTesting(InitParams* params) |
145 : LayerTreeHostRemote(params), | 142 : LayerTreeHostRemote(params), |
146 layer_tree_host_in_process_client_( | 143 layer_tree_host_in_process_client_( |
147 base::MakeUnique<LayerTreeHostInProcessClient>(this)) {} | 144 base::MakeUnique<LayerTreeHostInProcessClient>(this)) {} |
148 | 145 |
(...skipping 38 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
187 // Pass through because the InProcessHost has the input handler. | 184 // Pass through because the InProcessHost has the input handler. |
188 layer_tree_host_in_process_->NotifyInputThrottledUntilCommit(); | 185 layer_tree_host_in_process_->NotifyInputThrottledUntilCommit(); |
189 } | 186 } |
190 | 187 |
191 const base::WeakPtr<InputHandler>& | 188 const base::WeakPtr<InputHandler>& |
192 LayerTreeHostRemoteForTesting::GetInputHandler() const { | 189 LayerTreeHostRemoteForTesting::GetInputHandler() const { |
193 return layer_tree_host_in_process_->GetInputHandler(); | 190 return layer_tree_host_in_process_->GetInputHandler(); |
194 } | 191 } |
195 | 192 |
196 void LayerTreeHostRemoteForTesting::Initialize( | 193 void LayerTreeHostRemoteForTesting::Initialize( |
197 SharedBitmapManager* shared_bitmap_manager, | |
198 gpu::GpuMemoryBufferManager* gpu_memory_buffer_manager, | |
199 TaskGraphRunner* task_graph_runner, | 194 TaskGraphRunner* task_graph_runner, |
200 scoped_refptr<base::SingleThreadTaskRunner> main_task_runner, | 195 scoped_refptr<base::SingleThreadTaskRunner> main_task_runner, |
201 scoped_refptr<base::SingleThreadTaskRunner> impl_task_runner, | 196 scoped_refptr<base::SingleThreadTaskRunner> impl_task_runner, |
202 std::unique_ptr<FakeImageSerializationProcessor> | 197 std::unique_ptr<FakeImageSerializationProcessor> |
203 image_serialization_processor) { | 198 image_serialization_processor) { |
204 image_serialization_processor_ = std::move(image_serialization_processor); | 199 image_serialization_processor_ = std::move(image_serialization_processor); |
205 RemoteCompositorBridgeImpl* remote_compositor_bridge_impl = | 200 RemoteCompositorBridgeImpl* remote_compositor_bridge_impl = |
206 static_cast<RemoteCompositorBridgeImpl*>(remote_compositor_bridge()); | 201 static_cast<RemoteCompositorBridgeImpl*>(remote_compositor_bridge()); |
207 remote_compositor_bridge_impl->SetRemoteHost(this); | 202 remote_compositor_bridge_impl->SetRemoteHost(this); |
208 | 203 |
209 layer_tree_host_in_process_ = CreateLayerTreeHostInProcess( | 204 layer_tree_host_in_process_ = CreateLayerTreeHostInProcess( |
210 layer_tree_host_in_process_client_.get(), shared_bitmap_manager, | 205 layer_tree_host_in_process_client_.get(), task_graph_runner, |
211 gpu_memory_buffer_manager, task_graph_runner, GetSettings(), | 206 GetSettings(), main_task_runner, impl_task_runner); |
212 main_task_runner, impl_task_runner); | |
213 | 207 |
214 compositor_state_deserializer_ = | 208 compositor_state_deserializer_ = |
215 base::MakeUnique<CompositorStateDeserializer>( | 209 base::MakeUnique<CompositorStateDeserializer>( |
216 layer_tree_host_in_process_.get(), | 210 layer_tree_host_in_process_.get(), |
217 image_serialization_processor_->CreateClientPictureCache(), | 211 image_serialization_processor_->CreateClientPictureCache(), |
218 base::Bind(&LayerTreeHostRemoteForTesting::LayerDidScroll, | 212 base::Bind(&LayerTreeHostRemoteForTesting::LayerDidScroll, |
219 base::Unretained(this)), | 213 base::Unretained(this)), |
220 this); | 214 this); |
221 | 215 |
222 // Override the LayerFactory since a lot of tests rely on the fact that Layers | 216 // Override the LayerFactory since a lot of tests rely on the fact that Layers |
223 // and LayerImpls have matching ids. | 217 // and LayerImpls have matching ids. |
224 compositor_state_deserializer_->SetLayerFactoryForTesting( | 218 compositor_state_deserializer_->SetLayerFactoryForTesting( |
225 base::MakeUnique<RemoteClientLayerFactory>()); | 219 base::MakeUnique<RemoteClientLayerFactory>()); |
226 | 220 |
227 // Override the TaskRunnerProvider since tests may rely on accessing the impl | 221 // Override the TaskRunnerProvider since tests may rely on accessing the impl |
228 // task runner using it. | 222 // task runner using it. |
229 SetTaskRunnerProviderForTesting( | 223 SetTaskRunnerProviderForTesting( |
230 TaskRunnerProvider::Create(main_task_runner, impl_task_runner)); | 224 TaskRunnerProvider::Create(main_task_runner, impl_task_runner)); |
231 } | 225 } |
232 | 226 |
233 std::unique_ptr<LayerTreeHostInProcess> | 227 std::unique_ptr<LayerTreeHostInProcess> |
234 LayerTreeHostRemoteForTesting::CreateLayerTreeHostInProcess( | 228 LayerTreeHostRemoteForTesting::CreateLayerTreeHostInProcess( |
235 LayerTreeHostClient* client, | 229 LayerTreeHostClient* client, |
236 SharedBitmapManager* shared_bitmap_manager, | |
237 gpu::GpuMemoryBufferManager* gpu_memory_buffer_manager, | |
238 TaskGraphRunner* task_graph_runner, | 230 TaskGraphRunner* task_graph_runner, |
239 const LayerTreeSettings& settings, | 231 const LayerTreeSettings& settings, |
240 scoped_refptr<base::SingleThreadTaskRunner> main_task_runner, | 232 scoped_refptr<base::SingleThreadTaskRunner> main_task_runner, |
241 scoped_refptr<base::SingleThreadTaskRunner> impl_task_runner) { | 233 scoped_refptr<base::SingleThreadTaskRunner> impl_task_runner) { |
242 LayerTreeHostInProcess::InitParams params; | 234 LayerTreeHostInProcess::InitParams params; |
243 | 235 |
244 params.client = client; | 236 params.client = client; |
245 params.shared_bitmap_manager = shared_bitmap_manager; | |
246 params.gpu_memory_buffer_manager = gpu_memory_buffer_manager; | |
247 params.task_graph_runner = task_graph_runner; | 237 params.task_graph_runner = task_graph_runner; |
248 params.settings = &settings; | 238 params.settings = &settings; |
249 params.main_task_runner = main_task_runner; | 239 params.main_task_runner = main_task_runner; |
250 params.animation_host = AnimationHost::CreateMainInstance(); | 240 params.animation_host = AnimationHost::CreateMainInstance(); |
251 | 241 |
252 return LayerTreeHostInProcess::CreateThreaded(impl_task_runner, ¶ms); | 242 return LayerTreeHostInProcess::CreateThreaded(impl_task_runner, ¶ms); |
253 } | 243 } |
254 | 244 |
255 void LayerTreeHostRemoteForTesting::DispatchDrawAndSubmitCallbacks() { | 245 void LayerTreeHostRemoteForTesting::DispatchDrawAndSubmitCallbacks() { |
256 // Don't dispatch callbacks right after the commit on the remote host. Since | 246 // Don't dispatch callbacks right after the commit on the remote host. Since |
(...skipping 56 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
313 } | 303 } |
314 | 304 |
315 // The only case where the remote host would give a compositor update is if | 305 // The only case where the remote host would give a compositor update is if |
316 // they wanted the main frame to go till the commit pipeline stage. So | 306 // they wanted the main frame to go till the commit pipeline stage. So |
317 // request one to make sure that the in process main frame also goes till | 307 // request one to make sure that the in process main frame also goes till |
318 // the commit step. | 308 // the commit step. |
319 layer_tree_host_in_process_->SetNeedsCommit(); | 309 layer_tree_host_in_process_->SetNeedsCommit(); |
320 } | 310 } |
321 | 311 |
322 } // namespace cc | 312 } // namespace cc |
OLD | NEW |