mirror of
https://port.numenaute.org/aleajactaest/khanat-opennel-code.git
synced 2025-01-09 01:15:22 +00:00
183 lines
5.2 KiB
C++
183 lines
5.2 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 */
|