khanat-opennel-code/code/nel/include/nel/3d/u_instance_material.h
2012-07-02 22:49:24 +02:00

224 lines
7.3 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_U_INSTANCE_MATERIAL_H
#define NL_U_INSTANCE_MATERIAL_H
#include "nel/misc/types_nl.h"
#include "nel/misc/rgba.h"
#include "nel/misc/matrix.h"
#include "nel/misc/bitmap.h"
namespace NL3D
{
using NLMISC::CRGBA;
// ***************************************************************************
/**
* Base interface for manipulating Material retrieved from UInstance.
* \author Lionel Berenguier
* \author Nevrax France
* \date 2001
*/
class UInstanceMaterial
{
public:
enum ZFunc { always=0,never,equal,notequal,less,lessequal,greater,greaterequal, zfuncCount };
enum TBlend { one=0, zero, srcalpha, invsrcalpha, srccolor, invsrccolor, blendCount };
// This enums MUST be the same than in ITexture!!
enum TWrapMode
{
Repeat= 0,
Clamp,
WrapModeCount
};
public:
/// \name Modes.
// @{
bool isLighted() const;
void setLighting(bool active,
CRGBA emissive=CRGBA(0,0,0),
CRGBA ambient=CRGBA(0,0,0),
CRGBA diffuse=CRGBA(0,0,0),
CRGBA specular=CRGBA(0,0,0),
float shininess= 10);
bool isUserColor() const;
// @}
/// \name Blending.
// @{
void setBlend(bool active);
void setBlendFunc(TBlend src, TBlend dst);
void setSrcBlend(TBlend val);
void setDstBlend(TBlend val);
void setAlphaTestThreshold(float at);
void setZWrite(bool active);
void setZFunc(ZFunc val);
float getAlphaTestThreshold() const;
void setAlphaTest(bool active);
bool getBlend() const;
TBlend getSrcBlend(void) const;
TBlend getDstBlend(void) const;
// @}
/// \name Lighted material mgt. Has effect only if isLighted().
// @{
/// Set the emissive part ot material. Useful only if isLighted()
void setEmissive( CRGBA emissive=CRGBA(0,0,0) );
/// Set the Ambient part ot material. Useful only if isLighted()
void setAmbient( CRGBA ambient=CRGBA(0,0,0) );
/// Set the Diffuse part ot material. Useful only if isLighted()
void setDiffuse( CRGBA diffuse=CRGBA(0,0,0) );
/// Set the Opacity part ot material. Useful only if isLighted()
void setOpacity( uint8 opa );
/// Set the specular part ot material. Useful only if isLighted()
void setSpecular( CRGBA specular=CRGBA(0,0,0) );
/// Set the shininess part ot material. Useful only if isLighted()
void setShininess( float shininess );
CRGBA getEmissive() const;
CRGBA getAmbient() const;
/// return diffuse part. NB: A==opacity.
CRGBA getDiffuse() const;
uint8 getOpacity() const;
CRGBA getSpecular() const;
float getShininess() const;
// @}
/// \name UnLighted material mgt. Has effect only if !isLighted().
// @{
void setColor(CRGBA rgba);
CRGBA getColor(void) const;
// @}
/// \name Per stage constant color
// @{
void setConstantColor(uint stage, NLMISC::CRGBA color);
NLMISC::CRGBA getConstantColor(uint stage) const;
// @}
/// \name Texture UserColor. No effect if !isUserColor(). (getUserColor() return CRGBA(0,0,0,0))
// @{
void setUserColor(CRGBA userColor);
CRGBA getUserColor() const;
// @}
/// \name Texture files specific
// @{
/// Get the last stage that got a texture. -1 means there is no textures.
sint getLastTextureStage() const;
/// Check whether the texture of the n-th stage is a texture file
bool isTextureFile(uint stage) const;
/// Get the fileName used by the n-th texture file. (must be a texture file or an assertion is raised)
std::string getTextureFileName(uint stage) const;
// Empty the texture at the given stage
void emptyTexture(uint stage = 0);
/** Set the fileName used by the n-th texture file. (must be a texture file or an assertion is raised)
* NB: if success and if instanceOwner->getAsyncTextureMode()==true, then instanceOwner->setAsyncTextureDirty(true)
* is called
*/
void setTextureFileName(const std::string &fileName, uint stage = 0);
/** Set the texture datas to be read from memory rather than from a file. This erases any previous texture at that slot.
* The provided block can be a memory image of a file, however
* \param stage The stage at which texture must be set
* \param data Pointer of the file, or of the pixels datas
* \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 texture has ownership on the texture datas
* \param texType relevant only when isFile is set to false. Gives the format to expand the texture to when it is generated.
*/
void setTextureMem(uint stage, uint8 *data, uint32 length, bool _delete, bool isFile = true, uint width = 0, uint height = 0, NLMISC::CBitmap::TType texType = NLMISC::CBitmap::RGBA);
// Set wrapping mode for a texture
void setWrapS(uint stage, TWrapMode mode);
void setWrapT(uint stage, TWrapMode mode);
TWrapMode getWrapS(uint stage) const;
TWrapMode getWrapT(uint stage) const;
// set
/// \name Texture matrix
// @{
// Enable a user texture matrix for the n-th stage. The initial matrix is set to identity.
void enableUserTexMat(uint stage, bool enabled = true);
// Test whether a user texture is enabled for the n-th stage
bool isUserTexMatEnabled(uint stage) const;
/// Set a new texture matrix for the given stage.
void setUserTexMat(uint stage, const NLMISC::CMatrix &m);
/** Get a const ref. on the texture matrix of the n-th stage.
*/
const NLMISC::CMatrix &getUserTexMat(uint stage) const;
// @}
/// Proxy interface
/// Constructors
UInstanceMaterial()
{
_Object = NULL;
}
UInstanceMaterial(class CMeshBaseInstance *mbi, class CMaterial *object, class CAsyncTextureBlock *asyncTextureBlock)
{
_MBI = mbi;
_Object = object;
_AsyncTextureBlock = asyncTextureBlock;
};
/// Attach an object to this proxy
void attach(class CMeshBaseInstance *mbi, class CMaterial *object, class CAsyncTextureBlock *asyncTextureBlock)
{
_MBI = mbi;
_Object = object;
_AsyncTextureBlock = asyncTextureBlock;
}
/// Detach the object
void detach()
{
_MBI = NULL;
_Object = NULL;
_AsyncTextureBlock = NULL;
}
/// Return true if the proxy is empty() (not attached)
bool empty() const {return _Object==NULL;}
/// For advanced usage, get the internal object ptr
class CMaterial *getObjectPtr() const {return (CMaterial*)_Object;}
private:
CMeshBaseInstance *_MBI;
CMaterial *_Object;
CAsyncTextureBlock *_AsyncTextureBlock;
};
} // NL3D
#endif // NL_U_INSTANCE_MATERIAL_H
/* End of u_instance_material.h */