khanat-opennel-code/code/nel/include/nel/3d/flare_shape.h

324 lines
9.8 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_FLARE_SHAPE_H
#define NL_FLARE_SHAPE_H
#include "nel/misc/types_nl.h"
#include "nel/misc/class_id.h"
#include "nel/3d/animation_time.h"
#include "nel/3d/shape.h"
#include "nel/3d/texture.h"
#include "nel/3d/track.h"
namespace NL3D {
// class id for flares
const NLMISC::CClassId FlareModelClassId = NLMISC::CClassId(0x6d674c32, 0x53b961a0);
// max number of flares
const uint MaxFlareNum= 10;
class CMesh;
class CShapeBank;
/**
* shape for a flare
* \author Nicolas Vizerie
* \author Nevrax France
* \date 2001
*/
class CFlareShape : public IShape
{
public:
NLMISC_DECLARE_CLASS(CFlareShape);
///\name Object
//@{
/// Constructor
CFlareShape();
/// serial this shape
void serial(NLMISC::IStream &f) throw(NLMISC::EStream);
//@}
/// inherited from IShape
virtual CTransformShape *createInstance(CScene &scene);
/// inherited from IShape
virtual bool clip(const std::vector<CPlane> &pyramid, const CMatrix &worldMatrix);
/// inherited from IShape. Does nothing. A new traverseRender() was set for that
virtual void render(IDriver * /* drv */, CTransformShape * /* trans */, bool /* opaquePass */) {}
/// inherited from IShape
virtual void getAABBox(NLMISC::CAABBox &bbox) const;
/// inherited from ishape
virtual float getNumTriangles (float distance);
/// inherited from ishape
virtual void flushTextures (IDriver &driver, uint selectedTexture);
/** set a texture for the flare
* \param index the index of the flare to set. Vaklue ranges from 0 to MaxFlareNum - 1
* \param tex the texture to set. NULL removes the texture
*/
void setTexture(uint index, ITexture *tex)
{
nlassert(index < MaxFlareNum);
_Tex[index] = tex;
if (tex)
{
// clamp borders
_Tex[index]->setWrapS(ITexture::Clamp);
_Tex[index]->setWrapT(ITexture::Clamp);
}
}
/** get the nth texture used by the flare.
* \param index the index of the flare to set. Value ranges from 0 to MaxFlareNum - 1
*/
ITexture *getTexture(uint index)
{
nlassert(index < MaxFlareNum);
return _Tex[index];
}
/// get the texture used by the flare (const version)
const ITexture *getTexture(uint index) const
{
nlassert(index < MaxFlareNum);
return _Tex[index];
}
/** set the size of the nth flare flare
* \param index the index of the flare to set. Value ranges from 0 to MaxFlareNum - 1
*/
void setSize(uint index, float size)
{
nlassert(index < MaxFlareNum);
_Size[index] = size;
}
/** get the size of the nth flare
* \param index the index of the flare to set. Value ranges from 0 to MaxFlareNum - 1
*/
float getSize(uint index) const
{
return _Size[index];
}
/** set the relative position of the nth flares. The default goes linearly from 0 (which appear at the position of the flare)
* to 1 (which appears at the center of the screen when the flare spaving is set to 1
* \see setFlareSpacing()
*/
void setRelativePos(uint index, float pos)
{
nlassert(index < MaxFlareNum);
_Pos[index] = pos;
}
/// get the relative pos of the nth flare
float getRelativePos(uint index) const
{
nlassert(index < MaxFlareNum);
return _Pos[index];
}
/// set the color of flares
void setColor(NLMISC::CRGBA col)
{
_Color = col;
}
/// get the color of flares
NLMISC::CRGBA getColor(void) const
{
return _Color;
}
/// set the flares spacing
void setFlareSpacing(float spacing)
{
_Spacing = spacing;
}
/** Get the flares spacing : A spacing of 1.f means thta the last flare will reach the center of the screen
* , a spacing of 0.5f means only the half way to the middle of the screen will be reached
*/
float getFlareSpacing(void) const
{
return _Spacing;
}
/// set the persistence of this shape, in second (the time it takes to fade from white to black)
void setPersistence(TAnimationTime persistence)
{
_Persistence = persistence;
}
/** get the persistence of this shape
* \see setPersistence
*/
TAnimationTime getPersistence(void) const
{
return _Persistence;
}
/// force radial attenuation of the flares
void setAttenuable(bool enable = true) { _Attenuable = enable; }
/// check whether radial :attenuation is on
bool getAttenuable(void) const { return _Attenuable; }
/// set the range for attenuation
void setAttenuationRange(float range) { _AttenuationRange = range; }
/// get the attenuation range
float getAttenuationRange(void) const { return _AttenuationRange; }
/// force the first flare to keep its real size (e.g the isze on screen doesn't remains constant)
void setFirstFlareKeepSize(bool enable = true) { _FirstFlareKeepSize = enable; }
/// test whether the first flare keep its real size
bool getFirstFlareKeepSize(void) const { return _FirstFlareKeepSize; }
/// enable dazzle when the flare is near the center of the screen
void enableDazzle(bool enable = true) { _DazzleEnabled = enable; }
/// check whether dazzle is enabled
bool hasDazzle(void) const { return _DazzleEnabled; }
/** set Dazzle color
* \see enableDazzle()
*/
void setDazzleColor(NLMISC::CRGBA col) { _DazzleColor = col; }
/** get Dazzle color
* \see enableDazzle()
*/
NLMISC::CRGBA getDazzleColor(void) const { return _DazzleColor; }
/** Set Dazzle attenuation range. It is the same than with attenuationRange. 1 mean that the dazzle stops when the flare
* is at the border of screen. 0.5, for the half way between center and border etc .
* \see enableDazzle()
*/
void setDazzleAttenuationRange(float range) { _DazzleAttenuationRange = range; }
/// get the attenuation range of Dazzle
float getDazzleAttenuationRange(void) const { return _DazzleAttenuationRange; }
/** set the maxViewDist for the flares
* The default is 1000
*/
void setMaxViewDist(float dist) { _MaxViewDist = dist; }
/// get the max view dist
float getMaxViewDist(void) const { return _MaxViewDist; }
/** set a distance ratio. when dist / maxViewDist is above this ratio, the flares will start to fade
* The default is 0.9
*/
void setMaxViewDistRatio(float ratio) { _MaxViewDistRatio = ratio; }
/// get the max view dist ratio
float getMaxViewDistRatio(void) const { return _MaxViewDistRatio; }
/** The flare is considered to be at the infinite. This mean that it is always drawn
* And that there's no attenuation with dist. The real flare must be created far from the camera
* for this to work. The defualt is false
*/
void setFlareAtInfiniteDist(bool enabled = true) { _InfiniteDist = enabled; }
/// test whether the flare is at the infinite
bool getFlareAtInfiniteDist(void) const { return _InfiniteDist; }
/// Transform default tracks.
CTrackDefaultVector _DefaultPos;
/// \name access default tracks.
// @{
CTrackDefaultVector* getDefaultPos () {return &_DefaultPos;}
// @}
/** Set the name of the mesh that is used to test the visible surface
* If the value is empty, then a simple point is used
* The mesh materials are ignored
*/
void setOcclusionTestMeshName(const std::string &shapeName);
const std::string &getOcclusionTestMeshName() const { return _OcclusionTestMeshName; }
/** Return the mesh that is used to perform the occlusion test.
* \return pointer to the mesh, or NULL if not used or not found
*/
CMesh *getOcclusionTestMesh(CShapeBank &sb);
// Tell whether the occlusion mesh inherit the rotation/scale part of the model matrix
void setOcclusionTestMeshInheritScaleRot(bool on) { _OcclusionTestMeshInheritScaleRot = on; }
bool getOcclusionTestMeshInheritScaleRot() const { return _OcclusionTestMeshInheritScaleRot; }
void setScaleWhenDisappear(bool enable) { _ScaleWhenDisappear = enable; }
bool getScaleWhenDisappear() const { return _ScaleWhenDisappear; }
void setSizeDisappear(float size) { _SizeDisappear = size; }
void setAngleDisappear(float angle) { _AngleDisappear = angle; }
float getSizeDisappear() const { return _SizeDisappear; }
float getAngleDisappear() const { return _AngleDisappear; }
// decide whether first flare is displayed using lookat mode
void setLookAtMode(bool on) { _LookAtMode = on; }
bool getLookAtMode() const { return _LookAtMode; }
protected:
friend class CFlareModel;
NLMISC::CSmartPtr<ITexture> _Tex[MaxFlareNum];
NLMISC::CRGBA _Color;
NLMISC::CRGBA _DazzleColor;
float _Size[MaxFlareNum];
float _SizeDisappear;
bool _ScaleWhenDisappear;
float _AngleDisappear;
float _Pos[MaxFlareNum];
TAnimationTime _Persistence;
float _Spacing;
bool _Attenuable;
float _AttenuationRange;
bool _FirstFlareKeepSize;
bool _DazzleEnabled;
float _DazzleAttenuationRange;
float _MaxViewDist;
float _MaxViewDistRatio;
bool _InfiniteDist;
std::string _OcclusionTestMeshName;
NLMISC::CSmartPtr<CMesh> _OcclusionTestMesh;
bool _OcclusionMeshNotFound;
bool _OcclusionTestMeshInheritScaleRot;
bool _LookAtMode;
};
} // NL3D
#endif // NL_FLARE_SHAPE_H
/* End of flare_shape.h */