Blob Blame Raw
#pragma once

#ifndef IMAGE_BUILDERS_H
#define IMAGE_BUILDERS_H

#include "tfilepath.h"

#include "toonz/imagemanager.h"

//======================================================

//  Forward declarations

class TImageInfo;
class TXshSimpleLevel;

//======================================================

//***************************************************************************************
//    ImageLoader  class declaration
//***************************************************************************************

/*!
  ImageLoader is the specialized ImageBuilder class used to automatically load
  images from a level file on hard disk.

  Refer to ImageLoader::BuildExtData for a description of the allowed options for
  image loading.
*/
class ImageLoader : public ImageBuilder
{
public:
	struct BuildExtData {
		const TXshSimpleLevel *m_sl; //!< TXshSimpleLevel instance associated to an image loading request
		TFrameId m_fid;				 //!< m_sl's fid at which the image will be loaded

		int m_subs; //!< The subsampling factor for image loading (0 meaning either
		//!< 'the currently stored one' if an image is already cached, or
		//!< m_sl's subsampling property otherwise)
		bool m_icon; //!< Whether the icon (if any) should be loaded instead

	public:
		BuildExtData(const TXshSimpleLevel *sl, const TFrameId &fid, int subs = 0, bool icon = false)
			: m_sl(sl), m_fid(fid), m_subs(subs), m_icon(icon) {}
	};

public:
	ImageLoader(const TFilePath &path, const TFrameId &fid);

	bool isImageCompatible(int imFlags, void *extData);

	/*-- ImageBuilder仮想関数の実装。アイコン、画像をLoad時に全てキャッシュに格納する --*/
	void buildAllIconsAndPutInCache(TXshSimpleLevel *level,
									std::vector<TFrameId> fids,
									std::vector<std::string> iconIds,
									bool cacheImagesAsWell);

protected:
	bool getInfo(TImageInfo &info, int imFlags, void *extData);
	TImageP build(int imFlags, void *extData);

	void invalidate();

	inline int buildSubsampling(int imFlags, BuildExtData *data);

private:
	TFilePath m_path; //!< Level path to load images from
	TFrameId m_fid;   //!< Frame of the level to load

	bool m_64bitCompatible; //!< Whether current image is 64-bit compatible
	int m_subsampling;		//!< Current image subsampling
							//!< NOTE: Should this be replaced by requests to the TImageCache?
};

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

class ImageRasterizer : public ImageBuilder
{
public:
	ImageRasterizer() {}
	~ImageRasterizer() {}

	bool isImageCompatible(int imFlags, void *extData) { return true; }

protected:
	bool getInfo(TImageInfo &info, int imFlags, void *extData);
	TImageP build(int imFlags, void *extData);
};

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

class ImageFiller : public ImageBuilder
{
public:
	ImageFiller() {}
	~ImageFiller() {}

	bool isImageCompatible(int imFlags, void *extData) { return true; }

protected:
	bool getInfo(TImageInfo &info, int imFlags, void *extData);
	TImageP build(int imFlags, void *extData);
};

#endif // IMAGE_BUILDERS_H