339 lines
10 KiB
C++
339 lines
10 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_GROUP_H
|
|
#define NL_U_INSTANCE_GROUP_H
|
|
|
|
#include "nel/misc/types_nl.h"
|
|
#include "nel/misc/rgba.h"
|
|
#include "point_light_influence.h"
|
|
|
|
#include <vector>
|
|
#include <string>
|
|
|
|
namespace NLMISC
|
|
{
|
|
class CVector;
|
|
class CQuat;
|
|
class CMatrix;
|
|
}
|
|
|
|
namespace NL3D
|
|
{
|
|
class UInstance;
|
|
class UDriver;
|
|
|
|
|
|
|
|
|
|
/** Callback to know when an instance group begin to be added
|
|
*/
|
|
struct IIGAddBegin
|
|
{
|
|
virtual ~IIGAddBegin() {}
|
|
virtual void startAddingIG(uint numInstances) = 0;
|
|
};
|
|
|
|
/** Callback to know when an instance group is added / removed from the scene.
|
|
* NB: This is called after all 'transformName' calls in the ITransformName callback
|
|
*/
|
|
struct IAddRemoveInstance
|
|
{
|
|
virtual ~IAddRemoveInstance() {}
|
|
// All instances have been been added to the scene
|
|
virtual void instanceGroupAdded() = 0;
|
|
// All instances have been removed from the scene
|
|
virtual void instanceGroupRemoved() = 0;
|
|
};
|
|
|
|
/**
|
|
* Callback class used at instancegroup loading
|
|
*
|
|
* \author Matthieu 'TrapII' Besson
|
|
* \author Nevrax France
|
|
* \date 2002
|
|
*/
|
|
|
|
class ITransformName
|
|
{
|
|
|
|
public:
|
|
virtual ~ITransformName() {}
|
|
/**
|
|
* transformName is called at the addToScene(Async) moment to transform the name of an
|
|
* instance to another name. This should be useful to replace various shapes by others
|
|
* like in a shape-template. The function is called with the name of the shape and the
|
|
* user must return the new name of the shape.
|
|
* NB: This is called after the 'startAddingIG' calls in the IIGAddBegin callback
|
|
* \param instanceName is the name of the instance contained in the instance group (user string)
|
|
* \param shapeName is the name of the instance contained in the instance group (user string)
|
|
* \return the new name of the shape which must be loaded in place of the param
|
|
*/
|
|
virtual std::string transformName (uint index, const std::string &instanceName, const std::string &shapeName) = 0;
|
|
};
|
|
|
|
|
|
|
|
|
|
/**
|
|
* Game interface for managing group instance.
|
|
*
|
|
* \author Cyril 'Hulud' Corvazier
|
|
* \author Nevrax France
|
|
* \date 2001
|
|
*/
|
|
class UInstanceGroup
|
|
|
|
{
|
|
public:
|
|
|
|
enum TState { StateNotAdded = 0, StateAdding, StateAdded, StateError };
|
|
|
|
/**
|
|
* Instance group
|
|
*/
|
|
virtual ~UInstanceGroup () {}
|
|
|
|
|
|
/**
|
|
* Set up the callback used at loading and instanciating of the instanceGroup
|
|
* \param pTN is the transformName class that hold the callback
|
|
*/
|
|
virtual void setTransformNameCallback (ITransformName *pTN)=0;
|
|
|
|
/// set a callback to know when an instance has been added / removed from scene
|
|
virtual void setAddRemoveInstanceCallback(IAddRemoveInstance *callback) = 0;
|
|
|
|
/// Set a callback to know when an instance group is being created, and how many instances it contains
|
|
virtual void setIGAddBeginCallback(IIGAddBegin *callback) = 0;
|
|
|
|
/**
|
|
* Add all the instances to the scene. By default, freezeHRC() those instances and the root.
|
|
*
|
|
* \param scene is the scene in which you want to add the instance group.
|
|
* \param driver is a pointer to a driver. If this pointer is not NULL, the textures used by
|
|
* the shapes will be preloaded in this driver. If the pointer is NULL (default), textures
|
|
* will ve loaded when the shape will be used.
|
|
*/
|
|
virtual void addToScene (class UScene& scene, UDriver *driver=NULL, uint selectedTexture=0)=0;
|
|
virtual void addToSceneAsync (class UScene& scene, UDriver *driver=NULL, uint selectedTexture=0)=0;
|
|
virtual void stopAddToSceneAsync ()=0;
|
|
virtual TState getAddToSceneState ()=0;
|
|
|
|
/**
|
|
* remove this instance group from the given scene
|
|
*/
|
|
virtual void removeFromScene(class UScene& scene)=0;
|
|
|
|
/**
|
|
* This is the static function create a stand alone instance group.
|
|
*/
|
|
static UInstanceGroup *createInstanceGroup (const std::string &instanceGroup);
|
|
static void createInstanceGroupAsync (const std::string &instanceGroup, UInstanceGroup **pIG);
|
|
static void stopCreateInstanceGroupAsync (UInstanceGroup **pIG);
|
|
|
|
|
|
/**
|
|
* Return the count of shape instance in this group.
|
|
*/
|
|
virtual uint getNumInstance () const=0;
|
|
|
|
/**
|
|
* Return the name of the shape refered by an instance of the group.
|
|
*
|
|
* \param instanceNb is the number of the instance.
|
|
* \return the name of the shape.
|
|
*/
|
|
virtual const std::string& getShapeName (uint instanceNb) const=0;
|
|
|
|
/**
|
|
* Return the name of an instance of the group.
|
|
*
|
|
* \param instanceNb is the number of the instance.
|
|
* \return the name of the instance.
|
|
*/
|
|
virtual const std::string& getInstanceName (uint instanceNb) const=0;
|
|
|
|
|
|
/** Return the transformation matrix of an instance in the group
|
|
* NB no pivot is added
|
|
*/
|
|
virtual void getInstanceMatrix(uint instanceNb, NLMISC::CMatrix &dest) const = 0;
|
|
|
|
/**
|
|
* Return the position of an instance of the group.
|
|
*
|
|
* \param instanceNb is the number of the instance.
|
|
* \return the position of the instance.
|
|
*/
|
|
virtual const NLMISC::CVector& getInstancePos (uint instanceNb) const=0;
|
|
|
|
/**
|
|
* Return the rotation of an instance of the group.
|
|
*
|
|
* \param instanceNb is the number of the instance.
|
|
* \return the rotation of the instance.
|
|
*/
|
|
virtual const NLMISC::CQuat& getInstanceRot (uint instanceNb) const=0;
|
|
|
|
/**
|
|
* Return the scale of an instance of the group.
|
|
*
|
|
* \param instanceNb is the number of the instance.
|
|
* \return the scale of the instance.
|
|
*/
|
|
virtual const NLMISC::CVector& getInstanceScale (uint instanceNb) const=0;
|
|
|
|
/**
|
|
* Return an instance of the group. The instance lifeTime is the same of the instangeGroup lifeTime
|
|
*
|
|
* \param instanceNb is the number of the instance.
|
|
*/
|
|
virtual UInstance getInstance (uint instanceNb) const=0;
|
|
|
|
/** get index of instance from its name, or -1 if not found
|
|
* NB: lienar search so this is slow
|
|
*/
|
|
virtual sint getIndexByName(const std::string &name) const = 0;
|
|
|
|
/**
|
|
* Return the instance at a given position (const version)
|
|
*/
|
|
virtual UInstance getByName (const std::string& name) const=0;
|
|
|
|
/**
|
|
* Control a blendshape
|
|
*/
|
|
virtual void setBlendShapeFactor (const std::string &bsName, float rFactor)=0;
|
|
|
|
/**
|
|
* Create the link between scene and instance group before the addToScene
|
|
* to allow the instance group to be moved without being linked to a father
|
|
* cluster system.
|
|
*/
|
|
virtual void createRoot (class UScene &scene)=0;
|
|
|
|
/**
|
|
* All the instances must be checked against the following cluster system
|
|
*/
|
|
virtual void setClusterSystemForInstances (class UInstanceGroup *pClusterSystem)=0;
|
|
|
|
/** Link this ig clusters as sons of clusters of 'ig' that conatains them.
|
|
* \return true if the link succeeded
|
|
*/
|
|
virtual bool linkToParentCluster(UInstanceGroup *father) = 0;
|
|
|
|
/** return the parent cluster system of this IG. NULL if this is the GlobalInstanceGroup.
|
|
* \return true if the link succeeded
|
|
*/
|
|
virtual UInstanceGroup *getParentCluster() const =0;
|
|
|
|
/**
|
|
* Get all dynamic portals in the instance group
|
|
* \return a vector of portal names
|
|
*/
|
|
virtual void getDynamicPortals (std::vector<std::string> &names)=0;
|
|
|
|
/**
|
|
* Set the state of a dynamic portal
|
|
* \param name is the name of the dynamic portal to open or close
|
|
* \param opened is the state the portal will have (true=opened, false=closed)
|
|
*/
|
|
virtual void setDynamicPortal (std::string& name, bool opened)=0;
|
|
|
|
/**
|
|
* Get the state of a dynamic portal
|
|
* \return the state (true=opened, false=closed) of a dynamic portal
|
|
*/
|
|
virtual bool getDynamicPortal (std::string& name)=0;
|
|
|
|
/**
|
|
* Set the position of the instance group
|
|
* Take care if the instance group is a cluster system, you must not move it
|
|
* outside its father cluster which is assigned at addToScene moment.
|
|
*/
|
|
virtual void setPos (const NLMISC::CVector &pos)=0;
|
|
|
|
/**
|
|
* Set the rotation of the instance group
|
|
*/
|
|
virtual void setRotQuat (const NLMISC::CQuat &q)=0;
|
|
|
|
/**
|
|
* Get the position
|
|
*/
|
|
virtual NLMISC::CVector getPos ()=0;
|
|
|
|
/**
|
|
* Get the rotation
|
|
*/
|
|
virtual NLMISC::CQuat getRotQuat ()=0;
|
|
|
|
|
|
/// see UTransform::freezeHRC(). Do it for all instances (not clusters), and for the root of the IG.
|
|
virtual void freezeHRC()=0;
|
|
|
|
/// see UTransform::unfreezeHRC(). Do it for all instances (not clusters), and for the root of the IG.
|
|
virtual void unfreezeHRC()=0;
|
|
|
|
|
|
/// \name PointLight part
|
|
// @{
|
|
|
|
/** get the StaticLightSetup for a model at position localPos/retrieverIdentifier/surfaceId.
|
|
* NB: all are get with help of UGlobalPosition. localPos= gp.LocalPosition.Estimated
|
|
* NB: retrieverIdentifier= globalRetriever->getLocalRetrieverId(gp);
|
|
*/
|
|
virtual bool getStaticLightSetup(NLMISC::CRGBA sunAmbient, uint retrieverIdentifier, sint surfaceId, const NLMISC::CVector &localPos,
|
|
std::vector<CPointLightInfluence> &pointLightList, uint8 &sunContribution, NLMISC::CRGBA &localAmbient) =0;
|
|
|
|
// @}
|
|
|
|
/// \name Distances
|
|
// @{
|
|
// set a dist max for the instance
|
|
virtual void setDistMax(uint instance, float dist) = 0;
|
|
// get the dist max for the instance
|
|
virtual float getDistMax(uint instance) const = 0;
|
|
// Set the coarse mesh dist for the instance (or -1 to keep default)
|
|
virtual void setCoarseMeshDist(uint instance, float dist) = 0;
|
|
// Get the coarse mesh dist (-1 if no coarse mesh or if default dist is used)
|
|
virtual float getCoarseMeshDist(uint instance) const = 0;
|
|
// @}
|
|
|
|
|
|
/// For debug purpose, display clusters as poly/lines. The matrixs and frustum should have been setuped
|
|
virtual void displayDebugClusters(UDriver *drv, class UTextContext *txtCtx) = 0;
|
|
|
|
/** return the DontCastShadowForInterior flag of an instance.
|
|
* Warning: if DontCastShadow=true, and DontCastShadowForInterior=false, false is still returned
|
|
*/
|
|
virtual bool dontCastShadowForInterior(uint instance) const =0;
|
|
|
|
/** return the DontCastShadowForExterior flag of an instance.
|
|
* Warning: if DontCastShadow=true, and DontCastShadowForExterior=false, false is still returned
|
|
*/
|
|
virtual bool dontCastShadowForExterior(uint instance) const =0;
|
|
|
|
};
|
|
|
|
|
|
} // NL3D
|
|
|
|
|
|
#endif // NL_U_INSTANCE_GROUP_H
|
|
|
|
/* End of u_instance_group.h */
|