#include "toonz/ttilesaver.h"
#include "toonz/ttileset.h"
#define TILE_BIT_SIZE 6
#define TILE_SIZE_MINUS_1 63
//divisione per tileSize approssimata per eccesso
inline int divSup(int x)
{
// return (x & TILE_SIZE_MINUS_1)? (x>>TILE_BIT_SIZE)+1 : (x>>TILE_BIT_SIZE);
return ((x + TILE_SIZE_MINUS_1) >> TILE_BIT_SIZE);
}
//------------------------------------------------------------------------
TTileSaverCM32::TTileSaverCM32(const TRasterCM32P &raster, TTileSetCM32 *tileSet)
: m_raster(raster), m_tileSet(tileSet), m_rowSize(divSup(raster->getLx())), m_savedTiles(m_rowSize * divSup(raster->getLy()), 0)
{
}
//------------------------------------------------------------------------
void TTileSaverCM32::saveTile(int row, int col)
{
UINT index = m_rowSize * row + col;
assert(index < m_savedTiles.size());
if (m_savedTiles[index])
return;
m_savedTiles[index] = 1;
int x = col << TILE_BIT_SIZE;
int y = row << TILE_BIT_SIZE;
TRect tileBounds(x, y, x + TILE_SIZE_MINUS_1, y + TILE_SIZE_MINUS_1);
m_tileSet->add(m_raster, tileBounds);
}
//------------------------------------------------------------------------
void TTileSaverCM32::save(TRect rect)
{
if (!m_raster->getBounds().overlaps(rect))
return;
rect = rect * m_raster->getBounds();
TPoint p0 = rect.getP00();
TPoint p1 = rect.getP11();
int col0 = p0.x >> TILE_BIT_SIZE;
int row0 = p0.y >> TILE_BIT_SIZE;
int col1 = p1.x >> TILE_BIT_SIZE;
int row1 = p1.y >> TILE_BIT_SIZE;
for (int row = row0; row <= row1; ++row)
for (int col = col0; col <= col1; ++col)
saveTile(row, col);
}
//------------------------------------------------------------------------
void TTileSaverCM32::save(TPoint point)
{
if (m_raster->getBounds().contains(point))
saveTile(point.y >> TILE_BIT_SIZE, point.x >> TILE_BIT_SIZE);
}
//------------------------------------------------------------------------
TTileSetCM32 *TTileSaverCM32::getTileSet() const
{
return m_tileSet;
}
//********************************************************************************
TTileSaverFullColor::TTileSaverFullColor(const TRasterP &raster, TTileSetFullColor *tileSet)
: m_raster(raster), m_tileSet(tileSet), m_rowSize(divSup(raster->getLx())), m_savedTiles(m_rowSize * divSup(raster->getLy()), 0)
{
}
//------------------------------------------------------------------------
void TTileSaverFullColor::saveTile(int row, int col)
{
UINT index = m_rowSize * row + col;
assert(index < m_savedTiles.size());
if (m_savedTiles[index])
return;
m_savedTiles[index] = 1;
int x = col << TILE_BIT_SIZE;
int y = row << TILE_BIT_SIZE;
TRect tileBounds(x, y, x + TILE_SIZE_MINUS_1, y + TILE_SIZE_MINUS_1);
m_tileSet->add(m_raster, tileBounds);
}
//------------------------------------------------------------------------
void TTileSaverFullColor::save(TRect rect)
{
if (!m_raster->getBounds().overlaps(rect))
return;
rect = rect * m_raster->getBounds();
TPoint p0 = rect.getP00();
TPoint p1 = rect.getP11();
int col0 = p0.x >> TILE_BIT_SIZE;
int row0 = p0.y >> TILE_BIT_SIZE;
int col1 = p1.x >> TILE_BIT_SIZE;
int row1 = p1.y >> TILE_BIT_SIZE;
for (int row = row0; row <= row1; ++row)
for (int col = col0; col <= col1; ++col)
saveTile(row, col);
}
//------------------------------------------------------------------------
void TTileSaverFullColor::save(TPoint point)
{
if (m_raster->getBounds().contains(point))
saveTile(point.y >> TILE_BIT_SIZE, point.x >> TILE_BIT_SIZE);
}
//------------------------------------------------------------------------
TTileSetFullColor *TTileSaverFullColor::getTileSet() const
{
return m_tileSet;
}