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
3 // found in the LICENSE file.
5 #include "cc/layer_tiling_data.h"
7 #include "base/logging.h"
11 scoped_ptr
<LayerTilingData
> LayerTilingData::create(const gfx::Size
& tileSize
, BorderTexelOption border
)
13 return make_scoped_ptr(new LayerTilingData(tileSize
, border
));
16 LayerTilingData::LayerTilingData(const gfx::Size
& tileSize
, BorderTexelOption border
)
17 : m_tilingData(tileSize
, gfx::Size(), border
== HasBorderTexels
)
19 setTileSize(tileSize
);
22 LayerTilingData::~LayerTilingData()
26 void LayerTilingData::setTileSize(const gfx::Size
& size
)
28 if (tileSize() == size
)
33 m_tilingData
.SetMaxTextureSize(size
);
36 gfx::Size
LayerTilingData::tileSize() const
38 return m_tilingData
.max_texture_size();
41 void LayerTilingData::setBorderTexelOption(BorderTexelOption borderTexelOption
)
43 bool borderTexels
= borderTexelOption
== HasBorderTexels
;
44 if (hasBorderTexels() == borderTexels
)
48 m_tilingData
.SetHasBorderTexels(borderTexels
);
51 const LayerTilingData
& LayerTilingData::operator=(const LayerTilingData
& tiler
)
53 m_tilingData
= tiler
.m_tilingData
;
58 void LayerTilingData::addTile(scoped_ptr
<Tile
> tile
, int i
, int j
)
60 DCHECK(!tileAt(i
, j
));
62 m_tiles
.add(std::make_pair(i
, j
), tile
.Pass());
65 scoped_ptr
<LayerTilingData::Tile
> LayerTilingData::takeTile(int i
, int j
)
67 return m_tiles
.take_and_erase(std::make_pair(i
, j
));
70 LayerTilingData::Tile
* LayerTilingData::tileAt(int i
, int j
) const
72 return m_tiles
.get(std::make_pair(i
, j
));
75 void LayerTilingData::reset()
80 void LayerTilingData::contentRectToTileIndices(const gfx::Rect
& contentRect
, int& left
, int& top
, int& right
, int& bottom
) const
82 // An empty rect doesn't result in an empty set of tiles, so don't pass an empty rect.
83 // FIXME: Possibly we should fill a vector of tiles instead,
84 // since the normal use of this function is to enumerate some tiles.
85 DCHECK(!contentRect
.IsEmpty());
87 left
= m_tilingData
.TileXIndexFromSrcCoord(contentRect
.x());
88 top
= m_tilingData
.TileYIndexFromSrcCoord(contentRect
.y());
89 right
= m_tilingData
.TileXIndexFromSrcCoord(contentRect
.right() - 1);
90 bottom
= m_tilingData
.TileYIndexFromSrcCoord(contentRect
.bottom() - 1);
93 gfx::Rect
LayerTilingData::tileRect(const Tile
* tile
) const
95 gfx::Rect tileRect
= m_tilingData
.TileBoundsWithBorder(tile
->i(), tile
->j());
96 tileRect
.set_size(tileSize());
100 Region
LayerTilingData::opaqueRegionInContentRect(const gfx::Rect
& contentRect
) const
102 if (contentRect
.IsEmpty())
106 int left
, top
, right
, bottom
;
107 contentRectToTileIndices(contentRect
, left
, top
, right
, bottom
);
108 for (int j
= top
; j
<= bottom
; ++j
) {
109 for (int i
= left
; i
<= right
; ++i
) {
110 Tile
* tile
= tileAt(i
, j
);
114 gfx::Rect tileOpaqueRect
= gfx::IntersectRects(contentRect
, tile
->opaqueRect());
115 opaqueRegion
.Union(tileOpaqueRect
);
121 void LayerTilingData::setBounds(const gfx::Size
& size
)
123 m_tilingData
.SetTotalSize(size
);
124 if (size
.IsEmpty()) {
129 // Any tiles completely outside our new bounds are invalid and should be dropped.
130 int left
, top
, right
, bottom
;
131 contentRectToTileIndices(gfx::Rect(gfx::Point(), size
), left
, top
, right
, bottom
);
132 std::vector
<TileMapKey
> invalidTileKeys
;
133 for (TileMap::const_iterator it
= m_tiles
.begin(); it
!= m_tiles
.end(); ++it
) {
134 if (it
->first
.first
> right
|| it
->first
.second
> bottom
)
135 invalidTileKeys
.push_back(it
->first
);
137 for (size_t i
= 0; i
< invalidTileKeys
.size(); ++i
)
138 m_tiles
.erase(invalidTileKeys
[i
]);
141 gfx::Size
LayerTilingData::bounds() const
143 return m_tilingData
.total_size();