177 lines
5.5 KiB
C++
177 lines
5.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_PS_QUAD_H
|
|
#define NL_PS_QUAD_H
|
|
|
|
#include "nel/3d/ps_particle_basic.h"
|
|
#include "nel/3d/vertex_buffer.h"
|
|
|
|
namespace NL3D
|
|
{
|
|
|
|
|
|
class IDriver;
|
|
|
|
|
|
/** This abstract class holds what is needed with quad particles (CPSFaceLookAt, CPSFace) e.g
|
|
* Index and vertex buffer and method to setup them
|
|
* Material, and method to setup them
|
|
*/
|
|
|
|
class CPSQuad : public CPSParticle
|
|
, public CPSColoredParticle
|
|
, public CPSTexturedParticle
|
|
, public CPSMultiTexturedParticle
|
|
, public CPSSizedParticle
|
|
, public CPSMaterial
|
|
{
|
|
public:
|
|
/** create the quad by giving a texture. This can't be a CTextureGrouped (for animation)
|
|
* animation must be set later by using setTextureScheme
|
|
*/
|
|
CPSQuad(CSmartPtr<ITexture> tex = NULL);
|
|
|
|
|
|
/// return true if there are transparent faces in the object
|
|
virtual bool hasTransparentFaces(void);
|
|
|
|
/// return true if there are Opaque faces in the object
|
|
virtual bool hasOpaqueFaces(void);
|
|
|
|
/// return the max number of faces needed for display. This is needed for LOD balancing
|
|
virtual uint32 getNumWantedTris() const;
|
|
|
|
/// init the vertex buffers
|
|
static void initVertexBuffers();
|
|
|
|
// from CPSParticle
|
|
virtual bool supportGlobalColorLighting() const { return true; }
|
|
|
|
// from CPSParticle
|
|
virtual void setZBias(float value);
|
|
virtual float getZBias() const { return CPSMaterial::getZBias(); }
|
|
|
|
// from CPSLocatedBindable
|
|
virtual void enumTexs(std::vector<NLMISC::CSmartPtr<ITexture> > &dest, IDriver &drv);
|
|
|
|
|
|
protected:
|
|
// dtor
|
|
virtual ~CPSQuad();
|
|
|
|
/// initialisations
|
|
virtual void init(void);
|
|
|
|
/// update the material and the vb so that they match the color scheme. Inherited from CPSColoredParticle
|
|
virtual void updateMatAndVbForColor(void);
|
|
|
|
/// update the material and the vb so that they match the texture scheme.
|
|
virtual void updateMatAndVbForTexture(void);
|
|
|
|
/** update material before rendering
|
|
* This may also change the vb uv routing (if embm is used)
|
|
*/
|
|
void updateMatBeforeRendering(IDriver *drv, CVertexBuffer &vb);
|
|
|
|
/// this is inlined to save cost of call by derived class
|
|
void newElement(const CPSEmitterInfo &info)
|
|
{
|
|
newColorElement(info);
|
|
newSizeElement(info);
|
|
newTextureIndexElement(info);
|
|
}
|
|
|
|
/// this is inlined to save cost of call by derived class
|
|
void deleteElement(uint32 index)
|
|
{
|
|
deleteColorElement(index);
|
|
deleteSizeElement(index);
|
|
deleteTextureIndexElement(index);
|
|
}
|
|
|
|
void resize(uint32 capacity);
|
|
|
|
/// complete the bbox depending on the size of particles
|
|
virtual bool completeBBox(NLMISC::CAABBox &box) const;
|
|
|
|
/** calculate current color and texture coordinate before any rendering
|
|
* size can't be higher that quadBufSize ...
|
|
*/
|
|
void updateVbColNUVForRender(CVertexBuffer &vb, uint32 startIndex, uint32 numQuad, uint32 srcStep, IDriver &drv);
|
|
|
|
/// DERIVERS MUST CALL this
|
|
void serial(NLMISC::IStream &f) throw(NLMISC::EStream);
|
|
virtual CPSLocated *getColorOwner(void) { return _Owner; }
|
|
virtual CPSLocated *getSizeOwner(void) { return _Owner; }
|
|
virtual CPSLocated *getTextureIndexOwner(void) { return _Owner; }
|
|
|
|
enum VBType
|
|
{
|
|
VBCol = 0x0001, // the vb has colors
|
|
VBTex = 0x0002, // the vb has textures coordinates
|
|
VBTexAnimated = 0x0004, // the texture coordinate can be animated (not precomputed)
|
|
VBTex2 = 0x0008, // the vb has second texture coordinates
|
|
VBTex2Animated = 0x0010, // the second texture coordinates can be animated (not precomputed)
|
|
VBFullMask = 0x001f
|
|
};
|
|
|
|
/// the various kind of vertex buffers we need
|
|
static CVertexBuffer _VBPos;
|
|
static CVertexBuffer _VBPosCol;
|
|
static CVertexBuffer _VBPosTex1;
|
|
static CVertexBuffer _VBPosTex1Col;
|
|
static CVertexBuffer _VBPosTex1Anim;
|
|
static CVertexBuffer _VBPosTex1AnimCol;
|
|
//==========
|
|
static CVertexBuffer _VBPosTex1Tex2;
|
|
static CVertexBuffer _VBPosTex1ColTex2;
|
|
static CVertexBuffer _VBPosTex1AnimTex2;
|
|
static CVertexBuffer _VBPosTex1AnimColTex2;
|
|
//==========
|
|
static CVertexBuffer _VBPosTex1Tex2Anim;
|
|
static CVertexBuffer _VBPosTex1ColTex2Anim;
|
|
static CVertexBuffer _VBPosTex1AnimTex2Anim;
|
|
static CVertexBuffer _VBPosTex1AnimColTex2Anim;
|
|
|
|
/// get the vertex buffer that is needed for drawing
|
|
CVertexBuffer &getNeededVB(IDriver &drv);
|
|
|
|
|
|
/// used to get a pointer on the right vb dependant on its type (cf. values of VBType)
|
|
static CVertexBuffer * const _VbTab[];
|
|
|
|
|
|
// from CPSTexturedParticle / CPSMultiTexturedParticle : gives us the opportunity to update wrap mode for quad particles
|
|
virtual void setTexture(CSmartPtr<ITexture> tex);
|
|
virtual void setTextureGroup(NLMISC::CSmartPtr<CTextureGrouped> texGroup);
|
|
virtual void setTexture2(ITexture *tex);
|
|
virtual void setTexture2Alternate(ITexture *tex);
|
|
virtual void updateTexWrapMode(IDriver &drv);
|
|
|
|
|
|
public:
|
|
/// The number of quad to batche for each driver call.
|
|
enum { quadBufSize = 800 };
|
|
};
|
|
|
|
|
|
} // NL3D
|
|
|
|
|
|
#endif // NL_PS_QUAD_H
|
|
|
|
/* End of ps_quad.h */
|