| OLD | NEW |
| 1 // Copyright 2011 The Chromium Authors. All rights reserved. | 1 // Copyright 2011 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 | 5 |
| 6 #include "config.h" | 6 #include "config.h" |
| 7 | 7 |
| 8 #include "CCLayerTilingData.h" | 8 #include "CCLayerTilingData.h" |
| 9 | 9 |
| 10 using namespace std; | 10 using namespace std; |
| 11 | 11 |
| 12 namespace cc { | 12 namespace cc { |
| 13 | 13 |
| 14 PassOwnPtr<CCLayerTilingData> CCLayerTilingData::create(const IntSize& tileSize,
BorderTexelOption border) | 14 scoped_ptr<CCLayerTilingData> CCLayerTilingData::create(const IntSize& tileSize,
BorderTexelOption border) |
| 15 { | 15 { |
| 16 return adoptPtr(new CCLayerTilingData(tileSize, border)); | 16 return make_scoped_ptr(new CCLayerTilingData(tileSize, border)); |
| 17 } | 17 } |
| 18 | 18 |
| 19 CCLayerTilingData::CCLayerTilingData(const IntSize& tileSize, BorderTexelOption
border) | 19 CCLayerTilingData::CCLayerTilingData(const IntSize& tileSize, BorderTexelOption
border) |
| 20 : m_tilingData(tileSize, IntSize(), border == HasBorderTexels) | 20 : m_tilingData(tileSize, IntSize(), border == HasBorderTexels) |
| 21 { | 21 { |
| 22 setTileSize(tileSize); | 22 setTileSize(tileSize); |
| 23 } | 23 } |
| 24 | 24 |
| 25 CCLayerTilingData::~CCLayerTilingData() | 25 CCLayerTilingData::~CCLayerTilingData() |
| 26 { | 26 { |
| (...skipping 24 matching lines...) Expand all Loading... |
| 51 m_tilingData.setHasBorderTexels(borderTexels); | 51 m_tilingData.setHasBorderTexels(borderTexels); |
| 52 } | 52 } |
| 53 | 53 |
| 54 const CCLayerTilingData& CCLayerTilingData::operator=(const CCLayerTilingData& t
iler) | 54 const CCLayerTilingData& CCLayerTilingData::operator=(const CCLayerTilingData& t
iler) |
| 55 { | 55 { |
| 56 m_tilingData = tiler.m_tilingData; | 56 m_tilingData = tiler.m_tilingData; |
| 57 | 57 |
| 58 return *this; | 58 return *this; |
| 59 } | 59 } |
| 60 | 60 |
| 61 void CCLayerTilingData::addTile(PassOwnPtr<Tile> tile, int i, int j) | 61 void CCLayerTilingData::addTile(scoped_ptr<Tile> tile, int i, int j) |
| 62 { | 62 { |
| 63 ASSERT(!tileAt(i, j)); | 63 ASSERT(!tileAt(i, j)); |
| 64 tile->moveTo(i, j); | 64 tile->moveTo(i, j); |
| 65 m_tiles.add(make_pair(i, j), tile); | 65 m_tiles.add(make_pair(i, j), tile.Pass()); |
| 66 } | 66 } |
| 67 | 67 |
| 68 PassOwnPtr<CCLayerTilingData::Tile> CCLayerTilingData::takeTile(int i, int j) | 68 scoped_ptr<CCLayerTilingData::Tile> CCLayerTilingData::takeTile(int i, int j) |
| 69 { | 69 { |
| 70 return m_tiles.take(make_pair(i, j)); | 70 return m_tiles.take_and_erase(make_pair(i, j)); |
| 71 } | 71 } |
| 72 | 72 |
| 73 CCLayerTilingData::Tile* CCLayerTilingData::tileAt(int i, int j) const | 73 CCLayerTilingData::Tile* CCLayerTilingData::tileAt(int i, int j) const |
| 74 { | 74 { |
| 75 return m_tiles.get(make_pair(i, j)); | 75 return m_tiles.get(make_pair(i, j)); |
| 76 } | 76 } |
| 77 | 77 |
| 78 void CCLayerTilingData::reset() | 78 void CCLayerTilingData::reset() |
| 79 { | 79 { |
| 80 m_tiles.clear(); | 80 m_tiles.clear(); |
| (...skipping 46 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 127 if (size.isEmpty()) { | 127 if (size.isEmpty()) { |
| 128 m_tiles.clear(); | 128 m_tiles.clear(); |
| 129 return; | 129 return; |
| 130 } | 130 } |
| 131 | 131 |
| 132 // Any tiles completely outside our new bounds are invalid and should be dro
pped. | 132 // Any tiles completely outside our new bounds are invalid and should be dro
pped. |
| 133 int left, top, right, bottom; | 133 int left, top, right, bottom; |
| 134 contentRectToTileIndices(IntRect(IntPoint(), size), left, top, right, bottom
); | 134 contentRectToTileIndices(IntRect(IntPoint(), size), left, top, right, bottom
); |
| 135 Vector<TileMapKey> invalidTileKeys; | 135 Vector<TileMapKey> invalidTileKeys; |
| 136 for (TileMap::const_iterator it = m_tiles.begin(); it != m_tiles.end(); ++it
) { | 136 for (TileMap::const_iterator it = m_tiles.begin(); it != m_tiles.end(); ++it
) { |
| 137 #if WTF_NEW_HASHMAP_ITERATORS_INTERFACE | |
| 138 if (it->key.first > right || it->key.second > bottom) | |
| 139 invalidTileKeys.append(it->key); | |
| 140 #else | |
| 141 if (it->first.first > right || it->first.second > bottom) | 137 if (it->first.first > right || it->first.second > bottom) |
| 142 invalidTileKeys.append(it->first); | 138 invalidTileKeys.append(it->first); |
| 143 #endif | |
| 144 } | 139 } |
| 145 for (size_t i = 0; i < invalidTileKeys.size(); ++i) | 140 for (size_t i = 0; i < invalidTileKeys.size(); ++i) |
| 146 m_tiles.remove(invalidTileKeys[i]); | 141 m_tiles.erase(invalidTileKeys[i]); |
| 147 } | 142 } |
| 148 | 143 |
| 149 IntSize CCLayerTilingData::bounds() const | 144 IntSize CCLayerTilingData::bounds() const |
| 150 { | 145 { |
| 151 return m_tilingData.totalSize(); | 146 return m_tilingData.totalSize(); |
| 152 } | 147 } |
| 153 | 148 |
| 154 } // namespace cc | 149 } // namespace cc |
| OLD | NEW |