OLD | NEW |
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/resources/managed_tile_state.h" | 5 #include "cc/resources/managed_tile_state.h" |
6 | 6 |
7 #include <limits> | 7 #include <limits> |
8 | 8 |
9 #include "cc/base/math_util.h" | 9 #include "cc/base/math_util.h" |
10 | 10 |
11 namespace cc { | 11 namespace cc { |
12 | 12 |
13 scoped_ptr<base::Value> ManagedTileBinAsValue(ManagedTileBin bin) { | 13 scoped_ptr<base::Value> ManagedTileBinAsValue(ManagedTileBin bin) { |
14 switch (bin) { | 14 switch (bin) { |
15 case NOW_AND_READY_TO_DRAW_BIN: | 15 case NOW_AND_READY_TO_DRAW_BIN: |
16 return scoped_ptr<base::Value>(base::Value::CreateStringValue( | 16 return scoped_ptr<base::Value>( |
17 "NOW_AND_READY_TO_DRAW_BIN")); | 17 base::Value::CreateStringValue("NOW_AND_READY_TO_DRAW_BIN")); |
18 case NOW_BIN: | 18 case NOW_BIN: |
19 return scoped_ptr<base::Value>(base::Value::CreateStringValue( | 19 return scoped_ptr<base::Value>( |
20 "NOW_BIN")); | 20 base::Value::CreateStringValue("NOW_BIN")); |
21 case SOON_BIN: | 21 case SOON_BIN: |
22 return scoped_ptr<base::Value>(base::Value::CreateStringValue( | 22 return scoped_ptr<base::Value>( |
23 "SOON_BIN")); | 23 base::Value::CreateStringValue("SOON_BIN")); |
24 case EVENTUALLY_AND_ACTIVE_BIN: | 24 case EVENTUALLY_AND_ACTIVE_BIN: |
25 return scoped_ptr<base::Value>(base::Value::CreateStringValue( | 25 return scoped_ptr<base::Value>( |
26 "EVENTUALLY_AND_ACTIVE_BIN")); | 26 base::Value::CreateStringValue("EVENTUALLY_AND_ACTIVE_BIN")); |
27 case EVENTUALLY_BIN: | 27 case EVENTUALLY_BIN: |
28 return scoped_ptr<base::Value>(base::Value::CreateStringValue( | 28 return scoped_ptr<base::Value>( |
29 "EVENTUALLY_BIN")); | 29 base::Value::CreateStringValue("EVENTUALLY_BIN")); |
30 case NEVER_AND_ACTIVE_BIN: | 30 case AT_LAST_AND_ACTIVE_BIN: |
31 return scoped_ptr<base::Value>(base::Value::CreateStringValue( | 31 return scoped_ptr<base::Value>( |
32 "NEVER_AND_ACTIVE_BIN")); | 32 base::Value::CreateStringValue("AT_LAST_AND_ACTIVE_BIN")); |
33 case NEVER_BIN: | 33 case AT_LAST_BIN: |
34 return scoped_ptr<base::Value>(base::Value::CreateStringValue( | 34 return scoped_ptr<base::Value>( |
35 "NEVER_BIN")); | 35 base::Value::CreateStringValue("AT_LAST_BIN")); |
36 default: | 36 case NEVER_BIN: |
37 DCHECK(false) << "Unrecognized ManagedTileBin value " << bin; | 37 return scoped_ptr<base::Value>( |
38 return scoped_ptr<base::Value>(base::Value::CreateStringValue( | 38 base::Value::CreateStringValue("NEVER_BIN")); |
39 "<unknown ManagedTileBin value>")); | 39 case NUM_BINS: |
| 40 NOTREACHED(); |
| 41 return scoped_ptr<base::Value>( |
| 42 base::Value::CreateStringValue("Invalid Bin (NUM_BINS)")); |
40 } | 43 } |
41 } | 44 return scoped_ptr<base::Value>( |
42 | 45 base::Value::CreateStringValue("Invalid Bin (UNKNOWN)")); |
43 scoped_ptr<base::Value> ManagedTileBinPriorityAsValue( | |
44 ManagedTileBinPriority bin_priority) { | |
45 switch (bin_priority) { | |
46 case HIGH_PRIORITY_BIN: | |
47 return scoped_ptr<base::Value>(base::Value::CreateStringValue( | |
48 "HIGH_PRIORITY_BIN")); | |
49 case LOW_PRIORITY_BIN: | |
50 return scoped_ptr<base::Value>(base::Value::CreateStringValue( | |
51 "LOW_PRIORITY_BIN")); | |
52 default: | |
53 DCHECK(false) << "Unrecognized ManagedTileBinPriority value"; | |
54 return scoped_ptr<base::Value>(base::Value::CreateStringValue( | |
55 "<unknown ManagedTileBinPriority value>")); | |
56 } | |
57 } | 46 } |
58 | 47 |
59 ManagedTileState::ManagedTileState() | 48 ManagedTileState::ManagedTileState() |
60 : raster_mode(LOW_QUALITY_RASTER_MODE), | 49 : raster_mode(LOW_QUALITY_RASTER_MODE), |
| 50 bin(NEVER_BIN), |
61 gpu_memmgr_stats_bin(NEVER_BIN), | 51 gpu_memmgr_stats_bin(NEVER_BIN), |
62 resolution(NON_IDEAL_RESOLUTION), | 52 resolution(NON_IDEAL_RESOLUTION), |
63 required_for_activation(false), | 53 required_for_activation(false), |
64 time_to_needed_in_seconds(std::numeric_limits<float>::infinity()), | 54 time_to_needed_in_seconds(std::numeric_limits<float>::infinity()), |
65 distance_to_visible_in_pixels(std::numeric_limits<float>::infinity()), | 55 distance_to_visible_in_pixels(std::numeric_limits<float>::infinity()), |
66 visible_and_ready_to_draw(false), | 56 visible_and_ready_to_draw(false), |
67 scheduled_priority(0) { | 57 scheduled_priority(0) { |
68 for (int i = 0; i < NUM_TREES; ++i) { | 58 for (int i = 0; i < NUM_TREES; ++i) |
69 tree_bin[i] = NEVER_BIN; | 59 tree_bin[i] = NEVER_BIN; |
70 bin[i] = NEVER_BIN; | |
71 } | |
72 } | 60 } |
73 | 61 |
74 ManagedTileState::TileVersion::TileVersion() | 62 ManagedTileState::TileVersion::TileVersion() |
75 : mode_(RESOURCE_MODE), | 63 : mode_(RESOURCE_MODE), |
76 has_text_(false) { | 64 has_text_(false) { |
77 } | 65 } |
78 | 66 |
79 ManagedTileState::TileVersion::~TileVersion() { | 67 ManagedTileState::TileVersion::~TileVersion() { |
80 DCHECK(!resource_); | 68 DCHECK(!resource_); |
81 } | 69 } |
(...skipping 17 matching lines...) Expand all Loading... |
99 return resource_->bytes(); | 87 return resource_->bytes(); |
100 } | 88 } |
101 | 89 |
102 ManagedTileState::~ManagedTileState() { | 90 ManagedTileState::~ManagedTileState() { |
103 } | 91 } |
104 | 92 |
105 scoped_ptr<base::Value> ManagedTileState::AsValue() const { | 93 scoped_ptr<base::Value> ManagedTileState::AsValue() const { |
106 scoped_ptr<base::DictionaryValue> state(new base::DictionaryValue()); | 94 scoped_ptr<base::DictionaryValue> state(new base::DictionaryValue()); |
107 state->SetBoolean("has_resource", | 95 state->SetBoolean("has_resource", |
108 tile_versions[raster_mode].resource_.get() != 0); | 96 tile_versions[raster_mode].resource_.get() != 0); |
109 state->Set("bin.0", ManagedTileBinAsValue(bin[ACTIVE_TREE]).release()); | 97 state->Set("tree_bin.0", |
110 state->Set("bin.1", ManagedTileBinAsValue(bin[PENDING_TREE]).release()); | 98 ManagedTileBinAsValue(tree_bin[ACTIVE_TREE]).release()); |
| 99 state->Set("tree_bin.1", |
| 100 ManagedTileBinAsValue(tree_bin[PENDING_TREE]).release()); |
111 state->Set("gpu_memmgr_stats_bin", | 101 state->Set("gpu_memmgr_stats_bin", |
112 ManagedTileBinAsValue(bin[ACTIVE_TREE]).release()); | 102 ManagedTileBinAsValue(gpu_memmgr_stats_bin).release()); |
113 state->Set("resolution", TileResolutionAsValue(resolution).release()); | 103 state->Set("resolution", TileResolutionAsValue(resolution).release()); |
114 state->Set("time_to_needed_in_seconds", | 104 state->Set("time_to_needed_in_seconds", |
115 MathUtil::AsValueSafely(time_to_needed_in_seconds).release()); | 105 MathUtil::AsValueSafely(time_to_needed_in_seconds).release()); |
116 state->Set("distance_to_visible_in_pixels", | 106 state->Set("distance_to_visible_in_pixels", |
117 MathUtil::AsValueSafely(distance_to_visible_in_pixels).release()); | 107 MathUtil::AsValueSafely(distance_to_visible_in_pixels).release()); |
118 state->SetBoolean("required_for_activation", required_for_activation); | 108 state->SetBoolean("required_for_activation", required_for_activation); |
119 state->SetBoolean( | 109 state->SetBoolean( |
120 "is_solid_color", | 110 "is_solid_color", |
121 tile_versions[raster_mode].mode_ == TileVersion::SOLID_COLOR_MODE); | 111 tile_versions[raster_mode].mode_ == TileVersion::SOLID_COLOR_MODE); |
122 state->SetBoolean( | 112 state->SetBoolean( |
123 "is_transparent", | 113 "is_transparent", |
124 tile_versions[raster_mode].mode_ == TileVersion::SOLID_COLOR_MODE && | 114 tile_versions[raster_mode].mode_ == TileVersion::SOLID_COLOR_MODE && |
125 !SkColorGetA(tile_versions[raster_mode].solid_color_)); | 115 !SkColorGetA(tile_versions[raster_mode].solid_color_)); |
126 state->SetInteger("scheduled_priority", scheduled_priority); | 116 state->SetInteger("scheduled_priority", scheduled_priority); |
127 return state.PassAs<base::Value>(); | 117 return state.PassAs<base::Value>(); |
128 } | 118 } |
129 | 119 |
130 } // namespace cc | 120 } // namespace cc |
131 | 121 |
OLD | NEW |