Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(695)

Unified Diff: cc/resources/tile_manager.h

Issue 62283012: cc: Added tile bundles (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: rebase Created 7 years ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
« no previous file with comments | « cc/resources/tile_bundle_unittest.cc ('k') | cc/resources/tile_manager.cc » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: cc/resources/tile_manager.h
diff --git a/cc/resources/tile_manager.h b/cc/resources/tile_manager.h
index 10a1df8c00327aa1ee09bce40c93e5858ce8c917..e708cdffc1e0f925bb36ae44e88cb07243ba3e08 100644
--- a/cc/resources/tile_manager.h
+++ b/cc/resources/tile_manager.h
@@ -21,6 +21,7 @@
#include "cc/resources/raster_worker_pool.h"
#include "cc/resources/resource_pool.h"
#include "cc/resources/tile.h"
+#include "cc/resources/tile_bundle.h"
namespace cc {
class ResourceProvider;
@@ -47,7 +48,8 @@ scoped_ptr<base::Value> RasterTaskCompletionStatsAsValue(
// by layers; they automatically register with the manager when they are
// created, and unregister from the manager when they are deleted.
class CC_EXPORT TileManager : public RasterWorkerPoolClient,
- public RefCountedManager<Tile> {
+ public RefCountedManager<Tile>,
+ public RefCountedManager<TileBundle> {
public:
static scoped_ptr<TileManager> Create(
TileManagerClient* client,
@@ -74,6 +76,11 @@ class CC_EXPORT TileManager : public RasterWorkerPoolClient,
int source_frame_number,
int flags);
+ scoped_refptr<TileBundle> CreateTileBundle(int offset_x,
+ int offset_y,
+ int width,
+ int height);
+
scoped_ptr<base::Value> BasicStateAsValue() const;
scoped_ptr<base::Value> AllTilesAsValue() const;
void GetMemoryStats(size_t* memory_required_bytes,
@@ -124,16 +131,22 @@ class CC_EXPORT TileManager : public RasterWorkerPoolClient,
size_t max_raster_usage_bytes,
RenderingStatsInstrumentation* rendering_stats_instrumentation);
- // Methods called by Tile
+ // Methods called by Tile and TileBundle
+ friend class TileBundle;
friend class Tile;
+
void DidChangeTilePriority(Tile* tile);
+ void DidChangeTileBundlePriority(TileBundle* bundle);
void CleanUpReleasedTiles();
- // Overriden from RefCountedManager<Tile>:
+ // Overridden from RefCountedManager<Tile>:
virtual void Release(Tile* tile) OVERRIDE;
- // Overriden from RasterWorkerPoolClient:
+ // Overridden from RefCountedManager<TileBundle>:
+ virtual void Release(TileBundle* bundle) OVERRIDE;
+
+ // Overridden from RasterWorkerPoolClient:
virtual bool ShouldForceTasksRequiredForActivationToComplete() const
OVERRIDE;
virtual void DidFinishRunningTasks() OVERRIDE;
@@ -186,6 +199,9 @@ class CC_EXPORT TileManager : public RasterWorkerPoolClient,
typedef base::hash_map<Tile::Id, Tile*> TileMap;
TileMap tiles_;
+ typedef base::hash_map<TileBundle::Id, TileBundle*> TileBundleMap;
+ TileBundleMap bundles_;
+
PrioritizedTileSet prioritized_tiles_;
bool prioritized_tiles_dirty_;
@@ -217,6 +233,7 @@ class CC_EXPORT TileManager : public RasterWorkerPoolClient,
RasterTaskCompletionStats update_visible_tiles_stats_;
std::vector<Tile*> released_tiles_;
+ std::vector<TileBundle*> released_tile_bundles_;
DISALLOW_COPY_AND_ASSIGN(TileManager);
};
« no previous file with comments | « cc/resources/tile_bundle_unittest.cc ('k') | cc/resources/tile_manager.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698