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

Side by Side Diff: cc/test/fake_layer_tree_host.cc

Issue 1458703010: Mac: Don't repaint scrollbars every frame (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master2
Patch Set: Rebase and resolve Created 5 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
« no previous file with comments | « cc/test/fake_layer_tree_host.h ('k') | cc/test/fake_scrollbar.h » ('j') | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
1 // Copyright 2013 The Chromium Authors. All rights reserved. 1 // Copyright 2013 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/fake_layer_tree_host.h" 5 #include "cc/test/fake_layer_tree_host.h"
6 6
7 #include "cc/layers/layer.h" 7 #include "cc/layers/layer.h"
8 #include "cc/test/test_task_graph_runner.h" 8 #include "cc/test/test_task_graph_runner.h"
9 9
10 namespace cc { 10 namespace cc {
11 FakeLayerTreeHost::FakeLayerTreeHost(FakeLayerTreeHostClient* client, 11 FakeLayerTreeHost::FakeLayerTreeHost(FakeLayerTreeHostClient* client,
12 LayerTreeHost::InitParams* params) 12 LayerTreeHost::InitParams* params)
13 : LayerTreeHost(params), 13 : LayerTreeHost(params),
14 client_(client), 14 client_(client),
15 host_impl_(*params->settings, 15 host_impl_(*params->settings,
16 &task_runner_provider_, 16 &task_runner_provider_,
17 &manager_, 17 &manager_,
18 params->task_graph_runner), 18 params->task_graph_runner),
19 needs_commit_(false) { 19 needs_commit_(false),
20 renderer_capabilities_set(false) {
20 client_->SetLayerTreeHost(this); 21 client_->SetLayerTreeHost(this);
21 } 22 }
22 23
23 scoped_ptr<FakeLayerTreeHost> FakeLayerTreeHost::Create( 24 scoped_ptr<FakeLayerTreeHost> FakeLayerTreeHost::Create(
24 FakeLayerTreeHostClient* client, 25 FakeLayerTreeHostClient* client,
25 TestTaskGraphRunner* task_graph_runner) { 26 TestTaskGraphRunner* task_graph_runner) {
26 LayerTreeSettings settings; 27 LayerTreeSettings settings;
27 settings.verify_property_trees = true; 28 settings.verify_property_trees = true;
28 return Create(client, task_graph_runner, settings); 29 return Create(client, task_graph_runner, settings);
29 } 30 }
30 31
31 scoped_ptr<FakeLayerTreeHost> FakeLayerTreeHost::Create( 32 scoped_ptr<FakeLayerTreeHost> FakeLayerTreeHost::Create(
32 FakeLayerTreeHostClient* client, 33 FakeLayerTreeHostClient* client,
33 TestTaskGraphRunner* task_graph_runner, 34 TestTaskGraphRunner* task_graph_runner,
34 const LayerTreeSettings& settings) { 35 const LayerTreeSettings& settings) {
35 LayerTreeHost::InitParams params; 36 LayerTreeHost::InitParams params;
36 params.client = client; 37 params.client = client;
37 params.settings = &settings; 38 params.settings = &settings;
38 params.task_graph_runner = task_graph_runner; 39 params.task_graph_runner = task_graph_runner;
39 return make_scoped_ptr(new FakeLayerTreeHost(client, &params)); 40 return make_scoped_ptr(new FakeLayerTreeHost(client, &params));
40 } 41 }
41 42
42 FakeLayerTreeHost::~FakeLayerTreeHost() { 43 FakeLayerTreeHost::~FakeLayerTreeHost() {
43 client_->SetLayerTreeHost(NULL); 44 client_->SetLayerTreeHost(NULL);
44 } 45 }
45 46
47 const RendererCapabilities& FakeLayerTreeHost::GetRendererCapabilities() const {
48 if (renderer_capabilities_set)
49 return renderer_capabilities;
50 return LayerTreeHost::GetRendererCapabilities();
51 }
52
46 void FakeLayerTreeHost::SetNeedsCommit() { needs_commit_ = true; } 53 void FakeLayerTreeHost::SetNeedsCommit() { needs_commit_ = true; }
47 54
48 LayerImpl* FakeLayerTreeHost::CommitAndCreateLayerImplTree() { 55 LayerImpl* FakeLayerTreeHost::CommitAndCreateLayerImplTree() {
49 scoped_ptr<LayerImpl> old_root_layer_impl = active_tree()->DetachLayerTree(); 56 scoped_ptr<LayerImpl> old_root_layer_impl = active_tree()->DetachLayerTree();
50 57
51 scoped_ptr<LayerImpl> layer_impl = TreeSynchronizer::SynchronizeTrees( 58 scoped_ptr<LayerImpl> layer_impl = TreeSynchronizer::SynchronizeTrees(
52 root_layer(), std::move(old_root_layer_impl), active_tree()); 59 root_layer(), std::move(old_root_layer_impl), active_tree());
53 active_tree()->SetPropertyTrees(*property_trees()); 60 active_tree()->SetPropertyTrees(*property_trees());
54 TreeSynchronizer::PushProperties(root_layer(), layer_impl.get()); 61 TreeSynchronizer::PushProperties(root_layer(), layer_impl.get());
55 62
56 active_tree()->SetRootLayer(std::move(layer_impl)); 63 active_tree()->SetRootLayer(std::move(layer_impl));
57 64
58 if (page_scale_layer() && inner_viewport_scroll_layer()) { 65 if (page_scale_layer() && inner_viewport_scroll_layer()) {
59 active_tree()->SetViewportLayersFromIds( 66 active_tree()->SetViewportLayersFromIds(
60 overscroll_elasticity_layer() ? overscroll_elasticity_layer()->id() 67 overscroll_elasticity_layer() ? overscroll_elasticity_layer()->id()
61 : Layer::INVALID_ID, 68 : Layer::INVALID_ID,
62 page_scale_layer()->id(), inner_viewport_scroll_layer()->id(), 69 page_scale_layer()->id(), inner_viewport_scroll_layer()->id(),
63 outer_viewport_scroll_layer() ? outer_viewport_scroll_layer()->id() 70 outer_viewport_scroll_layer() ? outer_viewport_scroll_layer()->id()
64 : Layer::INVALID_ID); 71 : Layer::INVALID_ID);
65 } 72 }
66 73
67 active_tree()->UpdatePropertyTreesForBoundsDelta(); 74 active_tree()->UpdatePropertyTreesForBoundsDelta();
68 return active_tree()->root_layer(); 75 return active_tree()->root_layer();
69 } 76 }
70 77
71 } // namespace cc 78 } // namespace cc
OLDNEW
« no previous file with comments | « cc/test/fake_layer_tree_host.h ('k') | cc/test/fake_scrollbar.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698