OLD | NEW |
| (Empty) |
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. | |
4 | |
5 #ifndef CC_RESOURCES_PICTURE_LAYER_TILING_SET_H_ | |
6 #define CC_RESOURCES_PICTURE_LAYER_TILING_SET_H_ | |
7 | |
8 #include <set> | |
9 #include <vector> | |
10 | |
11 #include "cc/base/region.h" | |
12 #include "cc/base/scoped_ptr_vector.h" | |
13 #include "cc/resources/picture_layer_tiling.h" | |
14 #include "ui/gfx/geometry/size.h" | |
15 | |
16 namespace base { | |
17 namespace trace_event { | |
18 class TracedValue; | |
19 } | |
20 } | |
21 | |
22 namespace cc { | |
23 | |
24 class CC_EXPORT PictureLayerTilingSet { | |
25 public: | |
26 enum TilingRangeType { | |
27 HIGHER_THAN_HIGH_RES, | |
28 HIGH_RES, | |
29 BETWEEN_HIGH_AND_LOW_RES, | |
30 LOW_RES, | |
31 LOWER_THAN_LOW_RES | |
32 }; | |
33 struct TilingRange { | |
34 TilingRange(size_t start, size_t end) : start(start), end(end) {} | |
35 | |
36 size_t start; | |
37 size_t end; | |
38 }; | |
39 | |
40 static scoped_ptr<PictureLayerTilingSet> Create( | |
41 PictureLayerTilingClient* client, | |
42 size_t max_tiles_for_interest_area, | |
43 float skewport_target_time_in_seconds, | |
44 int skewport_extrapolation_limit_in_content); | |
45 | |
46 ~PictureLayerTilingSet(); | |
47 | |
48 const PictureLayerTilingClient* client() const { return client_; } | |
49 | |
50 void CleanUpTilings(float min_acceptable_high_res_scale, | |
51 float max_acceptable_high_res_scale, | |
52 const std::vector<PictureLayerTiling*>& needed_tilings, | |
53 bool should_have_low_res, | |
54 PictureLayerTilingSet* twin_set, | |
55 PictureLayerTilingSet* recycled_twin_set); | |
56 void RemoveNonIdealTilings(); | |
57 | |
58 // This function can be called on both the active and pending tree. | |
59 // |pending_twin_set| represents the current pending twin. In situations where | |
60 // this is called on the active tree in two trees situations, | |
61 // |pending_twin_set| represents the tiling set from the pending twin layer. | |
62 // In situations where this is called on the sync tree (whether it's pending | |
63 // or active in cases of one tree), |pending_twin_set| should be nullptr. | |
64 void UpdateTilingsToCurrentRasterSource( | |
65 scoped_refptr<RasterSource> raster_source, | |
66 const PictureLayerTilingSet* pending_twin_set, | |
67 const Region& layer_invalidation, | |
68 float minimum_contents_scale, | |
69 float maximum_contents_scale); | |
70 | |
71 PictureLayerTiling* AddTiling(float contents_scale, | |
72 scoped_refptr<RasterSource> raster_source); | |
73 size_t num_tilings() const { return tilings_.size(); } | |
74 int NumHighResTilings() const; | |
75 PictureLayerTiling* tiling_at(size_t idx) { return tilings_[idx]; } | |
76 const PictureLayerTiling* tiling_at(size_t idx) const { | |
77 return tilings_[idx]; | |
78 } | |
79 | |
80 PictureLayerTiling* FindTilingWithScale(float scale) const; | |
81 PictureLayerTiling* FindTilingWithResolution(TileResolution resolution) const; | |
82 | |
83 void MarkAllTilingsNonIdeal(); | |
84 | |
85 // If a tiling exists whose scale is within |snap_to_existing_tiling_ratio| | |
86 // ratio of |start_scale|, then return that tiling's scale. Otherwise, return | |
87 // |start_scale|. If multiple tilings match the criteria, return the one with | |
88 // the least ratio to |start_scale|. | |
89 float GetSnappedContentsScale(float start_scale, | |
90 float snap_to_existing_tiling_ratio) const; | |
91 | |
92 // Returns the maximum contents scale of all tilings, or 0 if no tilings | |
93 // exist. | |
94 float GetMaximumContentsScale() const; | |
95 | |
96 // Removes all tilings with a contents scale < |minimum_scale|. | |
97 void RemoveTilingsBelowScale(float minimum_scale); | |
98 | |
99 // Removes all tilings with a contents scale > |maximum_scale|. | |
100 void RemoveTilingsAboveScale(float maximum_scale); | |
101 | |
102 // Remove all tilings. | |
103 void RemoveAllTilings(); | |
104 | |
105 // Remove all tiles; keep all tilings. | |
106 void RemoveAllTiles(); | |
107 | |
108 // Update the rects and priorities for tiles based on the given information. | |
109 bool UpdateTilePriorities(const gfx::Rect& required_rect_in_layer_space, | |
110 float ideal_contents_scale, | |
111 double current_frame_time_in_seconds, | |
112 const Occlusion& occlusion_in_layer_space, | |
113 bool can_require_tiles_for_activation); | |
114 | |
115 void GetAllTilesAndPrioritiesForTracing( | |
116 std::map<const Tile*, TilePriority>* tile_map) const; | |
117 | |
118 // For a given rect, iterates through tiles that can fill it. If no | |
119 // set of tiles with resources can fill the rect, then it will iterate | |
120 // through null tiles with valid geometry_rect() until the rect is full. | |
121 // If all tiles have resources, the union of all geometry_rects will | |
122 // exactly fill rect with no overlap. | |
123 class CC_EXPORT CoverageIterator { | |
124 public: | |
125 CoverageIterator(const PictureLayerTilingSet* set, | |
126 float contents_scale, | |
127 const gfx::Rect& content_rect, | |
128 float ideal_contents_scale); | |
129 ~CoverageIterator(); | |
130 | |
131 // Visible rect (no borders), always in the space of rect, | |
132 // regardless of the relative contents scale of the tiling. | |
133 gfx::Rect geometry_rect() const; | |
134 // Texture rect (in texels) for geometry_rect | |
135 gfx::RectF texture_rect() const; | |
136 | |
137 Tile* operator->() const; | |
138 Tile* operator*() const; | |
139 | |
140 CoverageIterator& operator++(); | |
141 operator bool() const; | |
142 | |
143 TileResolution resolution() const; | |
144 PictureLayerTiling* CurrentTiling() const; | |
145 | |
146 private: | |
147 int NextTiling() const; | |
148 | |
149 const PictureLayerTilingSet* set_; | |
150 float contents_scale_; | |
151 float ideal_contents_scale_; | |
152 PictureLayerTiling::CoverageIterator tiling_iter_; | |
153 int current_tiling_; | |
154 int ideal_tiling_; | |
155 | |
156 Region current_region_; | |
157 Region missing_region_; | |
158 Region::Iterator region_iter_; | |
159 }; | |
160 | |
161 void AsValueInto(base::trace_event::TracedValue* array) const; | |
162 size_t GPUMemoryUsageInBytes() const; | |
163 | |
164 TilingRange GetTilingRange(TilingRangeType type) const; | |
165 | |
166 private: | |
167 explicit PictureLayerTilingSet( | |
168 PictureLayerTilingClient* client, | |
169 size_t max_tiles_for_interest_area, | |
170 float skewport_target_time_in_seconds, | |
171 int skewport_extrapolation_limit_in_content_pixels); | |
172 | |
173 void CopyTilingsFromPendingTwin( | |
174 const PictureLayerTilingSet* pending_twin_set, | |
175 const scoped_refptr<RasterSource>& raster_source); | |
176 | |
177 // Remove one tiling. | |
178 void Remove(PictureLayerTiling* tiling); | |
179 | |
180 ScopedPtrVector<PictureLayerTiling> tilings_; | |
181 | |
182 const size_t max_tiles_for_interest_area_; | |
183 const float skewport_target_time_in_seconds_; | |
184 const int skewport_extrapolation_limit_in_content_pixels_; | |
185 PictureLayerTilingClient* client_; | |
186 | |
187 friend class Iterator; | |
188 DISALLOW_COPY_AND_ASSIGN(PictureLayerTilingSet); | |
189 }; | |
190 | |
191 } // namespace cc | |
192 | |
193 #endif // CC_RESOURCES_PICTURE_LAYER_TILING_SET_H_ | |
OLD | NEW |