[NaCl SDK]: use standard __BEGIN_DECLS macros in sys/select.h
[chromium-blink-merge.git] / cc / resources / tile.h
blob5d49275716948464ffc746b9aaf5510bfd24c081
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.
5 #ifndef CC_RESOURCES_TILE_H_
6 #define CC_RESOURCES_TILE_H_
8 #include "base/memory/ref_counted.h"
9 #include "base/memory/scoped_ptr.h"
10 #include "base/memory/scoped_vector.h"
11 #include "cc/base/ref_counted_managed.h"
12 #include "cc/resources/managed_tile_state.h"
13 #include "cc/resources/picture_pile_impl.h"
14 #include "cc/resources/raster_mode.h"
15 #include "cc/resources/tile_priority.h"
16 #include "ui/gfx/rect.h"
17 #include "ui/gfx/size.h"
19 namespace cc {
21 class CC_EXPORT Tile : public RefCountedManaged<Tile> {
22 public:
23 enum TileRasterFlags { USE_PICTURE_ANALYSIS = 1 << 0 };
25 typedef uint64 Id;
27 Id id() const {
28 return id_;
31 PicturePileImpl* picture_pile() {
32 return picture_pile_.get();
35 const PicturePileImpl* picture_pile() const {
36 return picture_pile_.get();
39 const TilePriority& priority(WhichTree tree) const {
40 return priority_[tree];
43 TilePriority priority_for_tree_priority(TreePriority tree_priority) const {
44 switch (tree_priority) {
45 case SMOOTHNESS_TAKES_PRIORITY:
46 return priority_[ACTIVE_TREE];
47 case NEW_CONTENT_TAKES_PRIORITY:
48 return priority_[PENDING_TREE];
49 case SAME_PRIORITY_FOR_BOTH_TREES:
50 return combined_priority();
51 default:
52 NOTREACHED();
53 return TilePriority();
57 TilePriority combined_priority() const {
58 return TilePriority(priority_[ACTIVE_TREE],
59 priority_[PENDING_TREE]);
62 void SetPriority(WhichTree tree, const TilePriority& priority);
64 void set_is_occluded(WhichTree tree, bool is_occluded) {
65 is_occluded_[tree] = is_occluded;
68 bool is_occluded(WhichTree tree) const { return is_occluded_[tree]; }
70 void set_shared(bool is_shared) { is_shared_ = is_shared; }
71 bool is_shared() const { return is_shared_; }
73 bool is_occluded_for_tree_priority(TreePriority tree_priority) const {
74 switch (tree_priority) {
75 case SMOOTHNESS_TAKES_PRIORITY:
76 return is_occluded_[ACTIVE_TREE];
77 case NEW_CONTENT_TAKES_PRIORITY:
78 return is_occluded_[PENDING_TREE];
79 case SAME_PRIORITY_FOR_BOTH_TREES:
80 return is_occluded_[ACTIVE_TREE] && is_occluded_[PENDING_TREE];
81 default:
82 NOTREACHED();
83 return false;
87 void MarkRequiredForActivation();
89 bool required_for_activation() const {
90 return priority_[PENDING_TREE].required_for_activation;
93 bool use_picture_analysis() const {
94 return !!(flags_ & USE_PICTURE_ANALYSIS);
97 bool NeedsRasterForMode(RasterMode mode) const {
98 return !managed_state_.tile_versions[mode].IsReadyToDraw();
101 bool HasResources() const {
102 for (int mode = 0; mode < NUM_RASTER_MODES; ++mode) {
103 if (managed_state_.tile_versions[mode].has_resource())
104 return true;
106 return false;
109 void AsValueInto(base::debug::TracedValue* dict) const;
111 inline bool IsReadyToDraw() const {
112 for (int mode = 0; mode < NUM_RASTER_MODES; ++mode) {
113 if (managed_state_.tile_versions[mode].IsReadyToDraw())
114 return true;
116 return false;
119 const ManagedTileState::TileVersion& GetTileVersionForDrawing() const {
120 for (int mode = 0; mode < NUM_RASTER_MODES; ++mode) {
121 if (managed_state_.tile_versions[mode].IsReadyToDraw())
122 return managed_state_.tile_versions[mode];
124 return managed_state_.tile_versions[HIGH_QUALITY_RASTER_MODE];
127 gfx::Rect opaque_rect() const { return opaque_rect_; }
128 float contents_scale() const { return contents_scale_; }
129 gfx::Rect content_rect() const { return content_rect_; }
131 int layer_id() const { return layer_id_; }
133 int source_frame_number() const { return source_frame_number_; }
135 void set_picture_pile(scoped_refptr<PicturePileImpl> pile) {
136 DCHECK(pile->CanRaster(contents_scale_, content_rect_))
137 << "Recording rect: "
138 << gfx::ScaleToEnclosingRect(content_rect_, 1.f / contents_scale_)
139 .ToString();
140 picture_pile_ = pile;
143 size_t GPUMemoryUsageInBytes() const;
145 gfx::Size size() const { return size_; }
147 RasterMode DetermineRasterModeForTree(WhichTree tree) const;
148 RasterMode DetermineOverallRasterMode() const;
150 // Functionality used in tests.
151 RasterMode GetRasterModeForTesting() const {
152 return managed_state().raster_mode;
154 ManagedTileState::TileVersion& GetTileVersionForTesting(RasterMode mode) {
155 return managed_state_.tile_versions[mode];
158 private:
159 friend class TileManager;
160 friend class PrioritizedTileSet;
161 friend class FakeTileManager;
162 friend class BinComparator;
163 friend class FakePictureLayerImpl;
165 // Methods called by by tile manager.
166 Tile(TileManager* tile_manager,
167 PicturePileImpl* picture_pile,
168 const gfx::Size& tile_size,
169 const gfx::Rect& content_rect,
170 const gfx::Rect& opaque_rect,
171 float contents_scale,
172 int layer_id,
173 int source_frame_number,
174 int flags);
175 ~Tile();
177 ManagedTileState& managed_state() { return managed_state_; }
178 const ManagedTileState& managed_state() const { return managed_state_; }
179 RasterMode DetermineRasterModeForResolution(TileResolution resolution) const;
181 bool HasRasterTask() const;
183 TileManager* tile_manager_;
184 scoped_refptr<PicturePileImpl> picture_pile_;
185 gfx::Size size_;
186 gfx::Rect content_rect_;
187 float contents_scale_;
188 gfx::Rect opaque_rect_;
189 bool is_occluded_[NUM_TREES];
191 TilePriority priority_[NUM_TREES];
192 ManagedTileState managed_state_;
193 int layer_id_;
194 int source_frame_number_;
195 int flags_;
196 bool is_shared_;
198 Id id_;
199 static Id s_next_id_;
201 DISALLOW_COPY_AND_ASSIGN(Tile);
204 } // namespace cc
206 #endif // CC_RESOURCES_TILE_H_