1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
|
// Copyright 2016 The Chromium Authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#include "cc/trees/scroll_node.h"
#include "cc/base/math_util.h"
#include "cc/input/main_thread_scrolling_reason.h"
#include "cc/layers/layer.h"
#include "cc/paint/element_id.h"
#include "cc/trees/property_tree.h"
#include "base/trace_event/traced_value.h"
namespace cc {
ScrollNode::ScrollNode()
: id(ScrollTree::kInvalidNodeId),
parent_id(ScrollTree::kInvalidNodeId),
main_thread_scrolling_reasons(
MainThreadScrollingReason::kNotScrollingOnMain),
scrollable(false),
max_scroll_offset_affected_by_page_scale(false),
scrolls_inner_viewport(false),
scrolls_outer_viewport(false),
prevent_viewport_scrolling_from_inner(false),
should_flatten(false),
user_scrollable_horizontal(false),
user_scrollable_vertical(false),
transform_id(0),
overscroll_behavior(OverscrollBehavior::kOverscrollBehaviorTypeAuto),
is_composited(false) {}
ScrollNode::ScrollNode(const ScrollNode& other) = default;
ScrollNode::~ScrollNode() = default;
bool ScrollNode::operator==(const ScrollNode& other) const {
return id == other.id && parent_id == other.parent_id &&
scrollable == other.scrollable &&
main_thread_scrolling_reasons == other.main_thread_scrolling_reasons &&
container_bounds == other.container_bounds && bounds == other.bounds &&
max_scroll_offset_affected_by_page_scale ==
other.max_scroll_offset_affected_by_page_scale &&
scrolls_inner_viewport == other.scrolls_inner_viewport &&
prevent_viewport_scrolling_from_inner ==
other.prevent_viewport_scrolling_from_inner &&
scrolls_outer_viewport == other.scrolls_outer_viewport &&
offset_to_transform_parent == other.offset_to_transform_parent &&
should_flatten == other.should_flatten &&
user_scrollable_horizontal == other.user_scrollable_horizontal &&
user_scrollable_vertical == other.user_scrollable_vertical &&
element_id == other.element_id && transform_id == other.transform_id &&
overscroll_behavior == other.overscroll_behavior &&
snap_container_data == other.snap_container_data &&
is_composited == other.is_composited;
}
void ScrollNode::AsValueInto(base::trace_event::TracedValue* value) const {
value->SetInteger("id", id);
value->SetInteger("parent_id", parent_id);
value->SetBoolean("scrollable", scrollable);
MathUtil::AddToTracedValue("container_bounds", container_bounds, value);
MathUtil::AddToTracedValue("bounds", bounds, value);
MathUtil::AddToTracedValue("offset_to_transform_parent",
offset_to_transform_parent, value);
value->SetBoolean("should_flatten", should_flatten);
value->SetBoolean("user_scrollable_horizontal", user_scrollable_horizontal);
value->SetBoolean("user_scrollable_vertical", user_scrollable_vertical);
value->SetBoolean("scrolls_inner_viewport", scrolls_inner_viewport);
value->SetBoolean("scrolls_outer_viewport", scrolls_outer_viewport);
value->SetBoolean("prevent_viewport_scrolling_from_inner",
prevent_viewport_scrolling_from_inner);
element_id.AddToTracedValue(value);
value->SetInteger("transform_id", transform_id);
value->SetInteger("overscroll_behavior_x", overscroll_behavior.x);
value->SetInteger("overscroll_behavior_y", overscroll_behavior.y);
if (snap_container_data) {
value->SetString("snap_container_rect",
snap_container_data->rect().ToString());
if (snap_container_data->size()) {
value->BeginArray("snap_area_rects");
for (size_t i = 0; i < snap_container_data->size(); ++i) {
value->AppendString(snap_container_data->at(i).rect.ToString());
}
value->EndArray();
}
}
value->SetBoolean("is_composited", is_composited);
}
} // namespace cc
|