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
3 // found in the LICENSE file.
5 #ifndef CC_RESOURCES_TILE_PRIORITY_H_
6 #define CC_RESOURCES_TILE_PRIORITY_H_
11 #include "base/memory/ref_counted.h"
12 #include "base/memory/scoped_ptr.h"
13 #include "cc/resources/picture_pile.h"
14 #include "ui/gfx/quad_f.h"
15 #include "ui/gfx/rect.h"
16 #include "ui/gfx/size.h"
25 // Note: these must be 0 and 1 because we index with them in various places,
26 // e.g. in Tile::priority_.
30 // Be sure to update WhichTreeAsValue when adding new fields.
32 scoped_ptr
<base::Value
> WhichTreeAsValue(
38 NON_IDEAL_RESOLUTION
= 2,
40 scoped_ptr
<base::Value
> TileResolutionAsValue(
41 TileResolution resolution
);
43 struct CC_EXPORT TilePriority
{
44 enum PriorityBin
{ NOW
, SOON
, EVENTUALLY
};
47 : resolution(NON_IDEAL_RESOLUTION
),
48 required_for_activation(false),
49 priority_bin(EVENTUALLY
),
50 distance_to_visible(std::numeric_limits
<float>::infinity()) {}
52 TilePriority(TileResolution resolution
,
54 float distance_to_visible
)
55 : resolution(resolution
),
56 required_for_activation(false),
58 distance_to_visible(distance_to_visible
) {}
60 TilePriority(const TilePriority
& active
, const TilePriority
& pending
) {
61 if (active
.resolution
== HIGH_RESOLUTION
||
62 pending
.resolution
== HIGH_RESOLUTION
)
63 resolution
= HIGH_RESOLUTION
;
64 else if (active
.resolution
== LOW_RESOLUTION
||
65 pending
.resolution
== LOW_RESOLUTION
)
66 resolution
= LOW_RESOLUTION
;
68 resolution
= NON_IDEAL_RESOLUTION
;
70 required_for_activation
=
71 active
.required_for_activation
|| pending
.required_for_activation
;
73 if (active
.priority_bin
< pending
.priority_bin
) {
74 priority_bin
= active
.priority_bin
;
75 distance_to_visible
= active
.distance_to_visible
;
76 } else if (active
.priority_bin
> pending
.priority_bin
) {
77 priority_bin
= pending
.priority_bin
;
78 distance_to_visible
= pending
.distance_to_visible
;
80 priority_bin
= active
.priority_bin
;
82 std::min(active
.distance_to_visible
, pending
.distance_to_visible
);
86 scoped_ptr
<base::Value
> AsValue() const;
88 bool operator ==(const TilePriority
& other
) const {
89 return resolution
== other
.resolution
&&
90 priority_bin
== other
.priority_bin
&&
91 distance_to_visible
== other
.distance_to_visible
&&
92 required_for_activation
== other
.required_for_activation
;
95 bool operator !=(const TilePriority
& other
) const {
96 return !(*this == other
);
99 bool IsHigherPriorityThan(const TilePriority
& other
) const {
100 return priority_bin
< other
.priority_bin
||
101 (priority_bin
== other
.priority_bin
&&
102 distance_to_visible
< other
.distance_to_visible
);
105 TileResolution resolution
;
106 bool required_for_activation
;
107 PriorityBin priority_bin
;
108 float distance_to_visible
;
111 scoped_ptr
<base::Value
> TilePriorityBinAsValue(TilePriority::PriorityBin bin
);
113 enum TileMemoryLimitPolicy
{
117 // You might be made visible, but you're not being interacted with.
118 ALLOW_ABSOLUTE_MINIMUM
= 1, // Tall.
120 // You're being interacted with, but we're low on memory.
121 ALLOW_PREPAINT_ONLY
= 2, // Grande.
123 // You're the only thing in town. Go crazy.
124 ALLOW_ANYTHING
= 3, // Venti.
126 NUM_TILE_MEMORY_LIMIT_POLICIES
= 4,
128 // NOTE: Be sure to update TreePriorityAsValue and kBinPolicyMap when adding
129 // or reordering fields.
131 scoped_ptr
<base::Value
> TileMemoryLimitPolicyAsValue(
132 TileMemoryLimitPolicy policy
);
135 SAME_PRIORITY_FOR_BOTH_TREES
,
136 SMOOTHNESS_TAKES_PRIORITY
,
137 NEW_CONTENT_TAKES_PRIORITY
139 // Be sure to update TreePriorityAsValue when adding new fields.
141 scoped_ptr
<base::Value
> TreePriorityAsValue(TreePriority prio
);
143 class GlobalStateThatImpactsTilePriority
{
145 GlobalStateThatImpactsTilePriority()
146 : memory_limit_policy(ALLOW_NOTHING
),
147 soft_memory_limit_in_bytes(0),
148 hard_memory_limit_in_bytes(0),
149 num_resources_limit(0),
150 tree_priority(SAME_PRIORITY_FOR_BOTH_TREES
) {}
152 TileMemoryLimitPolicy memory_limit_policy
;
154 size_t soft_memory_limit_in_bytes
;
155 size_t hard_memory_limit_in_bytes
;
156 size_t num_resources_limit
;
158 TreePriority tree_priority
;
160 bool operator==(const GlobalStateThatImpactsTilePriority
& other
) const {
161 return memory_limit_policy
== other
.memory_limit_policy
&&
162 soft_memory_limit_in_bytes
== other
.soft_memory_limit_in_bytes
&&
163 hard_memory_limit_in_bytes
== other
.hard_memory_limit_in_bytes
&&
164 num_resources_limit
== other
.num_resources_limit
&&
165 tree_priority
== other
.tree_priority
;
167 bool operator!=(const GlobalStateThatImpactsTilePriority
& other
) const {
168 return !(*this == other
);
171 scoped_ptr
<base::Value
> AsValue() const;
176 #endif // CC_RESOURCES_TILE_PRIORITY_H_