| 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 23 matching lines...) Expand all Loading... |
| 34 const gfx::Rect& content_rect) = 0; | 34 const gfx::Rect& content_rect) = 0; |
| 35 virtual PicturePileImpl* GetPile() = 0; | 35 virtual PicturePileImpl* GetPile() = 0; |
| 36 virtual gfx::Size CalculateTileSize( | 36 virtual gfx::Size CalculateTileSize( |
| 37 const gfx::Size& content_bounds) const = 0; | 37 const gfx::Size& content_bounds) const = 0; |
| 38 virtual const Region* GetInvalidation() = 0; | 38 virtual const Region* GetInvalidation() = 0; |
| 39 virtual const PictureLayerTiling* GetTwinTiling( | 39 virtual const PictureLayerTiling* GetTwinTiling( |
| 40 const PictureLayerTiling* tiling) const = 0; | 40 const PictureLayerTiling* tiling) const = 0; |
| 41 virtual size_t GetMaxTilesForInterestArea() const = 0; | 41 virtual size_t GetMaxTilesForInterestArea() const = 0; |
| 42 virtual float GetSkewportTargetTimeInSeconds() const = 0; | 42 virtual float GetSkewportTargetTimeInSeconds() const = 0; |
| 43 virtual int GetSkewportExtrapolationLimitInContentPixels() const = 0; | 43 virtual int GetSkewportExtrapolationLimitInContentPixels() const = 0; |
| 44 virtual WhichTree GetTree() const = 0; |
| 45 virtual bool RequiresHighResToDraw() const = 0; |
| 44 | 46 |
| 45 protected: | 47 protected: |
| 46 virtual ~PictureLayerTilingClient() {} | 48 virtual ~PictureLayerTilingClient() {} |
| 47 }; | 49 }; |
| 48 | 50 |
| 49 class CC_EXPORT PictureLayerTiling { | 51 class CC_EXPORT PictureLayerTiling { |
| 50 public: | 52 public: |
| 51 class CC_EXPORT TilingRasterTileIterator { | 53 class CC_EXPORT TilingRasterTileIterator { |
| 52 public: | 54 public: |
| 53 TilingRasterTileIterator(); | 55 TilingRasterTileIterator(); |
| (...skipping 12 matching lines...) Expand all Loading... |
| 66 return tiling_->tiling_data_.TileBounds(visible_iterator_.index_x(), | 68 return tiling_->tiling_data_.TileBounds(visible_iterator_.index_x(), |
| 67 visible_iterator_.index_y()); | 69 visible_iterator_.index_y()); |
| 68 } | 70 } |
| 69 return tiling_->tiling_data_.TileBounds(spiral_iterator_.index_x(), | 71 return tiling_->tiling_data_.TileBounds(spiral_iterator_.index_x(), |
| 70 spiral_iterator_.index_y()); | 72 spiral_iterator_.index_y()); |
| 71 } | 73 } |
| 72 | 74 |
| 73 private: | 75 private: |
| 74 void AdvancePhase(); | 76 void AdvancePhase(); |
| 75 bool TileNeedsRaster(Tile* tile) const { | 77 bool TileNeedsRaster(Tile* tile) const { |
| 78 if (tile->is_occluded(tree_)) |
| 79 return false; |
| 76 RasterMode mode = tile->DetermineRasterModeForTree(tree_); | 80 RasterMode mode = tile->DetermineRasterModeForTree(tree_); |
| 77 return tile->NeedsRasterForMode(mode); | 81 return tile->NeedsRasterForMode(mode); |
| 78 } | 82 } |
| 79 | 83 |
| 80 PictureLayerTiling* tiling_; | 84 PictureLayerTiling* tiling_; |
| 81 | 85 |
| 82 TilePriority::PriorityBin type_; | 86 TilePriority::PriorityBin type_; |
| 83 gfx::Rect visible_rect_in_content_space_; | |
| 84 gfx::Rect skewport_in_content_space_; | |
| 85 gfx::Rect eventually_rect_in_content_space_; | |
| 86 gfx::Rect soon_border_rect_in_content_space_; | |
| 87 WhichTree tree_; | 87 WhichTree tree_; |
| 88 | 88 |
| 89 Tile* current_tile_; | 89 Tile* current_tile_; |
| 90 TilingData::Iterator visible_iterator_; | 90 TilingData::Iterator visible_iterator_; |
| 91 TilingData::SpiralDifferenceIterator spiral_iterator_; | 91 TilingData::SpiralDifferenceIterator spiral_iterator_; |
| 92 bool skewport_processed_; | 92 bool skewport_processed_; |
| 93 }; | 93 }; |
| 94 | 94 |
| 95 class CC_EXPORT TilingEvictionTileIterator { | 95 class CC_EXPORT TilingEvictionTileIterator { |
| 96 public: | 96 public: |
| (...skipping 25 matching lines...) Expand all Loading... |
| 122 ~PictureLayerTiling(); | 122 ~PictureLayerTiling(); |
| 123 | 123 |
| 124 // Create a tiling with no tiles. CreateTiles must be called to add some. | 124 // Create a tiling with no tiles. CreateTiles must be called to add some. |
| 125 static scoped_ptr<PictureLayerTiling> Create( | 125 static scoped_ptr<PictureLayerTiling> Create( |
| 126 float contents_scale, | 126 float contents_scale, |
| 127 const gfx::Size& layer_bounds, | 127 const gfx::Size& layer_bounds, |
| 128 PictureLayerTilingClient* client); | 128 PictureLayerTilingClient* client); |
| 129 gfx::Size layer_bounds() const { return layer_bounds_; } | 129 gfx::Size layer_bounds() const { return layer_bounds_; } |
| 130 void UpdateTilesToCurrentPile(const Region& layer_invalidation, | 130 void UpdateTilesToCurrentPile(const Region& layer_invalidation, |
| 131 const gfx::Size& new_layer_bounds); | 131 const gfx::Size& new_layer_bounds); |
| 132 void CreateMissingTilesInLiveTilesRect(); | |
| 133 | 132 |
| 134 void SetClient(PictureLayerTilingClient* client); | 133 void SetClient(PictureLayerTilingClient* client); |
| 135 void set_resolution(TileResolution resolution) { resolution_ = resolution; } | 134 void set_resolution(TileResolution resolution) { resolution_ = resolution; } |
| 136 TileResolution resolution() const { return resolution_; } | 135 TileResolution resolution() const { return resolution_; } |
| 137 | 136 |
| 138 gfx::Rect TilingRect() const; | 137 gfx::Rect TilingRect() const; |
| 139 gfx::Rect live_tiles_rect() const { return live_tiles_rect_; } | 138 gfx::Rect live_tiles_rect() const { return live_tiles_rect_; } |
| 140 gfx::Size tile_size() const { return tiling_data_.max_texture_size(); } | 139 gfx::Size tile_size() const { return tiling_data_.max_texture_size(); } |
| 141 float contents_scale() const { return contents_scale_; } | 140 float contents_scale() const { return contents_scale_; } |
| 142 | 141 |
| 143 Tile* TileAt(int i, int j) const { | 142 Tile* TileAt(int i, int j) const { |
| 144 TileMap::const_iterator iter = tiles_.find(TileMapKey(i, j)); | 143 TileMap::const_iterator iter = tiles_.find(TileMapKey(i, j)); |
| 145 return (iter == tiles_.end()) ? NULL : iter->second.get(); | 144 return (iter == tiles_.end()) ? NULL : iter->second.get(); |
| 146 } | 145 } |
| 147 | 146 |
| 147 Tile* GetOrCreateTileAt(int i, int j); |
| 148 |
| 149 void CreateInterestRectTilesForTesting() { |
| 150 for (TilingData::Iterator iter(&tiling_data_, live_tiles_rect_, true); iter; |
| 151 ++iter) { |
| 152 Tile* tile = GetOrCreateTileAt(iter.index_x(), iter.index_y()); |
| 153 if (tile) { |
| 154 UpdateTileOcclusion(tile); |
| 155 SetTileAndTwinPriority(tile); |
| 156 } |
| 157 } |
| 158 } |
| 159 |
| 148 void CreateAllTilesForTesting() { | 160 void CreateAllTilesForTesting() { |
| 149 SetLiveTilesRect(tiling_data_.tiling_rect()); | 161 SetLiveTilesRect(tiling_data_.tiling_rect()); |
| 162 for (TilingData::Iterator iter(&tiling_data_, live_tiles_rect_, true); iter; |
| 163 ++iter) { |
| 164 Tile* tile = GetOrCreateTileAt(iter.index_x(), iter.index_y()); |
| 165 if (tile) { |
| 166 UpdateTileOcclusion(tile); |
| 167 SetTileAndTwinPriority(tile); |
| 168 } |
| 169 } |
| 150 } | 170 } |
| 151 | 171 |
| 152 const TilingData& TilingDataForTesting() const { return tiling_data_; } | 172 const TilingData& TilingDataForTesting() const { return tiling_data_; } |
| 153 | 173 |
| 154 std::vector<Tile*> AllTilesForTesting() const { | 174 std::vector<Tile*> AllTilesForTesting() const { |
| 155 std::vector<Tile*> all_tiles; | 175 std::vector<Tile*> all_tiles; |
| 156 for (TileMap::const_iterator it = tiles_.begin(); | 176 for (TileMap::const_iterator it = tiles_.begin(); |
| 157 it != tiles_.end(); ++it) | 177 it != tiles_.end(); ++it) |
| 158 all_tiles.push_back(it->second.get()); | 178 all_tiles.push_back(it->second.get()); |
| 159 return all_tiles; | 179 return all_tiles; |
| (...skipping 57 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 217 double current_frame_time_in_seconds, | 237 double current_frame_time_in_seconds, |
| 218 const OcclusionTracker<LayerImpl>* occlusion_tracker, | 238 const OcclusionTracker<LayerImpl>* occlusion_tracker, |
| 219 const LayerImpl* render_target, | 239 const LayerImpl* render_target, |
| 220 const gfx::Transform& draw_transform); | 240 const gfx::Transform& draw_transform); |
| 221 | 241 |
| 222 // Copies the src_tree priority into the dst_tree priority for all tiles. | 242 // Copies the src_tree priority into the dst_tree priority for all tiles. |
| 223 // The src_tree priority is reset to the lowest priority possible. This | 243 // The src_tree priority is reset to the lowest priority possible. This |
| 224 // also updates the pile on each tile to be the current client's pile. | 244 // also updates the pile on each tile to be the current client's pile. |
| 225 void DidBecomeActive(); | 245 void DidBecomeActive(); |
| 226 | 246 |
| 227 // Resets the active priority for all tiles in a tiling, when an active | |
| 228 // tiling is becoming recycled. This may include some tiles which are | |
| 229 // not in the the pending tiling (due to invalidations). This must | |
| 230 // be called before DidBecomeActive, as it resets the active priority | |
| 231 // while DidBecomeActive promotes pending priority on a similar set of tiles. | |
| 232 void DidBecomeRecycled(); | |
| 233 | |
| 234 bool NeedsUpdateForFrameAtTime(double frame_time_in_seconds) { | 247 bool NeedsUpdateForFrameAtTime(double frame_time_in_seconds) { |
| 235 return frame_time_in_seconds != last_impl_frame_time_in_seconds_; | 248 return frame_time_in_seconds != last_impl_frame_time_in_seconds_; |
| 236 } | 249 } |
| 237 | 250 |
| 238 scoped_ptr<base::Value> AsValue() const; | 251 scoped_ptr<base::Value> AsValue() const; |
| 239 size_t GPUMemoryUsageInBytes() const; | 252 size_t GPUMemoryUsageInBytes() const; |
| 240 | 253 |
| 241 struct RectExpansionCache { | 254 struct RectExpansionCache { |
| 242 RectExpansionCache(); | 255 RectExpansionCache(); |
| 243 | 256 |
| (...skipping 20 matching lines...) Expand all Loading... |
| 264 friend class TilingEvictionTileIterator; | 277 friend class TilingEvictionTileIterator; |
| 265 | 278 |
| 266 typedef std::pair<int, int> TileMapKey; | 279 typedef std::pair<int, int> TileMapKey; |
| 267 typedef base::hash_map<TileMapKey, scoped_refptr<Tile> > TileMap; | 280 typedef base::hash_map<TileMapKey, scoped_refptr<Tile> > TileMap; |
| 268 | 281 |
| 269 PictureLayerTiling(float contents_scale, | 282 PictureLayerTiling(float contents_scale, |
| 270 const gfx::Size& layer_bounds, | 283 const gfx::Size& layer_bounds, |
| 271 PictureLayerTilingClient* client); | 284 PictureLayerTilingClient* client); |
| 272 void SetLiveTilesRect(const gfx::Rect& live_tiles_rect); | 285 void SetLiveTilesRect(const gfx::Rect& live_tiles_rect); |
| 273 Tile* CreateTile(int i, int j, const PictureLayerTiling* twin_tiling); | 286 Tile* CreateTile(int i, int j, const PictureLayerTiling* twin_tiling); |
| 287 void UpdateTileOcclusion(Tile* tile); |
| 288 bool IsTileRequiredForActivation(Tile* tile) const; |
| 274 | 289 |
| 275 // Computes a skewport. The calculation extrapolates the last visible | 290 // Computes a skewport. The calculation extrapolates the last visible |
| 276 // rect and the current visible rect to expand the skewport to where it | 291 // rect and the current visible rect to expand the skewport to where it |
| 277 // would be in |skewport_target_time| seconds. Note that the skewport | 292 // would be in |skewport_target_time| seconds. Note that the skewport |
| 278 // is guaranteed to contain the current visible rect. | 293 // is guaranteed to contain the current visible rect. |
| 279 gfx::Rect ComputeSkewport(double current_frame_time_in_seconds, | 294 gfx::Rect ComputeSkewport(double current_frame_time_in_seconds, |
| 280 const gfx::Rect& visible_rect_in_content_space) | 295 const gfx::Rect& visible_rect_in_content_space) |
| 281 const; | 296 const; |
| 282 | 297 |
| 283 void UpdateEvictionCacheIfNeeded(TreePriority tree_priority); | 298 void UpdateEvictionCacheIfNeeded(TreePriority tree_priority); |
| 284 void Invalidate(const Region& layer_region); | 299 void Invalidate(const Region& layer_region); |
| 285 | 300 |
| 301 void SetTileAndTwinPriority(Tile* tile) const; |
| 302 void SetTilePriority(Tile* tile) const; |
| 303 |
| 286 // Given properties. | 304 // Given properties. |
| 287 float contents_scale_; | 305 float contents_scale_; |
| 288 gfx::Size layer_bounds_; | 306 gfx::Size layer_bounds_; |
| 289 TileResolution resolution_; | 307 TileResolution resolution_; |
| 290 PictureLayerTilingClient* client_; | 308 PictureLayerTilingClient* client_; |
| 291 | 309 |
| 292 // Internal data. | 310 // Internal data. |
| 293 TilingData tiling_data_; | 311 TilingData tiling_data_; |
| 294 TileMap tiles_; // It is not legal to have a NULL tile in the tiles_ map. | 312 TileMap tiles_; // It is not legal to have a NULL tile in the tiles_ map. |
| 295 gfx::Rect live_tiles_rect_; | 313 gfx::Rect live_tiles_rect_; |
| 296 | 314 |
| 315 base::hash_set<std::pair<int, int> > occlusion_set_; |
| 316 |
| 297 // State saved for computing velocities based upon finite differences. | 317 // State saved for computing velocities based upon finite differences. |
| 298 double last_impl_frame_time_in_seconds_; | 318 double last_impl_frame_time_in_seconds_; |
| 299 gfx::Rect last_visible_rect_in_content_space_; | 319 gfx::Rect last_visible_rect_in_content_space_; |
| 320 float content_to_screen_scale_; |
| 300 | 321 |
| 301 gfx::Rect current_visible_rect_in_content_space_; | 322 gfx::Rect current_visible_rect_in_content_space_; |
| 302 gfx::Rect current_skewport_; | 323 gfx::Rect current_skewport_; |
| 303 gfx::Rect current_eventually_rect_; | 324 gfx::Rect current_eventually_rect_; |
| 304 gfx::Rect current_soon_border_rect_; | 325 gfx::Rect current_soon_border_rect_; |
| 305 | 326 |
| 327 bool current_visible_rect_has_tiles_; |
| 328 bool current_skewport_has_tiles_; |
| 329 bool current_eventually_rect_has_tiles_; |
| 330 bool current_soon_border_rect_has_tiles_; |
| 331 |
| 306 std::vector<Tile*> eviction_tiles_cache_; | 332 std::vector<Tile*> eviction_tiles_cache_; |
| 307 bool eviction_tiles_cache_valid_; | |
| 308 TreePriority eviction_cache_tree_priority_; | |
| 309 | 333 |
| 310 private: | 334 private: |
| 311 DISALLOW_ASSIGN(PictureLayerTiling); | 335 DISALLOW_ASSIGN(PictureLayerTiling); |
| 312 | 336 |
| 313 RectExpansionCache expansion_cache_; | 337 RectExpansionCache expansion_cache_; |
| 314 }; | 338 }; |
| 315 | 339 |
| 316 } // namespace cc | 340 } // namespace cc |
| 317 | 341 |
| 318 #endif // CC_RESOURCES_PICTURE_LAYER_TILING_H_ | 342 #endif // CC_RESOURCES_PICTURE_LAYER_TILING_H_ |
| OLD | NEW |