Blob Blame Raw


#include "toonz/ttileset.h"
#include "tcodec.h"
#include "timagecache.h"
#include "ttoonzimage.h"
#include "trasterimage.h"
//------------------------------------------------------------------------------------------

TTileSet::Tile::Tile()
	: m_rasterBounds(TRect()), m_dim(), m_pixelSize(0)
{
}

//------------------------------------------------------------------------------------------

TTileSet::Tile::Tile(const TRasterP &ras, const TPoint &p)
	: m_rasterBounds(ras->getBounds() + p), m_dim(ras->getSize()), m_pixelSize(ras->getPixelSize())
{
}

//------------------------------------------------------------------------------------------

TTileSet::Tile::~Tile()
{
}

//------------------------------------------------------------------------------------------

TTileSet::~TTileSet()
{
	clearPointerContainer(m_tiles);
}

//------------------------------------------------------------------------------------------

void TTileSet::add(Tile *tile)
{
	m_tiles.push_back(tile);
}

//------------------------------------------------------------------------------------------

void TTileSet::getRects(std::vector<TRect> &rects) const
{
	for (Tiles::const_iterator it = m_tiles.begin(); it != m_tiles.end(); ++it)
		rects.push_back((*it)->m_rasterBounds);
}

//------------------------------------------------------------------------------------------

TRect TTileSet::getBBox() const
{
	if (m_tiles.empty()) {
		return TRect();
	}
	Tiles::const_iterator it = m_tiles.begin();
	TRect bbox = (*it)->m_rasterBounds;
	for (; it != m_tiles.end(); ++it)
		bbox += (*it)->m_rasterBounds;
	return bbox;
}

//------------------------------------------------------------------------------------------

int TTileSet::getMemorySize() const
{
	int i, size = 0;
	for (i = 0; i < m_tiles.size(); i++) {
		size += m_tiles[i]->getSize();
	}
	return size;
}

//******************************************************************************************

TTileSetCM32::Tile::Tile()
	: TTileSet::Tile()
{
}

//------------------------------------------------------------------------------------------

TTileSetCM32::Tile::Tile(const TRasterCM32P &ras, const TPoint &p)
	: TTileSet::Tile(TRasterP(ras), p)
{
	TImageCache::instance()->add(id(), TToonzImageP(ras, ras->getBounds()));
}

//------------------------------------------------------------------------------------------

TTileSetCM32::Tile::~Tile()
{
	TImageCache::instance()->remove(id());
}

//------------------------------------------------------------------------------------------

TTileSetCM32::~TTileSetCM32()
{
}

//------------------------------------------------------------------------------------------

void TTileSetCM32::Tile::getRaster(TRasterCM32P &ras) const
{
	TToonzImageP timg = (TToonzImageP)TImageCache::instance()->get(id(), true);
	if (!timg)
		return;
	ras = timg->getRaster();
	assert(ras);
}

//------------------------------------------------------------------------------------------

TTileSetCM32::Tile *TTileSetCM32::Tile::clone() const
{
	Tile *tile = new Tile();
	tile->m_rasterBounds = m_rasterBounds;
	TToonzImageP timg = (TToonzImageP)TImageCache::instance()->get(id(), true);
	if (!timg)
		return tile;
	TImageCache::instance()->add(tile->id(), timg->clone());
	return tile;
}

//------------------------------------------------------------------------------------------

void TTileSetCM32::add(const TRasterP &ras, TRect rect)
{
	TRect bounds = ras->getBounds();
	if (!bounds.overlaps(rect))
		return;
	rect *= bounds;
	assert(!rect.isEmpty());
	assert(bounds.contains(rect));
	TTileSet::add(new Tile(ras->extract(rect)->clone(), rect.getP00()));
}

//------------------------------------------------------------------------------------------

const TTileSetCM32::Tile *TTileSetCM32::getTile(int index) const
{
	assert(0 <= index && index < getTileCount());
	TTileSetCM32::Tile *tile = dynamic_cast<TTileSetCM32::Tile *>(m_tiles[index]);
	assert(tile);
	return tile;
}

//------------------------------------------------------------------------------------------

TTileSetCM32::Tile *TTileSetCM32::editTile(int index) const
{
	assert(0 <= index && index < getTileCount());
	TTileSetCM32::Tile *tile = dynamic_cast<TTileSetCM32::Tile *>(m_tiles[index]);
	assert(tile);
	return tile;
}

//------------------------------------------------------------------------------------------

TTileSetCM32 *TTileSetCM32::clone() const
{
	TTileSetCM32 *tileSet = new TTileSetCM32(m_srcImageSize);
	Tiles::const_iterator it = m_tiles.begin();
	for (; it != m_tiles.end(); ++it)
		tileSet->m_tiles.push_back((*it)->clone());
	return tileSet;
}

//******************************************************************************************

TTileSetFullColor::Tile::Tile()
	: TTileSet::Tile()
{
}

//------------------------------------------------------------------------------------------

TTileSetFullColor::Tile::Tile(const TRasterP &ras, const TPoint &p)
	: TTileSet::Tile(ras, p)
{
	TImageCache::instance()->add(id(), TRasterImageP(ras));
}

//------------------------------------------------------------------------------------------

TTileSetFullColor::Tile::~Tile()
{
	TImageCache::instance()->remove(id());
}

//------------------------------------------------------------------------------------------

TTileSetFullColor::~TTileSetFullColor()
{
}

//------------------------------------------------------------------------------------------

void TTileSetFullColor::Tile::getRaster(TRasterP &ras) const
{
	TRasterImageP img = (TRasterImageP)TImageCache::instance()->get(id(), true);
	if (!img)
		return;
	ras = img->getRaster();
	assert(!!ras);
}

//------------------------------------------------------------------------------------------

TTileSetFullColor::Tile *TTileSetFullColor::Tile::clone() const
{
	Tile *tile = new Tile();
	tile->m_rasterBounds = m_rasterBounds;
	TRasterImageP img = (TRasterImageP)TImageCache::instance()->get(id(), true);
	if (!img)
		return tile;
	TRasterImageP clonedImage(img->getRaster()->clone());
	TImageCache::instance()->add(tile->id(), clonedImage);
	return tile;
}

//------------------------------------------------------------------------------------------

void TTileSetFullColor::add(const TRasterP &ras, TRect rect)
{
	TRect bounds = ras->getBounds();
	if (!bounds.overlaps(rect))
		return;
	rect *= bounds;
	assert(!rect.isEmpty());
	assert(bounds.contains(rect));
	TTileSet::add(new Tile(ras->extract(rect)->clone(), rect.getP00()));
}

//------------------------------------------------------------------------------------------

const TTileSetFullColor::Tile *TTileSetFullColor::getTile(int index) const
{
	assert(0 <= index && index < getTileCount());
	TTileSetFullColor::Tile *tile = dynamic_cast<TTileSetFullColor::Tile *>(m_tiles[index]);
	assert(tile);
	return tile;
}

//------------------------------------------------------------------------------------------

TTileSetFullColor *TTileSetFullColor::clone() const
{
	TTileSetFullColor *tileSet = new TTileSetFullColor(m_srcImageSize);
	Tiles::const_iterator it = m_tiles.begin();
	for (; it != m_tiles.end(); ++it)
		tileSet->m_tiles.push_back((*it)->clone());
	return tileSet;
}