khanat-opennel-code/code/nel/include/nel/3d/texture_mem.h
2013-06-18 21:53:08 -07:00

183 lines
5 KiB
C++

// NeL - MMORPG Framework <http://dev.ryzom.com/projects/nel/>
// Copyright (C) 2010 Winch Gate Property Limited
//
// This program is free software: you can redistribute it and/or modify
// it under the terms of the GNU Affero General Public License as
// published by the Free Software Foundation, either version 3 of the
// License, or (at your option) any later version.
//
// This program is distributed in the hope that it will be useful,
// but WITHOUT ANY WARRANTY; without even the implied warranty of
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
// GNU Affero General Public License for more details.
//
// You should have received a copy of the GNU Affero General Public License
// along with this program. If not, see <http://www.gnu.org/licenses/>.
#ifndef NL_TEXTURE_MEM_H
#define NL_TEXTURE_MEM_H
#include "nel/misc/types_nl.h"
#include "nel/3d/texture.h"
#include <string>
namespace NL3D
{
// ****************************************************************************
/**
* CTextureMem
*/
class CTextureMem : public ITexture
{
uint8 *_Data;
uint32 _Length;
bool _Delete;
bool _IsFile;
bool _AllowDegradation; // the default is false
std::string _ShareName;
NLMISC::CBitmap::TType _TexType;
/// keep size for textures that aren't from a file
uint _TexWidth, _TexHeight;
public:
/**
* Default constructor
*/
CTextureMem() : _Data(NULL),
_Delete(false),
_AllowDegradation(false),
_TexType(CBitmap::RGBA)
{
}
/**
* Destructor
*/
virtual ~CTextureMem()
{
if (_Data && _Delete)
delete [] _Data;
}
/**
* constructor
* \param data Pointer of the file.
* \param length length, in bytes, of the datas.
* \param _delete Is true if the class must delete the pointer.
* \param isFile is true if the data must be interpreted as a texture file. Otherwise, it is interpreted
* as the raw datas of the texture, so the format and size of the texture must also have been set to match
* the raw datas
* \param width used only if isFile is set to false
* \param height used only if isFile is set to false
* \param texType relevant only when isFile is set to false. Gives the format to expand the texture to when it is generated.
*/
CTextureMem(uint8 *data, uint32 length, bool _delete, bool isFile = true, uint width = 0, uint height = 0, CBitmap::TType texType = CBitmap::RGBA)
{
_AllowDegradation=false;
_Data=NULL;
_Delete=false;
setPointer(data, length, _delete, isFile, width, height, texType);
}
/**
* Set the pointer of the mem file containing the texture.
* \param data Pointer of the file.
* \param length length, in bytes, of the datas.
* \param isFile is true if the data must be interpreted as a texture file. Otherwise, it is interpreted
* as the raw datas of the texture, so the format and size of the texture must also have been set to match
* the raw datas
* \param _delete Is true if the class must delete the pointer.
* \param texType relevant only when isFile is set to false. Gives the format to expand the texture to when it is generated.
*/
void setPointer(uint8 *data, uint32 length, bool _delete, bool isFile = true, uint width = 0, uint height = 0, CBitmap::TType texType = CBitmap::RGBA)
{
if (_Data&&_Delete)
delete [] _Data;
_Touched=true;
_Data=data;
_Length=length;
_Delete=_delete;
_IsFile = isFile;
_TexWidth = width;
_TexHeight = height;
_TexType = texType;
}
/**
* Get the Pointer of the memory file containing the texture.
*/
uint8* getPointer() const { return _Data; }
/**
* Get length of the memory file containing the texture
*/
uint32 getLength() const { return _Length; }
/**
* Return true if the class handle the delete of the pointer.
*/
bool isDeletable() const { return _Delete; }
/**
* Generate the texture
*/
void doGenerate(bool async = false);
/// inherited from ITexture.
virtual bool supportSharing() const
{
return !_ShareName.empty();
}
/// inherited from ITexture.
virtual std::string getShareName() const
{
nlassert(!_ShareName.empty());
return _ShareName;
}
/// Make this texture sharable by assigning it a share name. An empty share name means it is not sharable, which is the default.
void setShareName(const std::string &shareName)
{
_ShareName = shareName;
}
/// texture file may allow the driver to degrade (default is true).
virtual bool allowDegradation() const { return _AllowDegradation; }
/// Change the degradation mode. NB: this does not touch() the ITexture...
void setAllowDegradation(bool allow);
/// Todo: serialize a mem texture.
virtual void serial(NLMISC::IStream &/* f */) throw(NLMISC::EStream) {nlstop;}
NLMISC_DECLARE_CLASS(CTextureMem);
/** This create a white square texture of 1x1
* It can be used to force the activation of a texture stage with no texture.
*/
static ITexture *Create1x1WhiteTex();
// get width of RAM image
uint32 getImageWidth() const;
// get height of RAM image
uint32 getImageHeight() const;
};
} // NL3D
#endif // NL_TEXTURE_MEM_H
/* End of texture_mem.h */