2008-05-22 11:51:37 +00:00
|
|
|
// Copyright (C) 2002-2008 Nikolaus Gebhardt
|
2007-05-20 18:03:49 +00:00
|
|
|
// This file is part of the "Irrlicht Engine".
|
|
|
|
// For conditions of distribution and use, see copyright notice in irrlicht.h
|
|
|
|
|
|
|
|
#ifndef __I_SURFACE_LOADER_H_INCLUDED__
|
|
|
|
#define __I_SURFACE_LOADER_H_INCLUDED__
|
|
|
|
|
2007-09-07 06:11:47 +00:00
|
|
|
#include "IReferenceCounted.h"
|
2007-05-20 18:03:49 +00:00
|
|
|
#include "IImage.h"
|
|
|
|
|
|
|
|
namespace irr
|
|
|
|
{
|
|
|
|
namespace io
|
|
|
|
{
|
|
|
|
class IReadFile;
|
|
|
|
} // end namespace io
|
|
|
|
namespace video
|
|
|
|
{
|
|
|
|
|
2008-05-22 11:51:37 +00:00
|
|
|
//! Class which is able to create a image from a file.
|
|
|
|
/** If you want the Irrlicht Engine be able to load textures of
|
2007-05-20 18:03:49 +00:00
|
|
|
currently unsupported file formats (e.g .gif), then implement
|
2008-05-22 11:51:37 +00:00
|
|
|
this and add your new Surface loader with
|
2007-05-20 18:03:49 +00:00
|
|
|
IVideoDriver::addExternalImageLoader() to the engine. */
|
2007-09-07 06:11:47 +00:00
|
|
|
class IImageLoader : public virtual IReferenceCounted
|
2007-05-20 18:03:49 +00:00
|
|
|
{
|
|
|
|
public:
|
|
|
|
|
2008-05-22 11:51:37 +00:00
|
|
|
//! Destructor
|
2007-09-16 23:41:55 +00:00
|
|
|
virtual ~IImageLoader() {}
|
2007-05-20 18:03:49 +00:00
|
|
|
|
2008-05-22 11:51:37 +00:00
|
|
|
//! Check if the file might be loaded by this class
|
|
|
|
/** Check is based on the file extension (e.g. ".tga")
|
|
|
|
\param fileName Name of file to check.
|
|
|
|
\return True if file seems to be loadable. */
|
2007-09-16 23:41:55 +00:00
|
|
|
virtual bool isALoadableFileExtension(const c8* fileName) const = 0;
|
2007-05-20 18:03:49 +00:00
|
|
|
|
2008-05-22 11:51:37 +00:00
|
|
|
//! Check if the file might be loaded by this class
|
|
|
|
/** Check might look into the file.
|
|
|
|
\param file File handle to check.
|
|
|
|
\return True if file seems to be loadable. */
|
2007-09-19 14:08:28 +00:00
|
|
|
virtual bool isALoadableFileFormat(io::IReadFile* file) const = 0;
|
2007-05-20 18:03:49 +00:00
|
|
|
|
2008-05-22 11:51:37 +00:00
|
|
|
//! Creates a surface from the file
|
|
|
|
/** \param file File handle to check.
|
|
|
|
\return Pointer to newly created image, or 0 upon error. */
|
2007-09-19 14:08:28 +00:00
|
|
|
virtual IImage* loadImage(io::IReadFile* file) const = 0;
|
2007-05-20 18:03:49 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
} // end namespace video
|
|
|
|
} // end namespace irr
|
|
|
|
|
|
|
|
#endif
|
|
|
|
|