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

Unified Diff: cc/layer_tiling_data.h

Issue 11122003: [cc] Rename all cc/ filenames to Chromium style (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Created 8 years, 2 months 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/layer_texture_updater.cc ('k') | cc/layer_tiling_data.cc » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: cc/layer_tiling_data.h
diff --git a/cc/layer_tiling_data.h b/cc/layer_tiling_data.h
index 638cbb270ce9b24689d5095baf174ade4f4d1a13..c73f0570c72f236f27b2069969d76ae2434f0726 100644
--- a/cc/layer_tiling_data.h
+++ b/cc/layer_tiling_data.h
@@ -1,3 +1,101 @@
-// Copyright 2012 The Chromium Authors. All rights reserved.
+// Copyright 2011 The Chromium Authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
+
+
+#ifndef CCLayerTilingData_h
+#define CCLayerTilingData_h
+
+#if USE(ACCELERATED_COMPOSITING)
+
+#include "base/basictypes.h"
+#include "IntRect.h"
+#include "Region.h"
+#include "TilingData.h"
+#include <wtf/HashMap.h>
+#include <wtf/HashTraits.h>
+#include <wtf/PassOwnPtr.h>
+
+namespace cc {
+
+class CCLayerTilingData {
+public:
+ enum BorderTexelOption { HasBorderTexels, NoBorderTexels };
+
+ ~CCLayerTilingData();
+
+ static PassOwnPtr<CCLayerTilingData> create(const IntSize& tileSize, BorderTexelOption);
+
+ bool hasEmptyBounds() const { return m_tilingData.hasEmptyBounds(); }
+ int numTilesX() const { return m_tilingData.numTilesX(); }
+ int numTilesY() const { return m_tilingData.numTilesY(); }
+ IntRect tileBounds(int i, int j) const { return m_tilingData.tileBounds(i, j); }
+ IntPoint textureOffset(int xIndex, int yIndex) const { return m_tilingData.textureOffset(xIndex, yIndex); }
+
+ // Change the tile size. This may invalidate all the existing tiles.
+ void setTileSize(const IntSize&);
+ IntSize tileSize() const;
+ // Change the border texel setting. This may invalidate all existing tiles.
+ void setBorderTexelOption(BorderTexelOption);
+ bool hasBorderTexels() const { return m_tilingData.borderTexels(); }
+
+ bool isEmpty() const { return hasEmptyBounds() || !tiles().size(); }
+
+ const CCLayerTilingData& operator=(const CCLayerTilingData&);
+
+ class Tile {
+ public:
+ Tile() : m_i(-1), m_j(-1) { }
+ virtual ~Tile() { }
+
+ int i() const { return m_i; }
+ int j() const { return m_j; }
+ void moveTo(int i, int j) { m_i = i; m_j = j; }
+
+ const IntRect& opaqueRect() const { return m_opaqueRect; }
+ void setOpaqueRect(const IntRect& opaqueRect) { m_opaqueRect = opaqueRect; }
+ private:
+ int m_i;
+ int m_j;
+ IntRect m_opaqueRect;
+ DISALLOW_COPY_AND_ASSIGN(Tile);
+ };
+ // Default hash key traits for integers disallow 0 and -1 as a key, so
+ // use a custom hash trait which disallows -1 and -2 instead.
+ typedef std::pair<int, int> TileMapKey;
+ struct TileMapKeyTraits : HashTraits<TileMapKey> {
+ static const bool emptyValueIsZero = false;
+ static const bool needsDestruction = false;
+ static TileMapKey emptyValue() { return std::make_pair(-1, -1); }
+ static void constructDeletedValue(TileMapKey& slot) { slot = std::make_pair(-2, -2); }
+ static bool isDeletedValue(TileMapKey value) { return value.first == -2 && value.second == -2; }
+ };
+ typedef HashMap<TileMapKey, OwnPtr<Tile>, DefaultHash<TileMapKey>::Hash, TileMapKeyTraits> TileMap;
+
+ void addTile(PassOwnPtr<Tile>, int, int);
+ PassOwnPtr<Tile> takeTile(int, int);
+ Tile* tileAt(int, int) const;
+ const TileMap& tiles() const { return m_tiles; }
+
+ void setBounds(const IntSize&);
+ IntSize bounds() const;
+
+ void contentRectToTileIndices(const IntRect&, int &left, int &top, int &right, int &bottom) const;
+ IntRect tileRect(const Tile*) const;
+
+ Region opaqueRegionInContentRect(const IntRect&) const;
+
+ void reset();
+
+protected:
+ CCLayerTilingData(const IntSize& tileSize, BorderTexelOption);
+
+ TileMap m_tiles;
+ TilingData m_tilingData;
+};
+
+}
+
+#endif // USE(ACCELERATED_COMPOSITING)
+
+#endif
« no previous file with comments | « cc/layer_texture_updater.cc ('k') | cc/layer_tiling_data.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698