OLD | NEW |
---|---|
1 // Copyright 2012 The Chromium Authors. All rights reserved. | 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 | 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 #ifndef CC_RESOURCES_PICTURE_LAYER_TILING_H_ | 5 #ifndef CC_RESOURCES_PICTURE_LAYER_TILING_H_ |
6 #define CC_RESOURCES_PICTURE_LAYER_TILING_H_ | 6 #define CC_RESOURCES_PICTURE_LAYER_TILING_H_ |
7 | 7 |
8 #include <utility> | 8 #include <utility> |
9 #include <vector> | 9 #include <vector> |
10 | 10 |
(...skipping 27 matching lines...) Expand all Loading... | |
38 virtual size_t GetMaxTilesForInterestArea() const = 0; | 38 virtual size_t GetMaxTilesForInterestArea() const = 0; |
39 virtual float GetSkewportTargetTimeInSeconds() const = 0; | 39 virtual float GetSkewportTargetTimeInSeconds() const = 0; |
40 virtual int GetSkewportExtrapolationLimitInContentPixels() const = 0; | 40 virtual int GetSkewportExtrapolationLimitInContentPixels() const = 0; |
41 | 41 |
42 protected: | 42 protected: |
43 virtual ~PictureLayerTilingClient() {} | 43 virtual ~PictureLayerTilingClient() {} |
44 }; | 44 }; |
45 | 45 |
46 class CC_EXPORT PictureLayerTiling { | 46 class CC_EXPORT PictureLayerTiling { |
47 public: | 47 public: |
48 class CC_EXPORT TilingRasterTileIterator { | |
epennerAtGoogle
2014/03/05 00:16:03
Cool. One thing I didn't see in here is whether we
vmpstr
2014/03/05 00:37:21
Not really... See my comment in the unittests. I t
| |
49 public: | |
50 enum Type { VISIBLE, SKEWPORT, EVENTUALLY }; | |
51 | |
52 TilingRasterTileIterator(); | |
53 explicit TilingRasterTileIterator(PictureLayerTiling* tiling); | |
54 ~TilingRasterTileIterator(); | |
55 | |
56 operator bool() const { return !!current_tile_; } | |
57 Tile* operator*() { return current_tile_; } | |
58 Type get_type() const { return type_; } | |
59 | |
60 TilingRasterTileIterator& operator++(); | |
61 | |
62 bool HasVisibleTiles() const { return type_ == VISIBLE; } | |
63 | |
64 gfx::Rect TileBounds() const { | |
65 DCHECK(*this); | |
66 if (type_ == VISIBLE) { | |
67 return tiling_->tiling_data_.TileBounds(visible_iterator_.index_x(), | |
68 visible_iterator_.index_y()); | |
69 } | |
70 return tiling_->tiling_data_.TileBounds(spiral_iterator_.index_x(), | |
71 spiral_iterator_.index_y()); | |
72 } | |
73 | |
74 private: | |
75 void AdvancePhase(); | |
76 | |
77 PictureLayerTiling* tiling_; | |
78 | |
79 Type type_; | |
80 | |
81 Tile* current_tile_; | |
82 TilingData::Iterator visible_iterator_; | |
83 TilingData::SpiralDifferenceIterator spiral_iterator_; | |
84 }; | |
85 | |
48 ~PictureLayerTiling(); | 86 ~PictureLayerTiling(); |
49 | 87 |
50 // Create a tiling with no tiles. CreateTiles must be called to add some. | 88 // Create a tiling with no tiles. CreateTiles must be called to add some. |
51 static scoped_ptr<PictureLayerTiling> Create( | 89 static scoped_ptr<PictureLayerTiling> Create( |
52 float contents_scale, | 90 float contents_scale, |
53 const gfx::Size& layer_bounds, | 91 const gfx::Size& layer_bounds, |
54 PictureLayerTilingClient* client); | 92 PictureLayerTilingClient* client); |
55 gfx::Size layer_bounds() const { return layer_bounds_; } | 93 gfx::Size layer_bounds() const { return layer_bounds_; } |
56 void SetLayerBounds(const gfx::Size& layer_bounds); | 94 void SetLayerBounds(const gfx::Size& layer_bounds); |
57 void Invalidate(const Region& layer_region); | 95 void Invalidate(const Region& layer_region); |
58 void CreateMissingTilesInLiveTilesRect(); | 96 void CreateMissingTilesInLiveTilesRect(); |
59 | 97 |
60 void SetCanUseLCDText(bool can_use_lcd_text); | 98 void SetCanUseLCDText(bool can_use_lcd_text); |
61 | 99 |
62 void SetClient(PictureLayerTilingClient* client); | 100 void SetClient(PictureLayerTilingClient* client); |
63 void set_resolution(TileResolution resolution) { resolution_ = resolution; } | 101 void set_resolution(TileResolution resolution) { resolution_ = resolution; } |
64 TileResolution resolution() const { return resolution_; } | 102 TileResolution resolution() const { return resolution_; } |
65 | 103 |
66 gfx::Rect ContentRect() const; | 104 gfx::Rect ContentRect() const; |
67 gfx::SizeF ContentSizeF() const; | 105 gfx::SizeF ContentSizeF() const; |
68 gfx::Rect live_tiles_rect() const { return live_tiles_rect_; } | 106 gfx::Rect live_tiles_rect() const { return live_tiles_rect_; } |
69 gfx::Size tile_size() const { return tiling_data_.max_texture_size(); } | 107 gfx::Size tile_size() const { return tiling_data_.max_texture_size(); } |
70 float contents_scale() const { return contents_scale_; } | 108 float contents_scale() const { return contents_scale_; } |
71 | 109 |
110 Tile* TileAt(int i, int j) const { | |
111 TileMap::const_iterator iter = tiles_.find(TileMapKey(i, j)); | |
112 return (iter == tiles_.end()) ? NULL : iter->second.get(); | |
113 } | |
114 | |
72 void CreateAllTilesForTesting() { | 115 void CreateAllTilesForTesting() { |
73 SetLiveTilesRect(gfx::Rect(tiling_data_.total_size())); | 116 SetLiveTilesRect(gfx::Rect(tiling_data_.total_size())); |
74 } | 117 } |
75 | 118 |
76 std::vector<Tile*> AllTilesForTesting() const { | 119 std::vector<Tile*> AllTilesForTesting() const { |
77 std::vector<Tile*> all_tiles; | 120 std::vector<Tile*> all_tiles; |
78 for (TileMap::const_iterator it = tiles_.begin(); | 121 for (TileMap::const_iterator it = tiles_.begin(); |
79 it != tiles_.end(); ++it) | 122 it != tiles_.end(); ++it) |
80 all_tiles.push_back(it->second.get()); | 123 all_tiles.push_back(it->second.get()); |
81 return all_tiles; | 124 return all_tiles; |
82 } | 125 } |
83 | 126 |
84 Tile* TileAt(int i, int j) const; | |
85 | |
86 // Iterate over all tiles to fill content_rect. Even if tiles are invalid | 127 // Iterate over all tiles to fill content_rect. Even if tiles are invalid |
87 // (i.e. no valid resource) this tiling should still iterate over them. | 128 // (i.e. no valid resource) this tiling should still iterate over them. |
88 // The union of all geometry_rect calls for each element iterated over should | 129 // The union of all geometry_rect calls for each element iterated over should |
89 // exactly equal content_rect and no two geometry_rects should intersect. | 130 // exactly equal content_rect and no two geometry_rects should intersect. |
90 class CC_EXPORT CoverageIterator { | 131 class CC_EXPORT CoverageIterator { |
91 public: | 132 public: |
92 CoverageIterator(); | 133 CoverageIterator(); |
93 CoverageIterator(const PictureLayerTiling* tiling, | 134 CoverageIterator(const PictureLayerTiling* tiling, |
94 float dest_scale, | 135 float dest_scale, |
95 const gfx::Rect& rect); | 136 const gfx::Rect& rect); |
(...skipping 56 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
152 // be called before DidBecomeActive, as it resets the active priority | 193 // be called before DidBecomeActive, as it resets the active priority |
153 // while DidBecomeActive promotes pending priority on a similar set of tiles. | 194 // while DidBecomeActive promotes pending priority on a similar set of tiles. |
154 void DidBecomeRecycled(); | 195 void DidBecomeRecycled(); |
155 | 196 |
156 void UpdateTilesToCurrentPile(); | 197 void UpdateTilesToCurrentPile(); |
157 | 198 |
158 bool NeedsUpdateForFrameAtTime(double frame_time_in_seconds) { | 199 bool NeedsUpdateForFrameAtTime(double frame_time_in_seconds) { |
159 return frame_time_in_seconds != last_impl_frame_time_in_seconds_; | 200 return frame_time_in_seconds != last_impl_frame_time_in_seconds_; |
160 } | 201 } |
161 | 202 |
203 size_t RequiredGPUMemoryInBytes() const; | |
204 | |
162 scoped_ptr<base::Value> AsValue() const; | 205 scoped_ptr<base::Value> AsValue() const; |
163 size_t GPUMemoryUsageInBytes() const; | 206 size_t GPUMemoryUsageInBytes() const; |
164 | 207 |
165 struct RectExpansionCache { | 208 struct RectExpansionCache { |
166 RectExpansionCache(); | 209 RectExpansionCache(); |
167 | 210 |
168 gfx::Rect previous_start; | 211 gfx::Rect previous_start; |
169 gfx::Rect previous_bounds; | 212 gfx::Rect previous_bounds; |
170 gfx::Rect previous_result; | 213 gfx::Rect previous_result; |
171 int64 previous_target; | 214 int64 previous_target; |
172 }; | 215 }; |
173 | 216 |
174 static | 217 static |
175 gfx::Rect ExpandRectEquallyToAreaBoundedBy( | 218 gfx::Rect ExpandRectEquallyToAreaBoundedBy( |
176 const gfx::Rect& starting_rect, | 219 const gfx::Rect& starting_rect, |
177 int64 target_area, | 220 int64 target_area, |
178 const gfx::Rect& bounding_rect, | 221 const gfx::Rect& bounding_rect, |
179 RectExpansionCache* cache); | 222 RectExpansionCache* cache); |
180 | 223 |
181 bool has_ever_been_updated() const { | 224 bool has_ever_been_updated() const { |
182 return last_impl_frame_time_in_seconds_ != 0.0; | 225 return last_impl_frame_time_in_seconds_ != 0.0; |
183 } | 226 } |
184 | 227 |
185 protected: | 228 protected: |
229 friend class TilingRasterTileIterator; | |
230 friend class TilingEvictionTileIterator; | |
231 | |
186 typedef std::pair<int, int> TileMapKey; | 232 typedef std::pair<int, int> TileMapKey; |
187 typedef base::hash_map<TileMapKey, scoped_refptr<Tile> > TileMap; | 233 typedef base::hash_map<TileMapKey, scoped_refptr<Tile> > TileMap; |
188 | 234 |
189 PictureLayerTiling(float contents_scale, | 235 PictureLayerTiling(float contents_scale, |
190 const gfx::Size& layer_bounds, | 236 const gfx::Size& layer_bounds, |
191 PictureLayerTilingClient* client); | 237 PictureLayerTilingClient* client); |
192 void SetLiveTilesRect(const gfx::Rect& live_tiles_rect); | 238 void SetLiveTilesRect(const gfx::Rect& live_tiles_rect); |
193 void CreateTile(int i, int j, const PictureLayerTiling* twin_tiling); | 239 void CreateTile(int i, int j, const PictureLayerTiling* twin_tiling); |
194 | 240 |
195 // Computes a skewport. The calculation extrapolates the last visible | 241 // Computes a skewport. The calculation extrapolates the last visible |
(...skipping 10 matching lines...) Expand all Loading... | |
206 TileResolution resolution_; | 252 TileResolution resolution_; |
207 PictureLayerTilingClient* client_; | 253 PictureLayerTilingClient* client_; |
208 | 254 |
209 // Internal data. | 255 // Internal data. |
210 TilingData tiling_data_; | 256 TilingData tiling_data_; |
211 TileMap tiles_; // It is not legal to have a NULL tile in the tiles_ map. | 257 TileMap tiles_; // It is not legal to have a NULL tile in the tiles_ map. |
212 gfx::Rect live_tiles_rect_; | 258 gfx::Rect live_tiles_rect_; |
213 | 259 |
214 // State saved for computing velocities based upon finite differences. | 260 // State saved for computing velocities based upon finite differences. |
215 double last_impl_frame_time_in_seconds_; | 261 double last_impl_frame_time_in_seconds_; |
216 gfx::RectF last_visible_rect_in_content_space_; | 262 gfx::Rect last_visible_rect_in_content_space_; |
263 | |
264 gfx::Rect current_visible_rect_in_content_space_; | |
265 gfx::Rect current_skewport_; | |
266 gfx::Rect current_eventually_rect_; | |
267 | |
268 WhichTree last_update_tree_; | |
217 | 269 |
218 friend class CoverageIterator; | 270 friend class CoverageIterator; |
219 | 271 |
220 private: | 272 private: |
221 DISALLOW_ASSIGN(PictureLayerTiling); | 273 DISALLOW_ASSIGN(PictureLayerTiling); |
222 | 274 |
223 RectExpansionCache expansion_cache_; | 275 RectExpansionCache expansion_cache_; |
224 }; | 276 }; |
225 | 277 |
226 } // namespace cc | 278 } // namespace cc |
227 | 279 |
228 #endif // CC_RESOURCES_PICTURE_LAYER_TILING_H_ | 280 #endif // CC_RESOURCES_PICTURE_LAYER_TILING_H_ |
OLD | NEW |