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 117 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
128 | 128 |
129 friend class PictureLayerTiling; | 129 friend class PictureLayerTiling; |
130 }; | 130 }; |
131 | 131 |
132 Region OpaqueRegionInContentRect(const gfx::Rect& content_rect) const; | 132 Region OpaqueRegionInContentRect(const gfx::Rect& content_rect) const; |
133 | 133 |
134 void Reset(); | 134 void Reset(); |
135 | 135 |
136 void UpdateTilePriorities( | 136 void UpdateTilePriorities( |
137 WhichTree tree, | 137 WhichTree tree, |
138 const gfx::Size& device_viewport, | |
139 const gfx::Rect& viewport_in_layer_space, | 138 const gfx::Rect& viewport_in_layer_space, |
140 const gfx::Rect& visible_layer_rect, | 139 const gfx::Rect& visible_layer_rect, |
141 const gfx::Size& last_layer_bounds, | 140 float layer_contents_scale, |
142 const gfx::Size& current_layer_bounds, | |
143 float last_layer_contents_scale, | |
144 float current_layer_contents_scale, | |
145 const gfx::Transform& last_screen_transform, | |
146 const gfx::Transform& current_screen_transform, | |
147 double current_frame_time_in_seconds, | 141 double current_frame_time_in_seconds, |
148 size_t max_tiles_for_interest_area); | 142 size_t max_tiles_for_interest_area); |
enne (OOO)
2014/01/31 23:07:46
This isn't part of your patch, but we don't change
vmpstr
2014/02/03 20:27:24
Done. But to avoid passing this in other functions
| |
149 | 143 |
150 // Copies the src_tree priority into the dst_tree priority for all tiles. | 144 // Copies the src_tree priority into the dst_tree priority for all tiles. |
151 // The src_tree priority is reset to the lowest priority possible. This | 145 // The src_tree priority is reset to the lowest priority possible. This |
152 // also updates the pile on each tile to be the current client's pile. | 146 // also updates the pile on each tile to be the current client's pile. |
153 void DidBecomeActive(); | 147 void DidBecomeActive(); |
154 | 148 |
155 // Resets the active priority for all tiles in a tiling, when an active | 149 // Resets the active priority for all tiles in a tiling, when an active |
156 // tiling is becoming recycled. This may include some tiles which are | 150 // tiling is becoming recycled. This may include some tiles which are |
157 // not in the the pending tiling (due to invalidations). This must | 151 // not in the the pending tiling (due to invalidations). This must |
158 // be called before DidBecomeActive, as it resets the active priority | 152 // be called before DidBecomeActive, as it resets the active priority |
(...skipping 32 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
191 protected: | 185 protected: |
192 typedef std::pair<int, int> TileMapKey; | 186 typedef std::pair<int, int> TileMapKey; |
193 typedef base::hash_map<TileMapKey, scoped_refptr<Tile> > TileMap; | 187 typedef base::hash_map<TileMapKey, scoped_refptr<Tile> > TileMap; |
194 | 188 |
195 PictureLayerTiling(float contents_scale, | 189 PictureLayerTiling(float contents_scale, |
196 const gfx::Size& layer_bounds, | 190 const gfx::Size& layer_bounds, |
197 PictureLayerTilingClient* client); | 191 PictureLayerTilingClient* client); |
198 void SetLiveTilesRect(const gfx::Rect& live_tiles_rect); | 192 void SetLiveTilesRect(const gfx::Rect& live_tiles_rect); |
199 void CreateTile(int i, int j, const PictureLayerTiling* twin_tiling); | 193 void CreateTile(int i, int j, const PictureLayerTiling* twin_tiling); |
200 | 194 |
195 gfx::Rect ComputeVisibleRect(const gfx::Rect& viewport_in_layer_space, | |
196 const gfx::Rect& visible_layer_rect) const; | |
197 | |
198 gfx::Rect ComputeSkewport(double current_frame_time_in_seconds, | |
199 const gfx::Rect& visible_rect_in_content_space) | |
200 const; | |
201 | |
201 // Given properties. | 202 // Given properties. |
202 float contents_scale_; | 203 float contents_scale_; |
203 gfx::Size layer_bounds_; | 204 gfx::Size layer_bounds_; |
204 TileResolution resolution_; | 205 TileResolution resolution_; |
205 PictureLayerTilingClient* client_; | 206 PictureLayerTilingClient* client_; |
206 | 207 |
207 // Internal data. | 208 // Internal data. |
208 TilingData tiling_data_; | 209 TilingData tiling_data_; |
209 TileMap tiles_; // It is not legal to have a NULL tile in the tiles_ map. | 210 TileMap tiles_; // It is not legal to have a NULL tile in the tiles_ map. |
210 gfx::Rect live_tiles_rect_; | 211 gfx::Rect live_tiles_rect_; |
211 | 212 |
212 // State saved for computing velocities based upon finite differences. | 213 // State saved for computing velocities based upon finite differences. |
213 double last_impl_frame_time_in_seconds_; | 214 double last_impl_frame_time_in_seconds_; |
215 gfx::RectF last_visible_rect_in_content_space_; | |
214 | 216 |
215 friend class CoverageIterator; | 217 friend class CoverageIterator; |
216 | 218 |
217 private: | 219 private: |
218 DISALLOW_ASSIGN(PictureLayerTiling); | 220 DISALLOW_ASSIGN(PictureLayerTiling); |
219 | 221 |
220 RectExpansionCache expansion_cache_; | 222 RectExpansionCache expansion_cache_; |
221 }; | 223 }; |
222 | 224 |
223 } // namespace cc | 225 } // namespace cc |
224 | 226 |
225 #endif // CC_RESOURCES_PICTURE_LAYER_TILING_H_ | 227 #endif // CC_RESOURCES_PICTURE_LAYER_TILING_H_ |
OLD | NEW |