FasTC/IO/config/ImageLoader.h.in

80 lines
1.8 KiB
C
Raw Normal View History

#ifndef _IMAGE_LOADER_H_
#define _IMAGE_LOADER_H_
enum EImageFileFormat {
eFileFormat_PNG,
kNumImageFileFormats
};
class ImageLoader {
protected:
unsigned int m_Width;
unsigned int m_Height;
unsigned int m_RedChannelPrecision;
unsigned char *m_RedData;
unsigned int m_GreenChannelPrecision;
unsigned char *m_GreenData;
unsigned int m_BlueChannelPrecision;
unsigned char *m_BlueData;
unsigned int m_AlphaChannelPrecision;
unsigned char *m_AlphaData;
const unsigned char *const m_RawData;
ImageLoader(const unsigned char *rawData) : m_RawData(rawData)
, m_Width(0), m_Height(0)
, m_RedChannelPrecision(0), m_RedData(0)
, m_GreenChannelPrecision(0), m_GreenData(0)
, m_BlueChannelPrecision(0), m_BlueData(0)
, m_AlphaChannelPrecision(0), m_AlphaData(0)
{ }
virtual ~ImageLoader() {
if(m_RedData) {
delete [] m_RedData;
m_RedData = 0;
}
if(m_GreenData) {
delete [] m_GreenData;
m_GreenData = 0;
}
if(m_BlueData) {
delete [] m_BlueData;
m_BlueData = 0;
}
if(m_AlphaData) {
delete [] m_AlphaData;
m_AlphaData = 0;
}
}
public:
virtual bool ReadData() = 0;
int GetRedChannelPrecision() const { return m_RedChannelPrecision; }
unsigned char * GetRedPixelData() const { return m_RedData; }
int GetGreenChannelPrecision() const { return m_GreenChannelPrecision; }
unsigned char * GetGreenPixelData() const { return m_GreenData; }
int GetBlueChannelPrecision() const { return m_BlueChannelPrecision; }
unsigned char * GetBluePixelData() const { return m_BlueData; }
int GetAlphaChannelPrecision() const { return m_AlphaChannelPrecision; }
unsigned char * GetAlphaPixelData() const { return m_AlphaData; }
};
#cmakedefine PNG_FOUND
#endif // _IMAGE_LOADER_H_