NL3D::CCamera Class Reference

#include <camera.h>

Inheritance diagram for NL3D::CCamera:

NL3D::CTransform NLMISC::CRefCount NL3D::ITransformable NL3D::IAnimatable

Detailed Description

A Camera node, based on a CTransform node. The camera look in his local Y direction (see CScene).

No special traverse*()

Definition at line 77 of file camera.h.

From Ianimatable.

enum  TAnimValues {
  OwnerBit = CTransform::AnimValueLast, FovValue, TargetValue, RollValue,
  AnimValueLast
}
 Added values. More...

virtual ITrackgetDefaultTrack (uint valueId)
 Default Track Values for are identity (roll= 0, target= CVector::Null, fov=Pi/2).

virtual IAnimatedValuegetValue (uint valueId)
 From IAnimatable.

virtual const char * getValueName (uint valueId) const
 From IAnimatable.

virtual void registerToChannelMixer (CChannelMixer *chanMixer, const std::string &prefix)
 register camera channels (in global anim mode).


Model updating/traversing features

virtual bool clip ()
 clip method called by traverseClip(). deafult is always visible

virtual void initModel ()
virtual void profileRender ()
 Called at RenderTrav to profile current render. no-op per default.

virtual void traverseAnimDetail ()
 call updateWorldMatrixFromFather(), then traverseAnimDetailWithoutUpdateWorldMatrix()

virtual void traverseClip ()
virtual void traverseHrc ()
 Each method is called in its associated traversal.

virtual void traverseLight ()
 traverse the lightedModel per default: recompute LightContribution is isLightable()

virtual void traverseLoadBalancing ()
 no-op by default

virtual void traverseRender ()
 no-op by default


[NOHEADER]

void freezeStaticLightSetup (CPointLight *pointLight[NL3D_MAX_LIGHT_CONTRIBUTION], uint numPointLights, uint8 sunContribution, CPointLight *frozenAmbientlight)
const CLightContributiongetLightContribution () const
virtual void getLightHotSpotInWorld (CVector &modelPos, float &modelRadius) const
bool getUserLightable () const
uint32 isBigLightable () const
uint32 isLightable () const
void resetLighting ()
void setUserLightable (bool enable)
void unfreezeStaticLightSetup ()
bool useMergedPointLight () const

Skinning Behavior.

virtual const std::vector<
NLMISC::CBSphere > * 
getSkinBoneSphere () const
virtual const std::vector<
sint32 > * 
getSkinBoneUsage () const
virtual bool isSkinnable () const
 Deriver must change this method if the model can be skinned. called rarely.

virtual sint renderShadowSkinGeom (uint remainingVertices, uint8 *vbDest)
virtual void renderShadowSkinPrimitives (CMaterial &castMat, IDriver *drv, uint baseVertex)
virtual void renderSkin (float alphaMRM)
virtual sint renderSkinGroupGeom (float alphaMRM, uint remainingVertices, uint8 *dest)
virtual void renderSkinGroupPrimitives (uint baseVertex, std::vector< CSkinSpecularRdrPass > &specularRdrPasses, uint skinIndex)
virtual void renderSkinGroupSpecularRdrPass (uint rdrPass)
 Render a specific specular renderPass returned by renderSkinGroupPrimitives.

virtual void setApplySkin (bool state)
virtual bool supportShadowSkinGrouping () const
 Special Skinning For ShadowMapping.

virtual bool supportSkinGrouping () const
uint _FatherBoneId
CSkeletonModel_FatherSkeletonModel

[NOHEADER]

uint32 isNeedUpdateFrozenStaticLightSetup () const
 non-zero if the object has a FrozenStaticLightSetup not correclty updated.

uint32 isNeedUpdateLighting () const
 non-zero if the object needs to updatelighting.

CLightContribution _LightContribution
 The contribution of all lights. This enlarge the struct only of approx 15%.

CLightingManager::CQGItLightedModel _LightedModelIt
 each transform may be in a quadGird of lighted models (see CLightingManager)


Hrc Traversal

void updateClipTravForAncestorSkeleton ()
void updateWorld ()
 Update the world state according to the parent world state and the local states.

CSkeletonModel_AncestorSkeletonModel
bool _ClipLinkedInSonsOfAncestorSkeletonModelGroup
bool _DontUnfreezeChildren
bool _Frozen
sint64 _LocalDate
CMatrix _LocalMatrix
 Hrc IN variables.

CHrcTrav::TVisibility _LocalVis
sint64 _WorldDate
CMatrix _WorldMatrix
 Hrc OUT variables.

bool _WorldVis

Public Types

enum  TTransformMode { DirectMatrix = 0, RotEuler, RotQuat, TransformModeCount }

Public Member Functions

void build (const CCameraInfo &info)
 Build a camera.

void buildCameraPyramid (std::vector< NLMISC::CPlane > &pyramid, bool useWorldMatrix)
 Build the camera Pyramid from current worldMatrix, and frustum.

bool compareMatrixDate (uint64 callerDate) const
bool enableFovAnimation (bool en, float aspectRatio=4.0f/3.0f)
bool enableTargetAnimation (bool en)
void freeze ()
void freezeHRC ()
virtual void getAABBox (NLMISC::CAABBox &bbox) const
CSkeletonModelgetAncestorSkeletonModel () const
bool getChannelMixerOwnerShip () const
CInstanceGroupgetClusterSystem ()
bool getForceClipRoot () const
void getFrustum (float &left, float &right, float &bottom, float &top, float &znear, float &zfar) const
 Get the camera frustum.

const CFrustumgetFrustum () const
 Get the frustum of the camera.

const CMatrixgetMatrix () const
 Get the matrix, compute her if necessary (work in all modes).

uint64 getMatrixDate () const
uint getOrderingLayer () const
 Get the ordering layer.

CScenegetOwnerScene () const
 get the scene which has created us

const sintgetRefCount () const
CSkeletonModelgetSkeletonModel () const
 Get the skeleton model. Returnr NULL in normal mode.

bool getUserClipping () const
 Return the user clipping state.

CHrcTrav::TVisibility getVisibility ()
 Get the local visibility state.

const CMatrixgetWorldMatrix () const
void heritVisibility ()
 herit the visibility from his father. (default behavior).

void hide ()
 Hide the object and his sons.

bool isClipVisible () const
bool isHrcVisible () const
uint32 isOpaque ()
bool isOrtho () const
 Is a ortho camera?

bool isPerspective () const
 Is a perspective camera?

uint32 isQuadGridClipEnabled () const
uint32 isTransparent ()
void setChannelMixerOwnerShip (bool enable=true)
void setClusterSystem (CInstanceGroup *pCS)
void setDontUnfreezeChildren (bool val)
void setForceClipRoot (bool forceClipRoot)
void setFrustum (float width, float height, float znear, float zfar, bool perspective=true)
 Setup the camera mode as a perspective/ortho camera. NB: znear and zfar must be >0 (if perspective).

void setFrustum (float left, float right, float bottom, float top, float znear, float zfar, bool perspective=true)
 Setup the camera mode as a perspective/ortho camera. NB: znear and zfar must be >0 (if perspective).

void setFrustum (const CFrustum &f)
 Set the frustum of the camera.

void setLogicInfo (ILogicInfo *logicInfo)
void setOpacity (bool v)
void setOrderingLayer (uint layer)
void setPerspective (float fov, float aspectRatio, float znear, float zfar)
void setTransparency (bool v)
void setUserClipping (bool enable)
void setWorldMatrix (const CMatrix &mat)
void show ()
 Show the objet and his sons.

void unfreezeHRC ()
access default tracks.
CTrackDefaultVectorgetDefaultPos ()
CTrackDefaultVectorgetDefaultTargetPos ()
Get / Set some values
Work only if enableTargetAnimation.

float getFov () const
 Work only if enableFovAnimation.

float getRoll () const
 Work only if enableTargetAnimation.

void getTargetPos (CVector &pos) const
 Work only if enableTargetAnimation.

void setFov (float fov)
 Work only if enableFovAnimation.

void setRoll (float roll)
 Work only if enableTargetAnimation.

void setTargetPos (float x, float y, float z)
 Work only if enableTargetAnimation.

void setTargetPos (const CVector &pos)
 Work only if enableFovAnimation.


Static Public Member Functions

const char * getPivotValueName ()
const char * getPosValueName ()
const char * getRotEulerValueName ()
const char * getRotQuatValueName ()
const char * getScaleValueName ()
void registerBasic ()
 Call at the begining of the program, to register the model.

Get some track name
Work only if enableTargetAnimation.

const char * getFovValueName ()
const char * getRollValueName ()
 Return the name of the roll track.

const char * getTargetValueName ()
 Return the name of the target track. This target is in the parent space of camera.


Data Fields

sint crefs
CPtrInfo * pinfo

Static Public Attributes

CPtrInfo NullPtrInfo

Protected Member Functions

sint addValue (CChannelMixer *chanMixer, uint valueId, uint ownerValueId, const std::string &prefix, bool detail)
 CCamera ()
 Constructor.

void clearFlag (uint valueId)
 This method clear a bit in the bitset.

void forceCompute ()
CChannelMixergetChannelMixer () const
bool getShowWhenLODSticked () const
 Test if obj must be displayed when sticked to an object displayed as a LOD (example: sword in hand of a character displayed as a LOD state).

void setFlag (uint valueId)
 This method set a bit in the bitset.

virtual void unlinkFromQuadCluster ()
 special feature for CQuadGridClipManager. called at unfreezeHRC(). Used by CTransformShape.

virtual void update ()
 Implement the update method.

virtual ~CCamera ()
 Destructor.


Protected Attributes

CFrustum _Frustum
uint32 _RenderFilterType

Static Private Member Functions

CTransformcreator ()

Private Attributes

CTrackDefaultVector _DefaultPos
CTrackDefaultVector _DefaultTargetPos
CAnimatedValueFloat _Fov
float _FovAnimationAspectRatio
bool _FovAnimationEnabled
CAnimatedValueFloat _Roll
CAnimatedValueVector _Target
bool _TargetAnimationEnabled

Static Private Attributes

CTrackDefaultFloat DefaultFov
CTrackDefaultFloat DefaultRoll

Friends

struct CPtrInfo


Member Enumeration Documentation

enum NL3D::CCamera::TAnimValues
 

Added values.

Enumeration values:
OwnerBit 
FovValue 
TargetValue 
RollValue 
AnimValueLast 

Reimplemented from NL3D::ITransformable.

Definition at line 194 of file camera.h.

00195         {
00196                 OwnerBit= CTransform::AnimValueLast,
00197                 FovValue ,
00198                 TargetValue,
00199                 RollValue,                      // Roll is the roll angle in radians.
00200 
00201                 AnimValueLast,
00202         };

enum NL3D::ITransformable::TTransformMode [inherited]
 

Enumeration values:
DirectMatrix 
RotEuler 
RotQuat 
TransformModeCount 

Definition at line 58 of file transformable.h.

Referenced by NL3D::ITransformable::getTransformMode().

00059         {
00060                 DirectMatrix=0,         // DirectMatrixMode.
00061                 RotEuler,                       // Matrix is computed from sperated composantes, with euler rotation.
00062                 RotQuat,                        // Matrix is computed from sperated composantes, with quat rotation (default).
00063 
00064                 TransformModeCount
00065         };


Constructor & Destructor Documentation

NL3D::CCamera::CCamera  )  [protected]
 

Constructor.

Definition at line 44 of file camera.cpp.

References _Fov, _FovAnimationAspectRatio, _FovAnimationEnabled, _Roll, _Target, _TargetAnimationEnabled, setFrustum(), NL3D::CAnimatedValueBlendable< T >::Value, and NL3D::CAnimatedValueBlendable< float >::Value.

00045 {
00046         setFrustum(1.0f, 1.0f, 0.01f, 1.0f);
00047 
00048         // IAnimatable.
00049         IAnimatable::resize(AnimValueLast);
00050 
00051         _FovAnimationEnabled= false;
00052         _TargetAnimationEnabled= false;
00053         _FovAnimationAspectRatio= 4.0f/3.0f;
00054 
00055         // Default Anims.
00056         _Fov.Value= (float)NLMISC::Pi/2;
00057         _Target.Value= CVector::Null;
00058         _Roll.Value= 0;
00059 }

virtual NL3D::CCamera::~CCamera  )  [inline, protected, virtual]
 

Destructor.

Definition at line 228 of file camera.h.

00228 {}


Member Function Documentation

sint NL3D::IAnimatable::addValue CChannelMixer chanMixer,
uint  valueId,
uint  ownerValueId,
const std::string &  prefix,
bool  detail
[protected, inherited]
 

This is a tool function which add a given value to a channel.

Returns:
-1 if the track was not found in the animationSet, else it return the channelId as if returned by CAnimationSet::getChannelIdByName(channelName).

Definition at line 37 of file animatable.cpp.

References NL3D::CChannelMixer::addChannel(), NL3D::IAnimatable::getDefaultTrack(), NL3D::IAnimatable::getValue(), NL3D::IAnimatable::getValueName(), nlassert, sint, and uint.

Referenced by NL3D::CTransform::registerToChannelMixer(), NL3D::CParticleSystemModel::registerToChannelMixer(), registerToChannelMixer(), NL3D::CBone::registerToChannelMixer(), NL3D::CAnimatedMorph::registerToChannelMixer(), NL3D::CAnimatedMaterial::registerToChannelMixer(), and NL3D::CAnimatedLightmap::registerToChannelMixer().

00038 {
00039         nlassert(chanMixer);
00040         return chanMixer->addChannel(prefix+getValueName(valueId), this, getValue(valueId), getDefaultTrack(valueId), valueId, ownerValueId, detail);
00041 }

void NL3D::CCamera::build const CCameraInfo info  ) 
 

Build a camera.

Definition at line 196 of file camera.cpp.

References _DefaultPos, _DefaultTargetPos, enableFovAnimation(), enableTargetAnimation(), NL3D::CCameraInfo::Fov, NL3D::CCameraInfo::Pos, NL3D::CCameraInfo::Roll, setFov(), NL3D::ITransformable::setPos(), setRoll(), setTargetPos(), NL3D::ITransformable::setTransformMode(), NL3D::CTrackDefaultBlendable< CVector >::setValue(), NL3D::CCameraInfo::TargetMode, NL3D::CCameraInfo::TargetPos, and NL3D::CCameraInfo::UseFov.

00197 {
00198         // Target ?
00199         enableTargetAnimation(cameraInfo.TargetMode);
00200         enableFovAnimation(cameraInfo.UseFov);
00201         if (cameraInfo.TargetMode)
00202         {
00203                 // Set the rot model
00204                 setTransformMode (ITransformable::RotQuat);
00205                 setTargetPos (cameraInfo.TargetPos);
00206                 _DefaultTargetPos.setValue (cameraInfo.TargetPos);
00207                 setRoll (cameraInfo.Roll);
00208         }
00209         if (cameraInfo.UseFov)
00210         {
00211                 setFov (cameraInfo.Fov);
00212         }
00213         setPos (cameraInfo.Pos);
00214         _DefaultPos.setValue (cameraInfo.Pos);
00215 }

void NL3D::CCamera::buildCameraPyramid std::vector< NLMISC::CPlane > &  pyramid,
bool  useWorldMatrix
 

Build the camera Pyramid from current worldMatrix, and frustum.

Definition at line 243 of file camera.cpp.

References _Frustum, NL3D::CFrustum::Bottom, NL3D::CFrustum::Far, NL3D::ITransformable::getMatrix(), NL3D::CTransform::getWorldMatrix(), NLMISC::CMatrix::invert(), NL3D::CFrustum::Left, NL3D::CFrustum::Near, NL3D::CFrustum::Perspective, NL3D::CFrustum::Right, NL3D::CFrustum::Top, and uint.

Referenced by NL3D::CCameraUser::buildCameraPyramid().

00244 {
00245         pyramid.resize(6);
00246 
00247         // Compute pyramid in view basis.
00248         CVector         pfoc(0,0,0);
00249         CVector         lb(_Frustum.Left,  _Frustum.Near, _Frustum.Bottom );
00250         CVector         lt(_Frustum.Left,  _Frustum.Near, _Frustum.Top    );
00251         CVector         rb(_Frustum.Right, _Frustum.Near, _Frustum.Bottom );
00252         CVector         rt(_Frustum.Right, _Frustum.Near, _Frustum.Top    );
00253         
00254         CVector         lbFar(_Frustum.Left,  _Frustum.Far, _Frustum.Bottom);
00255         CVector         ltFar(_Frustum.Left,  _Frustum.Far, _Frustum.Top   );
00256         CVector         rbFar(_Frustum.Right, _Frustum.Far, _Frustum.Bottom);
00257         CVector         rtFar(_Frustum.Right, _Frustum.Far, _Frustum.Top   );
00258         
00259         // near
00260         pyramid[0].make(lt, lb, rt);
00261         // far
00262         pyramid[1].make(lbFar, ltFar, rtFar);
00263         
00264         if(_Frustum.Perspective)
00265         {
00266                 // left
00267                 pyramid[2].make(pfoc, lt, lb);
00268                 // top
00269                 pyramid[3].make(pfoc, rt, lt);
00270                 // right
00271                 pyramid[4].make(pfoc, rb, rt);
00272                 // bottom
00273                 pyramid[5].make(pfoc, lb, rb);
00274         }
00275         else
00276         {
00277                 // left
00278                 pyramid[2].make(lt, ltFar, lbFar);
00279                 // top
00280                 pyramid[3].make(lt, rtFar, ltFar);
00281                 // right
00282                 pyramid[4].make(rt, rbFar, rtFar);
00283                 // bottom
00284                 pyramid[5].make(lb, lbFar, rbFar);
00285         }
00286         
00287         // get invCamMatrix
00288         CMatrix         invCamMatrix;
00289         if(useWorldMatrix)
00290                 invCamMatrix= getWorldMatrix();
00291         else
00292                 invCamMatrix= getMatrix();
00293         invCamMatrix.invert();
00294 
00295         // Compute pyramid in World basis.
00296         // The vector transformation M of a plane p is computed as p*M-1.
00297         for (uint i = 0; i < 6; i++)
00298         {
00299                 pyramid[i]= pyramid[i]*invCamMatrix;
00300         }
00301 }

bool NL3D::CTransform::canCastShadowMap  )  const [inline, inherited]
 

true if the instance cast shadow. By default false

Definition at line 470 of file transform.h.

References NL3D::CTransform::getStateFlag(), and NL3D::CTransform::IsFinalShadowMapCaster.

Referenced by NL3D::CClipTrav::clipSkeletonShadowMaps(), NL3D::CTransform::enableCastShadowMap(), NL3D::CTransform::setGeneratingShadowMap(), and NL3D::CMeshInstance::traverseRender().

00470 {return getStateFlag(IsFinalShadowMapCaster)!=0;}

bool NL3D::CTransform::canReceiveShadowMap  )  const [inline, inherited]
 

true if the instance receive shadow. By default false

Definition at line 477 of file transform.h.

References NL3D::CTransform::getStateFlag(), and NL3D::CTransform::IsFinalShadowMapReceiver.

Referenced by NL3D::CLandscapeUser::canReceiveShadowMap(), and NL3D::CLandscapeModel::traverseRender().

00477 {return getStateFlag(IsFinalShadowMapReceiver)!=0;}

void NL3D::IAnimatable::clearFlag uint  valueId  )  [inline, protected, inherited]
 

This method clear a bit in the bitset.

Definition at line 233 of file animatable.h.

References NL3D::IAnimatable::_BitSet, and uint.

Referenced by NL3D::ITransformable::clearTransformFlags(), NL3D::CParticleSystemModel::doAnimate(), and NL3D::CAnimatedMaterial::update().

00234         {
00235                 _BitSet&= ~(1<<valueId);
00236         }

virtual bool NL3D::CTransform::clip  )  [inline, virtual, inherited]
 

clip method called by traverseClip(). deafult is always visible

Reimplemented in NL3D::CCluster, NL3D::CLandscapeModel, NL3D::CParticleSystemModel, NL3D::CTransformShape, NL3D::CVegetableBlendLayerModel, and NL3D::CWaterModel.

Definition at line 155 of file transform.h.

Referenced by NL3D::CTransform::traverseClip().

00156         {
00157                 return true;
00158         }

void NL3D::CTransform::clipAddChild CTransform son  )  [inherited]
 

Definition at line 1217 of file transform.cpp.

References NL3D::CTransform::_ClipParents, NL3D::CTransform::_ClipSons, NL3D::CTransform::clipHasParent(), NL3D::CTransform::CClipNode::ClipNode, NL3D::CFastPtrList< CTransform >::insert(), and NL3D::CTransform::CClipNode::Parent.

Referenced by NL3D::CScene::createModel(), NL3D::CSkeletonModel::detachSkeletonSon(), NL3D::CLandscapeModel::initModel(), NL3D::CScene::initQuadGridClipManager(), NL3D::CQuadGridClipClusterListDist::resetSons(), NL3D::CClipTrav::traverse(), and NL3D::CTransform::updateClipTravForAncestorSkeleton().

01218 {
01219         if(!son)
01220                 return;
01221 
01222         // if already linked, no-op.
01223         if(son->clipHasParent(this))
01224                 return;
01225 
01226         // add a new parent entry for our son.
01227         CClipNode       *clipNode= new CClipNode;
01228         son->_ClipParents.push_back(clipNode);
01229 
01230         // link the son to us
01231         clipNode->Parent= this;
01232 
01233         // link us to the son 
01234         _ClipSons.insert(son, &clipNode->ClipNode);
01235 }

void NL3D::CTransform::clipDelChild CTransform son  )  [inherited]
 

Definition at line 1238 of file transform.cpp.

References NL3D::CTransform::clipDelFromParent().

Referenced by NL3D::CScene::initDefaultRoots(), NL3D::CLandscapeModel::initModel(), NL3D::CClipTrav::traverse(), and NL3D::CTransform::~CTransform().

01239 {
01240         if(!son)
01241                 return;
01242 
01243         // try to remove from me from my parent
01244         son->clipDelFromParent(this);
01245 }

CTransform * NL3D::CTransform::clipGetChild uint  index  )  const [inherited]
 

Definition at line 1265 of file transform.cpp.

References NL3D::CTransform::_ClipSons, index, nlassert, NL3D::CFastPtrList< CTransform >::size(), and uint.

Referenced by NL3D::CCluster::recursTraverseClip(), NL3D::CTransform::traverseClip(), NL3D::CRootModel::traverseClip(), NL3D::CParticleSystemModel::traverseClip(), and NL3D::CTransform::~CTransform().

01266 {
01267         nlassert(index < _ClipSons.size());
01268         return (const_cast<CTransform*>(this))->_ClipSons.begin()[index];
01269 }

uint NL3D::CTransform::clipGetNumChildren  )  const [inline, inherited]
 

Definition at line 237 of file transform.h.

References NL3D::CTransform::_ClipSons, NL3D::CFastPtrList< CTransform >::size(), and uint.

Referenced by NL3D::CCluster::recursTraverseClip(), NL3D::CTransform::traverseClip(), NL3D::CRootModel::traverseClip(), NL3D::CParticleSystemModel::traverseClip(), and NL3D::CTransform::~CTransform().

00237 {return _ClipSons.size();}

uint NL3D::CTransform::clipGetNumParents  )  const [inline, inherited]
 

Definition at line 234 of file transform.h.

References NL3D::CTransform::_ClipParents, and uint.

Referenced by NL3D::CTransform::clipUnlinkFromAll(), NL3D::CClipTrav::traverse(), and NL3D::CTransform::updateClipTravForAncestorSkeleton().

00234 {return _ClipParents.size();}

CTransform * NL3D::CTransform::clipGetParent uint  index  )  const [inherited]
 

Definition at line 1258 of file transform.cpp.

References NL3D::CTransform::_ClipParents, index, nlassert, and uint.

Referenced by NL3D::CTransform::clipUnlinkFromAll(), NL3D::CClipTrav::traverse(), and NL3D::CTransform::updateClipTravForAncestorSkeleton().

01259 {
01260         nlassert(index < _ClipParents.size());
01261         return _ClipParents[index]->Parent;
01262 }

void NL3D::CTransform::clipUnlinkFromAll  )  [inherited]
 

Definition at line 1248 of file transform.cpp.

References NL3D::CTransform::clipDelFromParent(), NL3D::CTransform::clipGetNumParents(), and NL3D::CTransform::clipGetParent().

Referenced by NL3D::CSkeletonModel::bindSkin(), NL3D::CScene::initQuadGridClipManager(), NL3D::CTransform::updateClipTravForAncestorSkeleton(), and NL3D::CTransform::~CTransform().

01249 {
01250         // unlink from all parent clip
01251         while( clipGetNumParents() )
01252         {
01253                 clipDelFromParent( clipGetParent(0) );
01254         }
01255 }

bool NL3D::ITransformable::compareMatrixDate uint64  callerDate  )  const [inline, inherited]
 

Tells if the LocalMatrix is newer than what caller except. This return true either if the matrix components (pos/rot etc...) are touched, or if matrix is newer than caller date.

Definition at line 82 of file transformable.h.

References NL3D::ITransformable::_LocalMatrixDate, NL3D::ITransformable::needCompute(), and uint64.

Referenced by NL3D::CWaterModel::updateDiffuseMapMatrix().

00083         {
00084                 return callerDate<_LocalMatrixDate || needCompute();
00085         }

virtual bool NL3D::CTransform::computeWorldBBoxForShadow NLMISC::CAABBox worldBB  )  [inline, virtual, inherited]
 

Special For Skeleton Caster. When Skeletons cast shadows, they first compute the WorldBBox. The model should compute its bbox in World (best fit).

Returns:
false if the model don't support it (default), or if hidden in HRC!!

Reimplemented in NL3D::CMeshInstance, and NL3D::CSkeletonModel.

Definition at line 521 of file transform.h.

Referenced by NL3D::CSkeletonModel::computeWorldBBoxForShadow().

00521 {return false;}

virtual void NL3D::CTransform::createShadowMap  )  [inline, protected, virtual, inherited]
 

To implement for ShadowCaster support. typically allocate a CShadowMap and store NB: the texture doesn't have to be inited at this time. Update it each frame in generateShadowMap()

Reimplemented in NL3D::CMeshInstance, and NL3D::CSkeletonModel.

Definition at line 902 of file transform.h.

Referenced by NL3D::CTransform::enableCastShadowMap().

00902 {}

CTransform* NL3D::CCamera::creator  )  [inline, static, private]
 

Reimplemented from NL3D::CTransform.

Definition at line 239 of file camera.h.

00239 {return new CCamera;}

virtual void NL3D::CTransform::deleteShadowMap  )  [inline, protected, virtual, inherited]
 

To implement for ShadowCaster support. typically free the shadowMap.

Reimplemented in NL3D::CMeshInstance, and NL3D::CSkeletonModel.

Definition at line 904 of file transform.h.

Referenced by NL3D::CTransform::enableCastShadowMap().

00904 {}

void NL3D::CTransform::enableCastShadowMap bool  state  )  [inherited]
 

By default, map shadow casting is disabled. This enabled shadow for this model. Fails if the model don't support dynamic Map Shadow Casting (eg landscape) Dervier note: createShadowMap() and deleteShadowMap() is called here.

Definition at line 1335 of file transform.cpp.

References NL3D::CTransform::canCastShadowMap(), NL3D::CTransform::createShadowMap(), NL3D::CTransform::deleteShadowMap(), NL3D::CTransform::getShadowMap(), NL3D::CTransform::IsFinalShadowMapCaster, NL3D::CTransform::modelCanCastShadowMap(), nlassert, and NL3D::CTransform::setStateFlag().

01336 {
01337         bool    precState= canCastShadowMap();
01338 
01339         if(modelCanCastShadowMap()) 
01340                 setStateFlag(IsFinalShadowMapCaster, state);
01341         else
01342                 setStateFlag(IsFinalShadowMapCaster, false);
01343 
01344         // if just enabled, create the shadowMap
01345         if(canCastShadowMap() && !precState)
01346         {
01347                 createShadowMap();
01348                 // The user must have created it.
01349                 nlassert(getShadowMap());
01350         }
01351         // if just disabled, free ressource
01352         else if(!canCastShadowMap() && precState)
01353         {
01354                 deleteShadowMap();
01355         }
01356 }

bool NL3D::CCamera::enableFovAnimation bool  en,
float  aspectRatio = 4.0f / 3.0f
[inline]
 

enable FOV animation. (default is false). see setPerspective(). znear and zfar are kept from previous setup. NB: as setPerspective(), fov is the full horizontal angle of camera (in radians).

Definition at line 115 of file camera.h.

References _FovAnimationAspectRatio, and _FovAnimationEnabled.

Referenced by build().

00116         {
00117                 _FovAnimationEnabled= en;
00118                 if(en)
00119                         _FovAnimationAspectRatio= aspectRatio;
00120                 return true;
00121         }

void NL3D::CTransform::enableReceiveShadowMap bool  state  )  [inline, inherited]
 

By default, map shadow receiving is disabled. This enabled shadow for this model. Fails if the model don't support dynamic Map Shadow Receiving (eg Particle system)

Definition at line 475 of file transform.h.

References NL3D::CTransform::IsFinalShadowMapReceiver, NL3D::CTransform::modelCanReceiveShadowMap(), and NL3D::CTransform::setStateFlag().

Referenced by NL3D::CLandscapeUser::enableReceiveShadowMap().

00475 {if(modelCanReceiveShadowMap()) setStateFlag(IsFinalShadowMapReceiver, state);}

bool NL3D::CCamera::enableTargetAnimation bool  en  )  [inline]
 

enable Target/Roll animation. (default is false). TTransform mode is forced to RotQuatMode. Roll is forced to 0. The camera builds the rot matrix from the animated target/roll.

Definition at line 125 of file camera.h.

References _Roll, _TargetAnimationEnabled, NL3D::ITransformable::setTransformMode(), and NL3D::CAnimatedValueBlendable< float >::Value.

Referenced by build().

00126         {
00127                 setTransformMode(ITransformable::RotQuat);
00128                 _TargetAnimationEnabled= en;
00129                 _Roll.Value= 0;
00130                 return true;
00131         }

void NL3D::CTransform::forceCompute  )  [protected, inherited]
 

Definition at line 1359 of file transform.cpp.

References NL3D::CTransform::_FatherBoneId, NL3D::CTransform::_FatherSkeletonModel, NL3D::CTransform::_HrcParent, NL3D::CSkeletonModel::forceComputeBone(), NL3D::CTransform::update(), and NL3D::CTransform::updateWorldMatrixFromFather().

Referenced by NL3D::CParticleSystemManager::processAnimate().

01360 {
01361         // if father is a skeleton, force to compute the bone we are sticked to
01362         if (_FatherSkeletonModel)
01363         {
01364                 _FatherSkeletonModel->forceComputeBone(_FatherBoneId);
01365         }
01366         else
01367         {
01368                 // force to compûte the father
01369                 if (_HrcParent)
01370                 {
01371                         _HrcParent->forceCompute();
01372                 }
01373         }
01374         // compute
01375         update();
01376         updateWorldMatrixFromFather();
01377 }

void NL3D::CTransform::freeze  )  [inherited]
 

freeze the preceding position of the model. Do not use, special code for cluster. This inform the scene that preceding position setuped by user is "frozen". ie at next render(), this object won't be added to the "object moving list" (usefull for cluster mgt). The "frozen" state is disabled (at render() time) if:

  • change in position (directly or indireclty, such as animation) is performed after the freeze().
  • the "frozen" state of a father is not enabled (or disabled by a change in position of him :) ).

Definition at line 367 of file transform.cpp.

References NL3D::CTransform::_Frozen, and NL3D::CTransform::update().

Referenced by NL3D::CInstanceGroup::addToSceneWhenAllShapesLoaded(), and NL3D::CScene::initDefaultRoots().

00368 {
00369         // First, update the model
00370         // _Frozen state is disabled here (in CTransform::update()).
00371         update();
00372 
00373         // Then flag the frozen state.
00374         _Frozen= true;
00375 }

void NL3D::CTransform::freezeHRC  )  [inherited]
 

freeze the HRC so the WorldMatrix computed at next render() will be kept for long, and the model won't either be tested in HRC (which is still expensive, even if the worldmatrix doesn't need to be recomputed). The model won't either be validated. It is suposed to not change at all. Also, if it is not a son of a CCluster, it may be accelerated during Cliping (with CQuadGridClipManager).

NB: the model won't be tested in HRC anymore. calling freezeHRC() on a model in a hierarchy without calling it to the root of the hierarchy will result in that the model won't be validated nor be HRC traversed. To be simplier, you should freezeHRC() all the models of a hierarchy, from base root to leaves.

NB: if the hierarchy of this object must change, or if the object must moves, you must call unfreezeHRC() first, and you should do this for all the parents of this model.

Definition at line 385 of file transform.cpp.

References NL3D::CTransform::_FreezeHRCState, NL3D::CTransform::_Frozen, NL3D::CTransform::_TransformDirty, NL3D::CTransform::FreezeHRCStateDisabled, NL3D::CTransform::FreezeHRCStateRequest, NL3D::CTransform::QuadGridClipEnabled, and NL3D::CTransform::setStateFlag().

Referenced by NL3D::CInstanceGroup::freezeHRC().

00386 {
00387         // if disabled, say we are ready to validate our worldMatrix for long.
00388         if(_FreezeHRCState==FreezeHRCStateDisabled)
00389         {
00390                 _FreezeHRCState= FreezeHRCStateRequest;
00391                 setStateFlag(QuadGridClipEnabled, true);
00392 
00393                 /* If the transform is not frozen (ie staticaly inserted in a cluster),
00394                         We must be sure it will be tested against QuadGridClipManager at next ClipTrav pass.
00395                         => must make this object a "moving object" at next render=> dirt _LocalMatrixDate.
00396                 */
00397                 if(!_Frozen)
00398                 {
00399                         _TransformDirty= true;
00400                 }
00401         }
00402 }

void NL3D::CTransform::freezeStaticLightSetup CPointLight pointLight[NL3D_MAX_LIGHT_CONTRIBUTION],
uint  numPointLights,
uint8  sunContribution,
CPointLight frozenAmbientlight
[inherited]
 

Freeze and set the Static Light Setup. Called by CInstanceGroup::addToScene() NB: it calls resetLighting() first. NB: nlassert(numPointLights<=NL3D_MAX_LIGHT_CONTRIBUTION)

Definition at line 1028 of file transform.cpp.

References NL3D::CTransform::_LightContribution, NL3D::CLightContribution::Factor, NL3D::CLightContribution::FrozenAmbientLight, NL3D::CLightContribution::FrozenStaticLightSetup, NL3D::CTransform::IsNeedUpdateFrozenStaticLightSetup, NL3D_MAX_LIGHT_CONTRIBUTION, nlassert, NL3D::CLightContribution::NumFrozenStaticLight, NL3D::CLightContribution::PointLight, NL3D::CTransform::resetLighting(), NL3D::CTransform::setStateFlag(), NL3D::CLightContribution::SunContribution, uint, and uint8.

01030 {
01031         nlassert(numPointLights <= NL3D_MAX_LIGHT_CONTRIBUTION);
01032 
01033         // resetLighting() first.
01034         resetLighting();
01035 
01036         // Enable StaticLightSetup.
01037         _LightContribution.FrozenStaticLightSetup= true;
01038         _LightContribution.NumFrozenStaticLight= numPointLights;
01039         _LightContribution.SunContribution= sunContribution;
01040         // setup the FrozenAmbientLight
01041         _LightContribution.FrozenAmbientLight= frozenAmbientlight;
01042         // Setup other pointLights
01043         uint i;
01044         for(i=0;i<numPointLights;i++)
01045         {
01046                 // set the light
01047                 _LightContribution.PointLight[i]= pointLight[i];
01048                 // Enable at max.
01049                 _LightContribution.Factor[i]= 255;
01050                 // Compute static AttFactor Later because don't have WorlPosition of the model here!!
01051                 setStateFlag(IsNeedUpdateFrozenStaticLightSetup, true);
01052 
01053                 // Do NOT set the iterator, because it is a staticLight.
01054         }
01055         // End the list
01056         if(i<NL3D_MAX_LIGHT_CONTRIBUTION)
01057                 _LightContribution.PointLight[i]= NULL;
01058 }

virtual void NL3D::CTransform::generateShadowMap const CVector lightDir  )  [inline, virtual, inherited]
 

For Casters. Display the Shadow to the "Auxiliary Driver". This method should only write to AlphaBuffer (since RGB may be the current rendered scene!), with Alpha==1 when pixel is shadowed. The ShadowMapManager has already cleared the AlphaBuffer to black, and has already enabled alpha write only. The ShadowMapManager has already setuped Viewport/Scissor as its convenience. The extra blurring is a work of the ShadowMapManager (which blurs multiple shadows in a same pass) NB: you can overwrite the current driver frustum/ViewMatrix/modelMatrix without backuping it (ShadowMapManager work)

Reimplemented in NL3D::CMeshInstance, and NL3D::CSkeletonModel.

Definition at line 492 of file transform.h.

Referenced by NL3D::CShadowMapManager::renderGenerate().

00492 {}

void NL3D::CTransform::getAABBox NLMISC::CAABBox bbox  )  const [virtual, inherited]
 

Get the untransformed AABBox of the transform. NULL (gtCenter()= 0, gtSize()==0) by default.

Reimplemented in NL3D::CParticleSystemModel, and NL3D::CTransformShape.

Definition at line 514 of file transform.cpp.

References NLMISC::CAABBox::setCenter(), and NLMISC::CAABBox::setHalfSize().

Referenced by NL3D::CTransform::traverseLight().

00515 {
00516         bbox.setCenter(CVector::Null);
00517         bbox.setHalfSize(CVector::Null);
00518 }

CSkeletonModel* NL3D::CTransform::getAncestorSkeletonModel  )  const [inline, inherited]
 

Definition at line 207 of file transform.h.

References NL3D::CTransform::_AncestorSkeletonModel.

Referenced by NL3D::CParticleSystemManager::processAnimate().

00207 { return _AncestorSkeletonModel; }

CChannelMixer* NL3D::CTransform::getChannelMixer  )  const [inline, protected, inherited]
 

get the channelMixer owned by the transform. return result of a refPtr => may be NULL.

Definition at line 641 of file transform.h.

Referenced by NL3D::CSkeletonModel::computeCurrentBBox(), NL3D::CMeshBaseInstance::traverseHrc(), and NL3D::CSkeletonModel::updateBoneToCompute().

00641 {return _ChannelMixer;}

bool NL3D::CTransform::getChannelMixerOwnerShip  )  const [inline, inherited]
 

Definition at line 257 of file transform.h.

References NL3D::CTransform::getStateFlag(), and NL3D::CTransform::IsDeleteChannelMixer.

Referenced by NL3D::CTransform::registerToChannelMixer(), and NL3D::CTransform::~CTransform().

00257 { return getStateFlag(IsDeleteChannelMixer)!=0; }

CInstanceGroup* NL3D::CTransform::getClusterSystem  )  [inline, inherited]
 

Definition at line 320 of file transform.h.

References NL3D::CTransform::_ClusterSystem.

Referenced by NL3D::CScene::findCameraClusterSystemFromRay(), and NL3D::CClipTrav::traverse().

00320 { return _ClusterSystem; }

CTrackDefaultVector* NL3D::CCamera::getDefaultPos  )  [inline]
 

Definition at line 217 of file camera.h.

References _DefaultPos.

00217 {return &_DefaultPos;}

CTrackDefaultVector* NL3D::CCamera::getDefaultTargetPos  )  [inline]
 

Definition at line 218 of file camera.h.

References _DefaultTargetPos.

00218 {return &_DefaultTargetPos;}

ITrack * NL3D::CCamera::getDefaultTrack uint  valueId  )  [virtual]
 

Default Track Values for are identity (roll= 0, target= CVector::Null, fov=Pi/2).

Reimplemented from NL3D::CTransform.

Definition at line 137 of file camera.cpp.

References _DefaultPos, _DefaultTargetPos, DefaultFov, DefaultRoll, FovValue, RollValue, TargetValue, and uint.

00138 {
00139         // what value ?
00140         switch (valueId)
00141         {
00142         case PosValue:                  return &_DefaultPos;
00143         case FovValue:                  return &DefaultFov;
00144         case TargetValue:               return &_DefaultTargetPos;
00145         case RollValue:                 return &DefaultRoll;
00146         }
00147 
00148         return CTransform::getDefaultTrack(valueId);
00149 }

bool NL3D::CTransform::getForceClipRoot  )  const [inline, inherited]
 

Definition at line 538 of file transform.h.

References NL3D::CTransform::ForceClipRoot, and NL3D::CTransform::getStateFlag().

Referenced by NL3D::CTransformUser::getForceClipRoot().

00538 { return getStateFlag(ForceClipRoot) != 0; }    

float NL3D::CCamera::getFov  )  const [inline]
 

Work only if enableFovAnimation.

Definition at line 173 of file camera.h.

References _Fov, _FovAnimationEnabled, nlassert, and NL3D::CAnimatedValueBlendable< float >::Value.

00174         {
00175                 nlassert(_FovAnimationEnabled);
00176                 return _Fov.Value;
00177         }

const char* NL3D::CCamera::getFovValueName  )  [inline, static]
 

Return the name of the fov track. NB: as setPerspective(), fov is the full horizontal angle of camera (in radians).

Definition at line 184 of file camera.h.

Referenced by getValueName().

00184 {return "fov";}

void NL3D::CCamera::getFrustum float &  left,
float &  right,
float &  bottom,
float &  top,
float &  znear,
float &  zfar
const
 

Get the camera frustum.

Definition at line 76 of file camera.cpp.

References _Frustum, NL3D::CFrustum::Bottom, NL3D::CFrustum::Far, NL3D::CFrustum::Left, NL3D::CFrustum::Near, NL3D::CFrustum::Right, and NL3D::CFrustum::Top.

00077 {
00078         left= _Frustum.Left;
00079         right= _Frustum.Right;
00080         bottom= _Frustum.Bottom;
00081         top= _Frustum.Top;
00082         znear= _Frustum.Near;
00083         zfar= _Frustum.Far;
00084 }

const CFrustum& NL3D::CCamera::getFrustum  )  const [inline]
 

Get the frustum of the camera.

Definition at line 92 of file camera.h.

References _Frustum.

Referenced by NL3D::CCameraUser::getFrustum(), and NL3D::CCloudScape::render().

00092 {return _Frustum;}

const CLightContribution& NL3D::CTransform::getLightContribution  )  const [inline, inherited]
 

Return the current light contribution of this model

Definition at line 373 of file transform.h.

References NL3D::CTransform::_LightContribution.

Referenced by NL3D::CShadowMapManager::computeShadowColors(), and NL3D::CShadowMapManager::computeShadowDirection().

00373 { return _LightContribution; }  

virtual void NL3D::CTransform::getLightHotSpotInWorld CVector modelPos,
float &  modelRadius
const [inline, virtual, inherited]
 

get the HotSpot of the model for Light computation. For models with global attenuation, this is the point taken for attenuation computes. NB: should return the current world position. NB: return also the modelRadius (only for bigLightable) Default to NULL.

Reimplemented in NL3D::CSkeletonModel, and NL3D::CTransformShape.

Definition at line 381 of file transform.h.

Referenced by NL3D::CLightingManager::computeModelLightContributions().

00381 {modelPos= CVector::Null; modelRadius=0;}

const std::string & NL3D::CTransform::getLoadBalancingGroup  )  const [inherited]
 

Get the load Balancing group of a model. see setLoadBalancingGroup().

Definition at line 532 of file transform.cpp.

References NL3D::CTransform::_LoadBalancingGroup, and NL3D::CLoadBalancingGroup::Name.

00533 {
00534         // get the group name
00535         return _LoadBalancingGroup->Name;
00536 }

const CMatrix& NL3D::ITransformable::getMatrix  )  const [inline, inherited]
 

Get the matrix, compute her if necessary (work in all modes).

Definition at line 76 of file transformable.h.

References NL3D::ITransformable::updateMatrix().

Referenced by NL3D::CInstanceGroup::addToSceneWhenAllShapesLoaded(), buildCameraPyramid(), NL3D::CBone::compute(), NL3D::CWaterShape::createInstance(), NL3D::CWaterModel::getAttenuatedHeight(), NL3D::CTransformableUser::getMatrix(), NL3D::CCloudScape::render(), NL3D::CMeshMultiLod::renderCoarseMesh(), and NL3D::CTransform::update().

00076 {updateMatrix(); return _LocalMatrix;}

uint64 NL3D::ITransformable::getMatrixDate  )  const [inline, inherited]
 

return the last date of computed matrix. updateMatrix() if necessary.

Definition at line 90 of file transformable.h.

References NL3D::ITransformable::_LocalMatrixDate, uint64, and NL3D::ITransformable::updateMatrix().

Referenced by NL3D::CWaterModel::updateDiffuseMapMatrix().

00091         {
00092                 updateMatrix();
00093                 return _LocalMatrixDate;
00094         }

CRGBA NL3D::CTransform::getMeanColor  )  const [inline, inherited]
 

see setMeanColor()

Definition at line 437 of file transform.h.

References NL3D::CTransform::_MeanColor.

00437 {return _MeanColor;}

uint NL3D::CTransform::getOrderingLayer  )  const [inline, inherited]
 

Get the ordering layer.

Definition at line 187 of file transform.h.

References NL3D::CTransform::_OrderingLayer, and uint.

Referenced by NL3D::CTransformUser::getOrderingLayer(), and NL3D::CRenderTrav::traverse().

00187 { return _OrderingLayer; }

CScene* NL3D::CTransform::getOwnerScene  )  const [inline, inherited]
 

get the scene which has created us

Definition at line 105 of file transform.h.

References NL3D::CTransform::_OwnerScene.

Referenced by NL3D::CLandscape::addZone(), NL3D::CWaterModel::clip(), NL3D::CTransformShape::clip(), NL3D::CLandscapeModel::clipAndRenderLandscape(), NL3D::CWaterModel::computeClippedPoly(), NL3D::CSkeletonModel::computeDisplayLodCharacterPriority(), NL3D::CSkeletonModel::computeLodTexture(), NL3D::CWaterModel::computeSimpleClippedPoly(), NL3D::CSkeletonModel::createShadowMap(), NL3D::CMeshInstance::createShadowMap(), NL3D::CSkeletonModel::detachSkeletonSon(), NL3D::CParticleSystemModel::doAnimate(), NL3D::CWaterModel::doSimpleRender(), NL3D::CTargetAnimCtrl::execute(), NL3D::CSkeletonModel::generateShadowMap(), NL3D::CMeshInstance::generateShadowMap(), NL3D::CMeshMultiLodInstance::getCoarseMeshLighting(), NL3D::CTransform::initModel(), NL3D::CSkeletonModel::initModel(), NL3D::CPointLightModel::initModel(), NL3D::CLandscapeModel::initModel(), NL3D::CParticleSystemModel::insertInVisibleList(), NL3D::CMeshMultiLod::instanciateCoarseMeshSpace(), NL3D::CQuadGridClipManager::linkModel(), NL3D::CQuadGridClipManager::profile(), NL3D::CTransformShape::profileRender(), NL3D::CLandscapeModel::receiveShadowMap(), NL3D::CCluster::recursTraverseClip(), NL3D::CMeshBaseInstance::releaseCurrentAsyncTextures(), NL3D::CSegRemanence::render(), NL3D::CMeshMultiLod::render(), NL3D::CMeshMRMSkinnedGeom::render(), NL3D::CMeshMRMGeom::render(), NL3D::CMeshGeom::render(), NL3D::CSkeletonModel::renderCLod(), NL3D::CMeshMultiLod::renderCoarseMesh(), NL3D::CSkeletonModel::renderIntoSkeletonShadowMap(), NL3D::CMeshInstance::renderIntoSkeletonShadowMap(), NL3D::CSkeletonModel::renderShadowSkins(), NL3D::CMeshMRMGeom::renderSkin(), NL3D::CMeshGeom::renderSkin(), NL3D::CMeshMRMSkinnedGeom::renderSkinGroupGeom(), NL3D::CMeshMRMGeom::renderSkinGroupGeom(), NL3D::CMeshMRMSkinnedGeom::renderSkinGroupPrimitives(), NL3D::CMeshMRMGeom::renderSkinGroupPrimitives(), NL3D::CMeshMRMSkinnedGeom::renderSkinGroupSpecularRdrPass(), NL3D::CMeshMRMGeom::renderSkinGroupSpecularRdrPass(), NL3D::CSkeletonModel::renderSkinList(), NL3D::CSkeletonModel::renderSkins(), NL3D::CQuadGridClipManager::reset(), NL3D::CTransform::setLoadBalancingGroup(), NL3D::CSkeletonModel::setLodCharacterShape(), NL3D::CMeshBaseInstance::startAsyncTextureLoading(), NL3D::CWaveMakerModel::traverseAnimDetail(), NL3D::CSkeletonModel::traverseAnimDetail(), NL3D::CSegRemanence::traverseAnimDetail(), NL3D::CParticleSystemModel::traverseAnimDetail(), NL3D::CMeshBaseInstance::traverseAnimDetail(), NL3D::CTransform::traverseAnimDetailWithoutUpdateWorldMatrix(), NL3D::CTransform::traverseClip(), NL3D::CQuadGridClipManager::traverseClip(), NL3D::CParticleSystemModel::traverseClip(), NL3D::CLandscapeModel::traverseClip(), NL3D::CMeshBaseInstance::traverseHrc(), NL3D::CLandscapeModel::traverseHrc(), NL3D::CTransform::traverseLight(), NL3D::CPointLightModel::traverseLight(), NL3D::CTransformShape::traverseLoadBalancing(), NL3D::CMeshMultiLodInstance::traverseLoadBalancing(), NL3D::CTransformShape::traverseLoadBalancingPass0(), NL3D::CWaterModel::traverseRender(), NL3D::CVegetableBlendLayerModel::traverseRender(), NL3D::CTransformShape::traverseRender(), NL3D::CMeshInstance::traverseRender(), NL3D::CLandscapeModel::traverseRender(), NL3D::CFlareModel::traverseRender(), NL3D::CTransform::unfreezeHRC(), NL3D::CTransform::update(), NL3D::CTransform::updateClipTravForAncestorSkeleton(), NL3D::CQuadGridClipManager::updateClustersFromCamera(), NL3D::CSkeletonModel::updateShadowMap(), NL3D::CMeshInstance::updateShadowMap(), NL3D::CTransform::updateWorld(), NL3D::CSkeletonModel::~CSkeletonModel(), and NL3D::CTransform::~CTransform().

00105 {return _OwnerScene;}

CVector NL3D::ITransformable::getPivot  )  [inline, inherited]
 

Work only in Rot* mode (nlassert).

Definition at line 255 of file transformable.h.

References NL3D::ITransformable::_Pivot, nlassert, NL3D::ITransformable::RotEuler, NL3D::ITransformable::RotQuat, and NL3D::CAnimatedValueBlendable< T >::Value.

00256         {
00257                 nlassert(_Mode==RotEuler || _Mode==RotQuat);
00258                 return _Pivot.Value;
00259         }

void NL3D::ITransformable::getPivot CVector pivot  )  [inline, inherited]
 

Work only in Rot* mode (nlassert).

Definition at line 224 of file transformable.h.

References NL3D::ITransformable::_Pivot, nlassert, NL3D::ITransformable::RotEuler, NL3D::ITransformable::RotQuat, and NL3D::CAnimatedValueBlendable< T >::Value.

Referenced by NL3D::CTransformableUser::getPivot().

00225         {
00226                 nlassert(_Mode==RotEuler || _Mode==RotQuat);
00227                 pivot= _Pivot.Value;
00228         }

const char * NL3D::ITransformable::getPivotValueName  )  [static, inherited]
 

Definition at line 117 of file transformable.cpp.

Referenced by NL3D::ITransformable::getValueName().

00118 {
00119         return "pivot";
00120 }

CVector NL3D::ITransformable::getPos void   )  [inline, inherited]
 

Work only in Rot* mode(nlassert).

Definition at line 231 of file transformable.h.

References nlassert, NL3D::ITransformable::RotEuler, NL3D::ITransformable::RotQuat, and NL3D::CAnimatedValueBlendable< T >::Value.

Referenced by NL3D::CSkeletonModel::generateShadowMap(), NL3D::CWaterModel::getHeight(), NL3D::CSkeletonModel::renderIntoSkeletonShadowMap(), NL3D::CMeshInstance::renderIntoSkeletonShadowMap(), and NL3D::CPointLightModel::traverseLight().

00232         {
00233                 nlassert(_Mode==RotEuler || _Mode==RotQuat);
00234                 return _Pos.Value;
00235         }

void NL3D::ITransformable::getPos CVector pos  )  [inline, inherited]
 

Work only in Rot* mode(nlassert).

Definition at line 200 of file transformable.h.

References nlassert, NL3D::ITransformable::RotEuler, NL3D::ITransformable::RotQuat, and NL3D::CAnimatedValueBlendable< T >::Value.

Referenced by NL3D::CTransformableUser::getPos(), NL3D::CInstanceGroup::getPos(), and NL3D::CPSLight::step().

00201         {
00202                 nlassert(_Mode==RotEuler || _Mode==RotQuat);
00203                 pos= _Pos.Value;
00204         }

const char * NL3D::ITransformable::getPosValueName  )  [static, inherited]
 

Definition at line 97 of file transformable.cpp.

Referenced by NL3D::ITransformable::getValueName().

00098 {
00099         return "pos";
00100 }

void NL3D::CTransform::getReceiverBBox CAABBox bbox  )  [virtual, inherited]
 

For receivers. get the World Instance bbox that includes the receiver.

Reimplemented in NL3D::CLandscapeModel.

Definition at line 1328 of file transform.cpp.

References NLMISC::CAABBox::setCenter(), and NLMISC::CAABBox::setHalfSize().

Referenced by NL3D::CShadowMapManager::addShadowReceiver().

01329 {
01330         bbox.setCenter(CVector::Null);
01331         bbox.setHalfSize(CVector::Null);
01332 }

virtual const CMatrix& NL3D::CTransform::getReceiverRenderWorldMatrix  )  const [inline, virtual, inherited]
 

For receivers. Retrieve the WorldMatrix of the model used for IDriver::render(). By default it returns getWorldMatrix(). The exception is the Landscape and his "ZBuffer Problem" management.

Reimplemented in NL3D::CLandscapeModel.

Definition at line 511 of file transform.h.

References NL3D::CTransform::getWorldMatrix().

Referenced by NL3D::CShadowMapManager::renderProject().

00511 {return getWorldMatrix();}

const sint& NLMISC::CRefCount::getRefCount  )  const [inline, inherited]
 

Definition at line 70 of file smart_ptr.h.

References NLMISC::CRefCount::crefs, and sint.

00071         {
00072                 return  crefs;
00073         }

float NL3D::CCamera::getRoll  )  const [inline]
 

Work only if enableTargetAnimation.

Definition at line 167 of file camera.h.

References _Roll, _TargetAnimationEnabled, nlassert, and NL3D::CAnimatedValueBlendable< float >::Value.

00168         {
00169                 nlassert(_TargetAnimationEnabled);
00170                 return _Roll.Value;
00171         }

const char* NL3D::CCamera::getRollValueName  )  [inline, static]
 

Return the name of the roll track.

Definition at line 188 of file camera.h.

Referenced by getValueName().

00188 {return "roll";}

CVector NL3D::ITransformable::getRotEuler  )  [inline, inherited]
 

Work only in RotEuler mode(nlassert).

Definition at line 237 of file transformable.h.

References NL3D::ITransformable::_RotEuler, nlassert, NL3D::ITransformable::RotEuler, and NL3D::CAnimatedValueBlendable< T >::Value.

00238         {
00239                 nlassert(_Mode==RotEuler);
00240                 return _RotEuler.Value;
00241         }

void NL3D::ITransformable::getRotEuler CVector rot  )  [inline, inherited]
 

Work only in RotEuler mode(nlassert).

Definition at line 206 of file transformable.h.

References NL3D::ITransformable::_RotEuler, nlassert, NL3D::ITransformable::RotEuler, and NL3D::CAnimatedValueBlendable< T >::Value.

Referenced by NL3D::CTransformableUser::getRotEuler().

00207         {
00208                 nlassert(_Mode==RotEuler);
00209                 rot= _RotEuler.Value;
00210         }

const char * NL3D::ITransformable::getRotEulerValueName  )  [static, inherited]
 

Definition at line 102 of file transformable.cpp.

Referenced by NL3D::ITransformable::getValueName().

00103 {
00104         return "roteuler";
00105 }

CMatrix::TRotOrder NL3D::ITransformable::getRotOrder  )  [inline, inherited]
 

get the current rotorder (information vlaid only when RotEuler mode).

Definition at line 194 of file transformable.h.

References NL3D::ITransformable::_RotOrder.

Referenced by NL3D::CTransformableUser::getRotOrder().

00195         {
00196                 return _RotOrder;
00197         }

CQuat NL3D::ITransformable::getRotQuat  )  [inline, inherited]
 

Work only in RotQuat mode (nlassert).

Definition at line 243 of file transformable.h.

References NL3D::ITransformable::_RotQuat, nlassert, NL3D::ITransformable::RotQuat, and NL3D::CAnimatedValueBlendable< T >::Value.

00244         {
00245                 nlassert(_Mode==RotQuat);
00246                 return _RotQuat.Value;
00247         }

void NL3D::ITransformable::getRotQuat CQuat quat  )  [inline, inherited]
 

Work only in RotQuat mode (nlassert).

Definition at line 212 of file transformable.h.

References NL3D::ITransformable::_RotQuat, nlassert, NL3D::ITransformable::RotQuat, and NL3D::CAnimatedValueBlendable< T >::Value.

Referenced by NL3D::CTransformableUser::getRotQuat(), and NL3D::CInstanceGroup::getRotQuat().

00213         {
00214                 nlassert(_Mode==RotQuat);
00215                 quat= _RotQuat.Value;
00216         }

const char * NL3D::ITransformable::getRotQuatValueName  )  [static, inherited]
 

Definition at line 107 of file transformable.cpp.

Referenced by NL3D::ITransformable::getValueName().

00108 {
00109         return "rotquat";
00110 }

CVector NL3D::ITransformable::getScale void   )  [inline, inherited]
 

Work only in Rot* mode (nlassert).

Definition at line 249 of file transformable.h.

References nlassert, NL3D::ITransformable::RotEuler, NL3D::ITransformable::RotQuat, and NL3D::CAnimatedValueBlendable< T >::Value.

00250         {
00251                 nlassert(_Mode==RotEuler || _Mode==RotQuat);
00252                 return _Scale.Value;
00253         }

void NL3D::ITransformable::getScale CVector scale  )  [inline, inherited]
 

Work only in Rot* mode (nlassert).

Definition at line 218 of file transformable.h.

References nlassert, NL3D::ITransformable::RotEuler, NL3D::ITransformable::RotQuat, and NL3D::CAnimatedValueBlendable< T >::Value.

Referenced by NL3D::CBone::compute(), and NL3D::CTransformableUser::getScale().

00219         {
00220                 nlassert(_Mode==RotEuler || _Mode==RotQuat);
00221                 scale= _Scale.Value;
00222         }

const char * NL3D::ITransformable::getScaleValueName  )  [static, inherited]
 

Definition at line 112 of file transformable.cpp.

Referenced by NL3D::ITransformable::getValueName().

00113 {
00114         return "scale";
00115 }

virtual CShadowMap* NL3D::CTransform::getShadowMap  )  [inline, virtual, inherited]
 

get The shadow Map result for receveing. If NULL, nothing is displayed.

Reimplemented in NL3D::CMeshInstance, and NL3D::CSkeletonModel.

Definition at line 495 of file transform.h.

Referenced by NL3D::CClipTrav::clipSkeletonShadowMaps(), NL3D::CTransform::enableCastShadowMap(), NL3D::CShadowMapManager::renderGenerate(), NL3D::CShadowMapManager::renderProject(), and NL3D::CShadowMapManager::selectShadowMapsToGenerate().

00495 {return NULL;}

bool NL3D::CTransform::getShowWhenLODSticked  )  const [inline, protected, inherited]
 

Test if obj must be displayed when sticked to an object displayed as a LOD (example: sword in hand of a character displayed as a LOD state).

Definition at line 680 of file transform.h.

References NL3D::CTransform::_ForceCLodSticked.

Referenced by NL3D::CParticleSystemModel::traverseClip().

00680 { return _ForceCLodSticked; }

CSkeletonModel* NL3D::CTransform::getSkeletonModel  )  const [inline, inherited]
 

Get the skeleton model. Returnr NULL in normal mode.

Definition at line 205 of file transform.h.

References NL3D::CTransform::_FatherSkeletonModel.

Referenced by NL3D::CMeshMRMSkinnedGeom::render(), NL3D::CMeshMRMGeom::render(), NL3D::CMeshGeom::render(), NL3D::CMeshMRMSkinnedGeom::renderShadowSkinGeom(), NL3D::CMeshMRMGeom::renderShadowSkinGeom(), NL3D::CMeshMRMGeom::renderSkin(), NL3D::CMeshGeom::renderSkin(), NL3D::CMeshMRMSkinnedGeom::renderSkinGroupGeom(), NL3D::CMeshMRMGeom::renderSkinGroupGeom(), and NL3D::CTransformShape::traverseLoadBalancingPass0().

00205 {return _FatherSkeletonModel;}

virtual const std::vector<NLMISC::CBSphere>* NL3D::CTransform::getSkinBoneSphere  )  const [inline, protected, virtual, inherited]
 

Deriver must change this method if isSkinnable(). It return a list of sphere relative to each bone of the father skeleton. Use with getSkinBoneUsage() to know to wich bone this sphere apply NB: if a sphere radius is -1, it means that the bone is not used (for any reason...) default is to return NULL.

Reimplemented in NL3D::CMeshMRMInstance, and NL3D::CMeshMRMSkinnedInstance.

Definition at line 584 of file transform.h.

Referenced by NL3D::CSkeletonModel::updateSkinRenderLists().

00584 {return NULL;}

virtual const std::vector<sint32>* NL3D::CTransform::getSkinBoneUsage  )  const [inline, protected, virtual, inherited]
 

Deriver must change this method if isSkinnable(). It return the list of bone (correct skeleton index) used by the skins (NB: without the parents of the bone). NB: if an index is -1, it means that the skin bone has not been found in the skeleton (skip it) default is to return NULL.

Reimplemented in NL3D::CMeshInstance, NL3D::CMeshMRMInstance, and NL3D::CMeshMRMSkinnedInstance.

Definition at line 578 of file transform.h.

Referenced by NL3D::CSkeletonModel::computeCLodVertexAlpha(), and NL3D::CSkeletonModel::updateSkinRenderLists().

00578 {return NULL;}

void NL3D::CCamera::getTargetPos CVector pos  )  const [inline]
 

Work only if enableTargetAnimation.

Definition at line 161 of file camera.h.

References _Target, _TargetAnimationEnabled, nlassert, and NL3D::CAnimatedValueBlendable< T >::Value.

00162         {
00163                 nlassert(_TargetAnimationEnabled);
00164                 pos=_Target.Value;
00165         }

const char* NL3D::CCamera::getTargetValueName  )  [inline, static]
 

Return the name of the target track. This target is in the parent space of camera.

Definition at line 186 of file camera.h.

Referenced by getValueName().

00186 {return "target";}

TTransformMode NL3D::ITransformable::getTransformMode  )  [inline, inherited]
 

get the current transform mode.

Definition at line 189 of file transformable.h.

References NL3D::ITransformable::TTransformMode.

Referenced by NL3D::CTargetAnimCtrl::execute(), and NL3D::CTransformableUser::getTransformMode().

00190         {
00191                 return _Mode;
00192         }

bool NL3D::CTransform::getUserClipping  )  const [inherited]
 

Return the user clipping state.

Definition at line 1316 of file transform.cpp.

References NL3D::CTransform::getStateFlag(), and NL3D::CTransform::UserClipping.

Referenced by NL3D::CTransformUser::getUserClipping().

01317 {
01318         return getStateFlag(UserClipping) != 0;
01319 }

bool NL3D::CTransform::getUserLightable  )  const [inline, inherited]
 

Get the UserLightable flag.

Definition at line 347 of file transform.h.

References NL3D::CTransform::getStateFlag(), and NL3D::CTransform::IsUserLightable.

Referenced by NL3D::CTransformUser::getUserLightable().

00347 {return getStateFlag(IsUserLightable)!=0;}

IAnimatedValue * NL3D::CCamera::getValue uint  valueId  )  [virtual]
 

From IAnimatable.

Reimplemented from NL3D::ITransformable.

Definition at line 106 of file camera.cpp.

References _Fov, _Roll, _Target, FovValue, RollValue, TargetValue, and uint.

00107 {
00108         // what value ?
00109         switch (valueId)
00110         {
00111         case FovValue:                  return &_Fov;
00112         case TargetValue:               return &_Target;
00113         case RollValue:                 return &_Roll;
00114         }
00115 
00116         return CTransform::getValue(valueId);
00117 }

const char * NL3D::CCamera::getValueName uint  valueId  )  const [virtual]
 

From IAnimatable.

Reimplemented from NL3D::ITransformable.

Definition at line 119 of file camera.cpp.

References FovValue, getFovValueName(), getRollValueName(), getTargetValueName(), RollValue, TargetValue, and uint.

00120 {
00121         // what value ?
00122         switch (valueId)
00123         {
00124         case FovValue:                  return getFovValueName();
00125         case TargetValue:               return getTargetValueName();
00126         case RollValue:                 return getRollValueName();
00127         }
00128 
00129         return CTransform::getValueName(valueId);
00130 }

CHrcTrav::TVisibility NL3D::CTransform::getVisibility  )  [inline, inherited]
 

Get the local visibility state.

Definition at line 203 of file transform.h.

References NL3D::CTransform::Visibility.

Referenced by NL3D::CTransformUser::getVisibility(), NL3D::CParticleSystemManager::processAnimate(), NL3D::CMeshMRMSkinnedInstance::renderSkin(), NL3D::CMeshMRMInstance::renderSkin(), NL3D::CMeshInstance::renderSkin(), NL3D::CParticleSystemModel::traverseAnimDetail(), and NL3D::CSkeletonModel::updateSkinRenderLists().

00203 {return Visibility;}

const CMatrix& NL3D::CTransform::getWorldMatrix  )  const [inline, inherited]
 

Get the worldMatrix that is computed at last Hrc pass

Definition at line 299 of file transform.h.

Referenced by NL3D::CMeshMRMGeom::activeInstance(), NL3D::CMeshGeom::activeInstance(), NL3D::CLightingManager::addDynamicLight(), buildCameraPyramid(), NL3D::CParticleSystemModel::checkAgainstPyramid(), NL3D::CTransformShape::clip(), NL3D::CClipTrav::clipSkeletonShadowMaps(), NL3D::CWaterModel::computeClippedPoly(), NL3D::CSkeletonModel::computeDisplayLodCharacterPriority(), NL3D::CShadowMapManager::computeShadowDirection(), NL3D::CWaterModel::computeSimpleClippedPoly(), NL3D::CMeshInstance::computeWorldBBoxForShadow(), NL3D::CParticleSystemModel::doAnimate(), NL3D::CWaterModel::doSimpleRender(), NL3D::CTargetAnimCtrl::execute(), NL3D::CSkeletonModel::generateShadowMap(), NL3D::CMeshInstance::generateShadowMap(), NL3D::CTransformShape::getLightHotSpotInWorld(), NL3D::CTransform::getReceiverRenderWorldMatrix(), NL3D::CLightingManager::insertStaticLightedModel(), NL3D::CQuadGridClipManager::linkModel(), NL3D::CParticleSystemManager::processAnimate(), NL3D::CParticleSystemModel::refreshRscDeletion(), NL3D::CParticleSystemShape::render(), NL3D::CMeshMRMSkinnedGeom::render(), NL3D::CMeshMRMGeom::render(), NL3D::CMeshGeom::render(), NL3D::CSkeletonModel::renderCLod(), NL3D::CSkeletonModel::renderIntoSkeletonShadowMap(), NL3D::CMeshInstance::renderIntoSkeletonShadowMap(), NL3D::CMeshMultiLod::renderMeshGeom(), NL3D::CShadowMapManager::renderProject(), NL3D::CMeshMRMGeom::renderSkin(), NL3D::CMeshGeom::renderSkin(), NL3D::CSkeletonModel::renderSkins(), NL3D::CSegRemanence::samplePos(), NL3D::CShadowMapManager::selectShadowMapsToGenerate(), NL3D::CMeshVPWindTree::setupPerInstanceConstants(), NL3D::CRenderTrav::traverse(), NL3D::CClipTrav::traverse(), NL3D::CWaveMakerModel::traverseAnimDetail(), NL3D::CSkeletonModel::traverseAnimDetail(), NL3D::CParticleSystemModel::traverseClip(), NL3D::CTransform::traverseLight(), NL3D::CPointLightModel::traverseLight(), NL3D::CTransformShape::traverseLoadBalancingPass0(), NL3D::CWaterModel::traverseRender(), NL3D::CFlareModel::traverseRender(), and NL3D::CWaterModel::updateDiffuseMapMatrix().

00299 {return _WorldMatrix;}

void NL3D::CTransform::heritVisibility  )  [inherited]
 

herit the visibility from his father. (default behavior).

Definition at line 287 of file transform.cpp.

References NL3D::CTransform::_FatherSkeletonModel, NL3D::CTransform::_TransformDirty, NL3D::CSkeletonModel::dirtSkinRenderLists(), NL3D::CTransform::isSkinned(), nlassert, and NL3D::CTransform::Visibility.

Referenced by NL3D::CTransformUser::heritVisibility().

00288 {
00289         // Optim: do nothing if already set
00290         if(Visibility!= CHrcTrav::Herit)
00291         {
00292                 _TransformDirty= true;
00293                 Visibility= CHrcTrav::Herit;
00294                 // If skinned, then must inform skeleton parent that it must recompute skin render/animDetail lists
00295                 if(isSkinned())
00296                 {
00297                         nlassert(_FatherSkeletonModel);
00298                         _FatherSkeletonModel->dirtSkinRenderLists();
00299                 }
00300         }
00301 }

void NL3D::CTransform::hide  )  [inherited]
 

Hide the object and his sons.

Definition at line 223 of file transform.cpp.

References NL3D::CTransform::_FatherSkeletonModel, NL3D::CTransform::_TransformDirty, NL3D::CSkeletonModel::dirtSkinRenderLists(), NL3D::CTransform::isSkinned(), nlassert, and NL3D::CTransform::Visibility.

Referenced by NL3D::CTransformUser::hide(), NL3D::CLandscapeUser::hide(), NL3D::CPSMesh::newElement(), and NL3D::CPSMesh::updatePos().

00224 {
00225         // Optim: do nothing if already set
00226         if(Visibility!= CHrcTrav::Hide)
00227         {
00228                 _TransformDirty= true;
00229                 Visibility= CHrcTrav::Hide;
00230                 // If skinned, then must inform skeleton parent that it must recompute skin render/animDetail lists
00231                 if(isSkinned())
00232                 {
00233                         nlassert(_FatherSkeletonModel);
00234                         _FatherSkeletonModel->dirtSkinRenderLists();
00235                 }
00236         }
00237 }

CTransform * NL3D::CTransform::hrcGetChild uint  index  )  const [inherited]
 

Definition at line 1202 of file transform.cpp.

References NL3D::CTransform::_HrcSons, index, nlassert, NL3D::CFastPtrList< CTransform >::size(), and uint.

Referenced by NL3D::CTransform::traverseHrc(), NL3D::CRootModel::traverseHrc(), NL3D::CAnimDetailTrav::traverseHrcRecurs(), and NL3D::CTransform::~CTransform().

01203 {
01204         nlassert(index < _HrcSons.size());
01205         return (const_cast<CTransform*>(this))->_HrcSons.begin()[index];
01206 }

uint NL3D::CTransform::hrcGetNumChildren  )  const [inline, inherited]
 

Definition at line 220 of file transform.h.

References NL3D::CTransform::_HrcSons, NL3D::CFastPtrList< CTransform >::size(), and uint.

Referenced by NL3D::CTransform::traverseHrc(), NL3D::CRootModel::traverseHrc(), NL3D::CAnimDetailTrav::traverseHrcRecurs(), and NL3D::CTransform::~CTransform().

00220 {return _HrcSons.size();}

CTransform* NL3D::CTransform::hrcGetParent  )  const [inline, inherited]
 

Definition at line 218 of file transform.h.

References NL3D::CTransform::_HrcParent.

Referenced by NL3D::CMeshBaseInstance::traverseHrc(), and NL3D::CTransform::updateWorldMatrixFromFather().

00218 {return _HrcParent;}

void NL3D::CTransform::hrcLinkSon CTransform son  )  [inherited]
 

link son to this in Hierarchy traversal NB: link does nothing if the son node is HRC frozen

Definition at line 1151 of file transform.cpp.

References NL3D::CTransform::_FreezeHRCState, NL3D::CTransform::_HrcNode, NL3D::CTransform::_HrcParent, NL3D::CTransform::_HrcParentUnfreeze, NL3D::CTransform::_HrcSons, NL3D::CTransform::_WorldDate, NL3D::CTransform::hrcUnlink(), and NL3D::CFastPtrList< CTransform >::insert().

Referenced by NL3D::CInstanceGroup::addToSceneWhenAllShapesLoaded(), NL3D::CScene::createModel(), NL3D::CSkeletonModel::detachSkeletonSon(), NL3D::CInstanceGroup::linkRoot(), NL3D::CTransform::setForceClipRoot(), NL3D::CSkeletonModel::stickObjectEx(), and NL3D::CTransform::unfreezeHRC().

01152 {
01153         if(!son)
01154                 return;
01155 
01156         // If not unfrozen, can't link
01157         if (son->_FreezeHRCState != CTransform::FreezeHRCStateDisabled)
01158                 return;
01159 
01160         // no-op if already me.
01161         if(son->_HrcParent==this)
01162                 return;
01163 
01164         // unlink from anyone
01165         son->hrcUnlink();
01166 
01167         // link son to me
01168         _HrcSons.insert(son, &son->_HrcNode);
01169         
01170         // link me to son
01171         son->_HrcParent= this;
01172         
01173         // Backup parent
01174         son->_HrcParentUnfreeze= this;
01175         
01176         // my son should recompute his worldMatrix!
01177         son->_WorldDate= -1;
01178 }

void NL3D::CTransform::hrcUnlink  )  [inherited]
 

unlink this from any Father in Hrc. No-op if no parent NB: unlink does nothing if the node is HRC frozen

Definition at line 1181 of file transform.cpp.

References NL3D::CTransform::_HrcNode, NL3D::CTransform::_HrcParent, NL3D::CTransform::_HrcParentUnfreeze, NL3D::CTransform::_WorldDate, NL3D::CTransform::ForceClipRoot, NL3D::CTransform::getStateFlag(), nlassert, and NL3D::CFastPtrListNode::unlink().

Referenced by NL3D::CSkeletonModel::bindSkin(), NL3D::CTransform::hrcLinkSon(), NL3D::CScene::initDefaultRoots(), NL3D::CScene::initQuadGridClipManager(), NL3D::CTransform::setForceClipRoot(), NL3D::CTransform::update(), and NL3D::CTransform::~CTransform().

01182 {
01183         // no-op if already NULL
01184         if(_HrcParent==NULL)
01185                 return;
01186 
01187         // if ForceClipRoot flag is set, then the fx can't be linked elsewhere in the hierarchy
01188         nlassert(!getStateFlag(ForceClipRoot));
01189 
01190         // unlink my parent from me.
01191         _HrcNode.unlink();
01192 
01193         // unlink me from parent
01194         _HrcParent= NULL;
01195         _HrcParentUnfreeze= NULL;
01196 
01197         // I should recompute my worldMatrix (well not usefull since not linked, but still do it...)
01198         _WorldDate= -1;
01199 }

void NL3D::CTransform::initModel  )  [virtual, inherited]
 

Extra init for a model. this method is called by the framework at the very end of CScene::createModel() Warning! if the model is a CTransformShape, then when initModel() is called, Shape and other related member/setup of IShape::createInstance() are not yet done (because createModel() is called at the begining in createInstance()).

Because initModel() is called at the very end, deriver could implement anything like creating other models, but not deleting this model...

Default behavior is to do nothing.

Reimplemented in NL3D::CLandscapeModel, NL3D::CPointLightModel, and NL3D::CSkeletonModel.

Definition at line 214 of file transform.cpp.

References NL3D::CTransform::_LoadBalancingGroup, NL3D::CLoadBalancingTrav::getDefaultGroup(), NL3D::CScene::getLoadBalancingTrav(), and NL3D::CTransform::getOwnerScene().

Referenced by NL3D::CScene::createModel().

00215 {
00216         // assign me to the default group
00217         _LoadBalancingGroup= getOwnerScene()->getLoadBalancingTrav().getDefaultGroup();
00218 }

uint32 NL3D::CTransform::isAnimDetailable  )  const [inline, inherited]
 

non-zero if the model is animDetailable (ie added to the animDetail list if visible)

Definition at line 440 of file transform.h.

References NL3D::CTransform::getStateFlag(), NL3D::CTransform::IsAnimDetailable, and uint32.

Referenced by NL3D::CClipTrav::clipSkeletonShadowMaps(), NL3D::CTransform::traverseClip(), and NL3D::CSkeletonModel::updateSkinRenderLists().

00440 {return getStateFlag(IsAnimDetailable);}

uint32 NL3D::CTransform::isBigLightable  )  const [inline, inherited]
 

non-zero if the lighting Manager must take into account the bbox of the transform. Default behavior is false. Deriver must call setIsBigLightable() at initialisation to change it.

Definition at line 365 of file transform.h.

References NL3D::CTransform::getStateFlag(), NL3D::CTransform::IsBigLightable, and uint32.

Referenced by NL3D::CTransformShape::getLightHotSpotInWorld().

00365 {return getStateFlag(IsBigLightable);}

bool NL3D::CTransform::isClipVisible  )  const [inline, inherited]
 

tells if the transform has been clipped in the clip traversal.

Definition at line 313 of file transform.h.

References NL3D::CTransform::_Visible.

Referenced by NL3D::CClipTrav::clipSkeletonShadowMaps(), NL3D::CSkeletonModel::computeDisplayLodCharacterPriority(), NL3D::CSkeletonModel::computeRenderedBBox(), NL3D::CTransformUser::getLastClippedState(), NL3D::CSkeletonModel::isBoneComputed(), NL3D::CParticleSystemManager::processAnimate(), NL3D::CTransform::traverseClip(), NL3D::CParticleSystemModel::traverseClip(), and NL3D::CPointLightModel::traverseLight().

00314         {
00315                 return _Visible;
00316         }

uint32 NL3D::CTransform::isCluster  )  const [inline, inherited]
 

non-zero if the CTransform can be casted to a CCluster

Definition at line 451 of file transform.h.

References NL3D::CTransform::getStateFlag(), NL3D::CTransform::IsCluster, and uint32.

Referenced by NL3D::CClipTrav::traverse().

00451 {return getStateFlag(IsCluster);}

bool NL3D::CTransform::isGeneratingShadowMap  )  const [inline, inherited]
 

true if the instance cast shadow. By default false

Definition at line 515 of file transform.h.

References NL3D::CTransform::getStateFlag(), and NL3D::CTransform::IsGeneratingShadowMap.

Referenced by NL3D::CClipTrav::clipSkeletonShadowMaps(), and NL3D::CSkeletonModel::traverseAnimDetail().

00515 {return getStateFlag(IsGeneratingShadowMap)!=0;}

bool NL3D::CTransform::isHrcVisible  )  const [inline, inherited]
 

tells if the transform has been determined as visible in the hrc traversal

Reimplemented in NL3D::CPointLightModel.

Definition at line 306 of file transform.h.

References NL3D::CTransform::_WorldVis.

Referenced by NL3D::CClipTrav::clipSkeletonShadowMaps(), NL3D::CSkeletonModel::computeWorldBBoxForShadow(), NL3D::CMeshInstance::computeWorldBBoxForShadow(), NL3D::CTransformUser::getLastWorldVisState(), NL3D::CSkeletonModel::renderIntoSkeletonShadowMap(), NL3D::CMeshInstance::renderIntoSkeletonShadowMap(), and NL3D::CSkeletonModel::traverseAnimDetail().

00307         {
00308                 return _WorldVis;
00309         }

uint32 NL3D::CTransform::isLightable  )  const [inline, inherited]
 

true if the model can be lighted (such as CMeshBaseInstance) Default behavior is false. Deriver must use setIsLightable(true) method if the instance can be lighted.

Returns:
0 if getUserLightable() is false, or if the model can't be lighted at all. else return a non-zero value

Definition at line 337 of file transform.h.

References NL3D::CTransform::getStateFlag(), NL3D::CTransform::IsFinalLightable, and uint32.

Referenced by NL3D::CClipTrav::clipSkeletonShadowMaps(), NL3D::CTransform::traverseClip(), NL3D::CTransformShape::traverseRender(), NL3D::CTransform::unfreezeHRC(), NL3D::CTransform::update(), and NL3D::CTransform::updateWorld().

00337 {return getStateFlag(IsFinalLightable);}

uint32 NL3D::CTransform::isLoadBalancable  )  const [inline, inherited]
 

non-zero if the model is loadBalancable (ie added to the loadBalancing list if visible)

Definition at line 442 of file transform.h.

References NL3D::CTransform::getStateFlag(), NL3D::CTransform::IsLoadBalancable, and uint32.

Referenced by NL3D::CTransform::traverseClip().

00442 {return getStateFlag(IsLoadBalancable);}

uint32 NL3D::CTransform::isMeshBaseInstance  )  const [inline, inherited]
 

non-zero if the CTransform can be casted to a CMeshBaseInstance

Definition at line 447 of file transform.h.

References NL3D::CTransform::getStateFlag(), NL3D::CTransform::IsMeshBaseInstance, and uint32.

Referenced by NL3D::CInstanceUser::enableAsyncTextureMode(), NL3D::CInstanceUser::getAsyncTextureDistance(), NL3D::CInstanceUser::getAsyncTextureMode(), NL3D::CInstanceUser::isAsyncTextureDirty(), NL3D::CInstanceUser::isAsyncTextureReady(), NL3D::CInstanceUser::setAsyncTextureDirty(), NL3D::CInstanceUser::setAsyncTextureDistance(), and NL3D::CInstanceUser::startAsyncTextureLoading().

00447 {return getStateFlag(IsMeshBaseInstance);}

uint32 NL3D::CTransform::isNeedUpdateFrozenStaticLightSetup  )  const [inline, protected, inherited]
 

non-zero if the object has a FrozenStaticLightSetup not correclty updated.

Definition at line 631 of file transform.h.

References NL3D::CTransform::getStateFlag(), NL3D::CTransform::IsNeedUpdateFrozenStaticLightSetup, and uint32.

Referenced by NL3D::CTransform::traverseLight().

00631 {return getStateFlag(IsNeedUpdateFrozenStaticLightSetup);}

uint32 NL3D::CTransform::isNeedUpdateLighting  )  const [inline, protected, inherited]
 

non-zero if the object needs to updatelighting.

Definition at line 629 of file transform.h.

References NL3D::CTransform::getStateFlag(), NL3D::CTransform::IsNeedUpdateLighting, and uint32.

Referenced by NL3D::CTransform::resetLighting(), and NL3D::CTransform::traverseLight().

00629 {return getStateFlag(IsNeedUpdateLighting);}

uint32 NL3D::CTransform::isOpaque  )  [inline, inherited]
 

Definition at line 173 of file transform.h.

References NL3D::CTransform::getStateFlag(), and uint32.

Referenced by NL3D::CTransformUser::isOpaque(), NL3D::CRenderTrav::traverse(), and NL3D::CSkeletonModel::updateSkinRenderLists().

00173 { return getStateFlag(IsOpaque); }

bool NL3D::CCamera::isOrtho  )  const
 

Is a ortho camera?

Definition at line 86 of file camera.cpp.

References _Frustum, and NL3D::CFrustum::Perspective.

Referenced by NL3D::CCameraUser::isOrtho().

00087 {
00088         return !_Frustum.Perspective;
00089 }

bool NL3D::CCamera::isPerspective  )  const
 

Is a perspective camera?

Definition at line 91 of file camera.cpp.

References _Frustum, and NL3D::CFrustum::Perspective.

Referenced by NL3D::CCameraUser::isPerspective().

00092 {
00093         return _Frustum.Perspective;
00094 }

uint32 NL3D::CTransform::isQuadGridClipEnabled  )  const [inline, inherited]
 

special feature for CQuadGridClipManager. return a non-zero value if true

Definition at line 294 of file transform.h.

References NL3D::CTransform::getStateFlag(), NL3D::CTransform::QuadGridClipEnabled, and uint32.

Referenced by NL3D::CClipTrav::traverse().

00294 {return getStateFlag(QuadGridClipEnabled);}

uint32 NL3D::CTransform::isRenderable  )  const [inline, inherited]
 

non-zero if the model is renderable (ie something may appear on screen)

Definition at line 444 of file transform.h.

References NL3D::CTransform::getStateFlag(), NL3D::CTransform::IsRenderable, and uint32.

Referenced by NL3D::CTransform::traverseClip().

00444 {return getStateFlag(IsRenderable);}

uint32 NL3D::CTransform::isSkeleton  )  const [inline, inherited]
 

return non-zero if I am a skeleton. if yes, static_cast<CSkeletonModel*> may be used

Definition at line 421 of file transform.h.

References NL3D::CTransform::getStateFlag(), NL3D::CTransform::IsSkeleton, and uint32.

Referenced by NL3D::CSkeletonModel::forceComputeBone(), and NL3D::CAnimDetailTrav::traverse().

00421 {return getStateFlag(IsSkeleton);}

virtual bool NL3D::CTransform::isSkinnable  )  const [inline, protected, virtual, inherited]
 

Deriver must change this method if the model can be skinned. called rarely.

Reimplemented in NL3D::CMeshInstance, NL3D::CMeshMRMInstance, and NL3D::CMeshMRMSkinnedInstance.

Definition at line 567 of file transform.h.

Referenced by NL3D::CSkeletonModel::bindSkin().

00567 {return false;}

uint32 NL3D::CTransform::isSkinned  )  const [inline, inherited]
 

non-zero if the model is skinned onto a skeleton.

Definition at line 423 of file transform.h.

References NL3D::CTransform::getStateFlag(), NL3D::CTransform::IsSkinned, and uint32.

Referenced by NL3D::CSkeletonModel::detachSkeletonSon(), NL3D::CTransform::heritVisibility(), NL3D::CTransform::hide(), NL3D::CTransform::registerToChannelMixer(), NL3D::CMeshMRMSkinnedGeom::render(), NL3D::CMeshMRMGeom::render(), NL3D::CMeshGeom::render(), NL3D::CMeshMRMGeom::renderSkin(), NL3D::CMeshGeom::renderSkin(), NL3D::CMeshMRMSkinnedGeom::renderSkinGroupGeom(), NL3D::CMeshMRMGeom::renderSkinGroupGeom(), NL3D::CTransform::setIsForceAnimDetail(), NL3D::CTransform::setOpacity(), NL3D::CTransform::setTransparency(), NL3D::CTransform::show(), NL3D::CTransform::updateWorldMatrixFromFather(), and NL3D::CTransform::~CTransform().

00423 {return getStateFlag(IsSkinned);}

uint32 NL3D::IAnimatable::isTouched uint  valueId  )  const [inline, inherited]
 

Return non 0 int if the value as been touched else 0.

Parameters:
valueId is the animated value ID in the object we want to test the touch flag. or it may be an OwnerBit.

Definition at line 184 of file animatable.h.

References NL3D::IAnimatable::_BitSet, uint, and uint32.

Referenced by NL3D::CParticleSystemModel::doAnimate(), NL3D::ITransformable::needCompute(), NL3D::IAnimatable::propagateTouch(), and NL3D::CAnimatedMaterial::update().

00185         {
00186                 return _BitSet&(1<<valueId);
00187         }

uint32 NL3D::CTransform::isTransformShape  )  const [inline, inherited]
 

non-zero if the CTransform can be casted to a CTransformShape

Definition at line 449 of file transform.h.

References NL3D::CTransform::getStateFlag(), NL3D::CTransform::IsTransformShape, and uint32.

Referenced by NL3D::CTransform::updateWorld().

00449 {return getStateFlag(IsTransformShape);}

uint32 NL3D::CTransform::isTransparent  )  [inline, inherited]
 

Definition at line 174 of file transform.h.

References NL3D::CTransform::getStateFlag(), and uint32.

Referenced by NL3D::CTransformUser::isTransparent(), NL3D::CRenderTrav::traverse(), and NL3D::CSkeletonModel::updateSkinRenderLists().

00174 { return getStateFlag(IsTransparent); }

void NL3D::ITransformable::lookAt const CVector eye,
const CVector target,
float  roll = 0.f
[inherited]
 

Setup Matrix by the lookAt method. Work only in DirectMatrix mode and RotQuat mode (not euler...).

Parameters:
eye is the coordinate of the object.
target is the point the object look at.
roll is the roll angle in radian along the object's Y axis.

Definition at line 169 of file transformable.cpp.

References NL3D::ITransformable::DirectMatrix, NLMISC::CMatrix::getPos(), NLMISC::CMatrix::getRot(), NLMISC::CMatrix::identity(), nlassert, NLMISC::CVector::normalize(), NLMISC::CMatrix::rotateY(), NL3D::ITransformable::RotQuat, NL3D::ITransformable::setMatrix(), NL3D::ITransformable::setPivot(), NL3D::ITransformable::setPos(), NLMISC::CMatrix::setPos(), NLMISC::CMatrix::setRot(), NL3D::ITransformable::setRotQuat(), and NL3D::ITransformable::setScale().

Referenced by NL3D::CTransformableUser::lookAt(), and update().

00170 {
00171         nlassert(_Mode==RotQuat || _Mode==DirectMatrix);
00172 
00173         // Roll matrix
00174         CMatrix rollMT;
00175         rollMT.identity();
00176         if (roll!=0.f)
00177                 rollMT.rotateY (roll);
00178 
00179         // Make the target base
00180         CVector j=target;
00181         j-=eye;
00182         j.normalize();
00183         CVector i=j^CVector (0,0,1.f);
00184         CVector k=i^j;
00185         k.normalize();
00186         i=j^k;
00187         i.normalize();
00188 
00189         // Make the target matrix
00190         CMatrix targetMT;
00191         targetMT.identity();
00192         targetMT.setRot (i, j, k);
00193         targetMT.setPos (eye);
00194 
00195         // Compose matrix
00196         targetMT*=rollMT;
00197 
00198         // Set the matrix
00199         if(_Mode==DirectMatrix)
00200                 setMatrix (targetMT);
00201         else
00202         {
00203                 // transfrom to quaternion mode.
00204                 setScale(CVector(1,1,1));
00205                 setPivot(CVector::Null);
00206                 setPos(targetMT.getPos());
00207                 setRotQuat(targetMT.getRot());
00208         }
00209 }

uint32 NL3D::CTransform::modelCanCastShadowMap  )  const [inline, inherited]
 

true if the model provide a method to support shadowMap generation

Definition at line 480 of file transform.h.

References NL3D::CTransform::getStateFlag(), NL3D::CTransform::IsShadowMapCaster, and uint32.

Referenced by NL3D::CTransform::enableCastShadowMap().

00480 {return getStateFlag(IsShadowMapCaster);}

uint32 NL3D::CTransform::modelCanReceiveShadowMap  )  const [inline, inherited]
 

true if the model provide a method to support shadowMap receiving

Definition at line 482 of file transform.h.

References NL3D::CTransform::getStateFlag(), NL3D::CTransform::IsShadowMapReceiver, and uint32.

Referenced by NL3D::CTransform::enableReceiveShadowMap().

00482 {return getStateFlag(IsShadowMapReceiver);}

void NL3D::CTransform::profileRender  )  [virtual, inherited]
 

Called at RenderTrav to profile current render. no-op per default.

Reimplemented in NL3D::CLandscapeModel, NL3D::CQuadGridClipManager, and NL3D::CTransformShape.

Definition at line 1137 of file transform.cpp.

Referenced by NL3D::CRenderTrav::traverse().

01138 {
01139         // no-op
01140 }

virtual void NL3D::CTransform::receiveShadowMap CShadowMap shadowMap,
const CVector casterPos,
const CMaterial shadowMat
[inline, virtual, inherited]
 

For receivers. Modulate the Object with a ShadowMap. The model shoud render in the scene driver a version of its geometry simplified, and modulate the background with shadowColor.

Parameters:
casterPos the world position of the caster model.
shadowMat a correclty setuped material with good ShadowColor, ready to be rendered.

Reimplemented in NL3D::CLandscapeModel.

Definition at line 506 of file transform.h.

Referenced by NL3D::CShadowMapManager::renderProject().

00506 {}

void NL3D::CCamera::registerBasic  )  [static]
 

Call at the begining of the program, to register the model.

Reimplemented from NL3D::CTransform.

Definition at line 37 of file camera.cpp.

References NL3D::CameraId, and NL3D::TransformId.

00038 {
00039         CScene::registerModel(CameraId, TransformId, CCamera::creator);
00040 }

void NL3D::CCamera::registerToChannelMixer CChannelMixer chanMixer,
const std::string &  prefix
[virtual]
 

register camera channels (in global anim mode).

Reimplemented from NL3D::CTransform.

Definition at line 151 of file camera.cpp.

References NL3D::IAnimatable::addValue(), FovValue, RollValue, and TargetValue.

00152 {
00153         // For CCamera, channels are not detailled.
00154         addValue(chanMixer, FovValue, OwnerBit, prefix, false);
00155         addValue(chanMixer, TargetValue, OwnerBit, prefix, false);
00156         addValue(chanMixer, RollValue, OwnerBit, prefix, false);
00157 
00158         CTransform::registerToChannelMixer(chanMixer, prefix);
00159 }

virtual void NL3D::CTransform::renderIntoSkeletonShadowMap CSkeletonModel rootSkeleton,
CMaterial castMat
[inline, virtual, inherited]
 

Special For Skeleton Caster. Render into the AuxDriver the mesh, within the current setuped Frustum/ViewMatrix. no-op by default, or if hidden in HRC!!

Parameters:
rootSkeleton the skeleton which is currently rendering its shadowMap

Reimplemented in NL3D::CMeshInstance, and NL3D::CSkeletonModel.

Definition at line 527 of file transform.h.

Referenced by NL3D::CSkeletonModel::renderIntoSkeletonShadowMap().

00527 {}

virtual sint NL3D::CTransform::renderShadowSkinGeom uint  remainingVertices,
uint8 vbDest
[inline, protected, virtual, inherited]
 

Deriver must change this method if isSkinnable(). It return a list of sphere relative to each bone of the father skeleton. Use with getSkinBoneUsage() to know to wich bone this sphere apply NB: if a sphere radius is -1, it means that the bone is not used (for any reason...) default is to return NULL.

Reimplemented in NL3D::CMeshMRMInstance, and NL3D::CMeshMRMSkinnedInstance.

Definition at line 612 of file transform.h.

References sint, uint, and uint8.

00612 {return 0;}

virtual void NL3D::CTransform::renderShadowSkinPrimitives CMaterial castMat,
IDriver drv,
uint  baseVertex
[inline, protected, virtual, inherited]
 

Deriver must change this method if isSkinnable(). It return a list of sphere relative to each bone of the father skeleton. Use with getSkinBoneUsage() to know to wich bone this sphere apply NB: if a sphere radius is -1, it means that the bone is not used (for any reason...) default is to return NULL.

Reimplemented in NL3D::CMeshMRMInstance, and NL3D::CMeshMRMSkinnedInstance.

Definition at line 613 of file transform.h.

References uint.

00613 {}

virtual void NL3D::CTransform::renderSkin float  alphaMRM  )  [inline, protected, virtual, inherited]
 

Deriver must change this method if isSkinnable(). It renders the skin with current ctx of the skeletonModel SkeletonModel has already setuped the Light and the modelMatrix in the driver. If the skin is a MRM, it is the skeleton which drives the MRM level with alphaMRM: [0,1] default is nop

Reimplemented in NL3D::CMeshInstance, NL3D::CMeshMRMInstance, and NL3D::CMeshMRMSkinnedInstance.

Definition at line 590 of file transform.h.

00590 {}

virtual sint NL3D::CTransform::renderSkinGroupGeom float  alphaMRM,
uint  remainingVertices,
uint8 dest
[inline, protected, virtual, inherited]
 

if supportSkinGrouping(), called to transform the VBuffer, and store it into dest.

Returns:
number of vertices added to the VBuffer, or -1 if > reaminingVertices

Reimplemented in NL3D::CMeshMRMInstance, and NL3D::CMeshMRMSkinnedInstance.

Definition at line 601 of file transform.h.

References sint, uint, and uint8.

00601 {return 0;}

virtual void NL3D::CTransform::renderSkinGroupPrimitives uint  baseVertex,
std::vector< CSkinSpecularRdrPass > &  specularRdrPasses,
uint  skinIndex
[inline, protected, virtual, inherited]
 

if supportSkinGrouping(), called to render the primitives of the already skinned vertices (VB activated in the driver) Optionnaly, fill specRdrPasses with specular rdrPass to sort (used for specular grouping).

Parameters:
baseVertex value to add to each PBlock index.

Reimplemented in NL3D::CMeshMRMInstance, and NL3D::CMeshMRMSkinnedInstance.

Definition at line 606 of file transform.h.

References uint.

00606 {}

virtual void NL3D::CTransform::renderSkinGroupSpecularRdrPass uint  rdrPass  )  [inline, protected, virtual, inherited]
 

Render a specific specular renderPass returned by renderSkinGroupPrimitives.

Reimplemented in NL3D::CMeshMRMInstance, and NL3D::CMeshMRMSkinnedInstance.

Definition at line 608 of file transform.h.

References uint.

00608 {}

void NL3D::CTransform::resetLighting  )  [inherited]
 

reset lights which influence this models. NB: the model is removed from all lights's list (except FrozenStaticLightSetup). Called by light rendering.

NB: the model is NOT removed from LightingManager (with eraseStaticLightedModel()).

Definition at line 988 of file transform.cpp.

References NL3D::CTransform::_LightContribution, NL3D::CLightContribution::FrozenStaticLightSetup, NL3D::CTransform::IsNeedUpdateLighting, NL3D::CTransform::isNeedUpdateLighting(), NL3D_MAX_LIGHT_CONTRIBUTION, NL3D::CLightContribution::NumFrozenStaticLight, NL3D::CLightContribution::PointLight, NL3D::CPointLight::removeLightedModel(), NL3D::CTransform::setStateFlag(), NL3D::CLightContribution::TransformIterator, and uint.

Referenced by NL3D::CLightingManager::addDynamicLight(), NL3D::CTransform::freezeStaticLightSetup(), NL3D::CPointLight::resetLightedModels(), NL3D::CTransform::unfreezeStaticLightSetup(), NL3D::CTransform::updateWorld(), and NL3D::CTransform::~CTransform().

00989 {
00990         // if the model is already isNeedUpdateLighting, his light setup is reseted.
00991         // so no need to reset again
00992         if(isNeedUpdateLighting())
00993                 return;
00994 
00995 
00996         // For all light not in FrozenStaticLightSetup, remove me from their list
00997         uint    startLight= 0;
00998         if(_LightContribution.FrozenStaticLightSetup)
00999         {
01000                 startLight= _LightContribution.NumFrozenStaticLight;
01001         }
01002 
01003         // for all light in the list, remove me from their list.
01004         for(uint i=startLight; i<NL3D_MAX_LIGHT_CONTRIBUTION; i++)
01005         {
01006                 CPointLight             *pl= _LightContribution.PointLight[i];
01007                 // if end of list, break.
01008                 if(!pl)
01009                         break;
01010                 else
01011                 {
01012                         // remove me from this light.
01013                         pl->removeLightedModel(_LightContribution.TransformIterator[i]);
01014                 }
01015         }
01016         // empty the list.
01017         if(startLight<NL3D_MAX_LIGHT_CONTRIBUTION)
01018                 _LightContribution.PointLight[startLight]= NULL;
01019 
01020 
01021         // the model needs to update his lighting.
01022         setStateFlag(IsNeedUpdateLighting, true);
01023         
01024 }

void NL3D::IAnimatable::resize uint  count  )  [inline, inherited]
 

Change value count, bit are set to 0

Parameters:
count is the new value count.

Definition at line 195 of file animatable.h.

References count, nlassert, and uint.

00196         {
00197                 // with the "uint32 _BitSet" implementation, juste check the size is correct
00198                 nlassert(count<=32);
00199         }

void NL3D::CTransform::setApplySkin bool  state  )  [protected, virtual, inherited]
 

Deriver must change this method if isSkinnable(). called by CSkeletonModel::bindSkin() NB: _FatherSkeletonModel is valid when setApplySkin() is called The default behavior must be called: it sets the flag so isSkinned() return the good thing

Reimplemented in NL3D::CMeshInstance, NL3D::CMeshMRMInstance, and NL3D::CMeshMRMSkinnedInstance.

Definition at line 584 of file transform.cpp.

References NL3D::CTransform::IsSkinned, and NL3D::CTransform::setStateFlag().

Referenced by NL3D::CSkeletonModel::bindSkin(), and NL3D::CSkeletonModel::detachSkeletonSon().

00585 {
00586         setStateFlag(IsSkinned, state);
00587 }

void NL3D::CTransform::setChannelMixerOwnerShip bool  enable = true  )  [inline, inherited]
 

This force gives this object ownership of the channel mixer it is registered to, so it will delete it when the dtor is called. It should be called AFTER this object has been registered to a channel mixer, because a new registration will broke the ownership. This is useful for automatic animations, when there's no owner of the channel mixer that could delete it.

Definition at line 256 of file transform.h.

References NL3D::CTransform::IsDeleteChannelMixer, and NL3D::CTransform::setStateFlag().

Referenced by NL3D::CScene::createInstance(), and NL3D::CTransform::registerToChannelMixer().

00256 { setStateFlag(IsDeleteChannelMixer, enable); }

void NL3D::CTransform::setClusterSystem CInstanceGroup pCS  )  [inline, inherited]
 

Definition at line 912 of file transform.h.

References NL3D::CTransform::_ClusterSystem, NL3D::CTransform::ForceClipRoot, NL3D::CTransform::getStateFlag(), and nlassert.

Referenced by NL3D::CScene::findCameraClusterSystemFromRay(), and NL3D::CTransform::setForceClipRoot().

00913 {
00914         if (pCS != NULL)
00915         {
00916                 nlassert(!getStateFlag(ForceClipRoot)); // the transform must be linked to the root, and have not cluster system when this flag is set
00917         }
00918         _ClusterSystem = pCS;
00919 }

void NL3D::CTransform::setDontUnfreezeChildren bool  val  )  [inherited]
 

Definition at line 378 of file transform.cpp.

References NL3D::CTransform::_DontUnfreezeChildren.

Referenced by NL3D::CInstanceGroup::createRoot().

00379 {
00380         _DontUnfreezeChildren = val;
00381 }

void NL3D::IAnimatable::setFather IAnimatable father,
uint  fatherOwnerBit
[inline, inherited]
 

Say which (if any) IAnimatable owns this one. This is important for Touch propagation. By this system, Fathers and ancestors know if they must check their sons (isTouched() return true).

Parameters:
father the father we must inform of our update.
fatherOwnerBit What bit of father we must set when we are updated

Definition at line 153 of file animatable.h.

References NL3D::IAnimatable::_Father, NL3D::IAnimatable::_FatherOwnerBit, NL3D::IAnimatable::propagateTouch(), and uint.

Referenced by NL3D::CMeshBase::instanciateMeshBase(), and NL3D::CSegRemanence::setAnimatedMaterial().

00154         {
00155                 _Father= father; _FatherOwnerBit= fatherOwnerBit;
00156 
00157                 // propagate the touch to the fathers.
00158                 propagateTouch();
00159         }

void NL3D::IAnimatable::setFlag uint  valueId  )  [inline, protected, inherited]
 

This method set a bit in the bitset.

Definition at line 239 of file animatable.h.

References NL3D::IAnimatable::_BitSet, and uint.

Referenced by NL3D::IAnimatable::propagateTouch(), and NL3D::IAnimatable::touch().

00240         {
00241                 _BitSet|= (1<<valueId);
00242         }

void NL3D::CTransform::setForceClipRoot bool  forceClipRoot  )  [inherited]
 

Force the transform to always be attached to the root As a consequence, it can't be inserted into a cluster system (even the root cluster) and is thus always visible when in the frustum (not clusterized) NB : any call to setClusterSystem will cause an assertion when the flag is set NB : any call to hrcUnlink will cause an assertion when the flag is set (must remain linked to the root)

Definition at line 1380 of file transform.cpp.

References NL3D::CTransform::_OwnerScene, NL3D::CTransform::ForceClipRoot, NL3D::CScene::getRoot(), NL3D::CTransform::getStateFlag(), NL3D::CTransform::hrcLinkSon(), NL3D::CTransform::hrcUnlink(), NL3D::CTransform::setClusterSystem(), and NL3D::CTransform::setStateFlag().

Referenced by NL3D::CTransformUser::setForceClipRoot().

01381 {
01382         if (forceClipRoot == (getStateFlag(ForceClipRoot) != 0)) return;
01383         if (forceClipRoot)
01384         {
01385                 // unlink from previous father and link to the root
01386                 hrcUnlink();
01387                 if (_OwnerScene)
01388                 {
01389                         _OwnerScene->getRoot()->hrcLinkSon(this);
01390                 }
01391                 setClusterSystem(NULL);
01392         }
01393         setStateFlag(ForceClipRoot, forceClipRoot);
01394 }

void NL3D::CCamera::setFov float  fov  )  [inline]
 

Work only if enableFovAnimation.

Definition at line 154 of file camera.h.

References _Fov, _FovAnimationEnabled, FovValue, nlassert, NL3D::IAnimatable::touch(), and NL3D::CAnimatedValueBlendable< float >::Value.

Referenced by build().

00155         {
00156                 nlassert(_FovAnimationEnabled);
00157                 _Fov.Value = fov;
00158                 touch(FovValue, OwnerBit);
00159         }

void NL3D::CCamera::setFrustum float  width,
float  height,
float  znear,
float  zfar,
bool  perspective = true
 

Setup the camera mode as a perspective/ortho camera. NB: znear and zfar must be >0 (if perspective).

Definition at line 66 of file camera.cpp.

References _Frustum, height, NL3D::CFrustum::init(), and width.

00067 {
00068         _Frustum.init(width, height, znear, zfar, perspective);
00069 }

void NL3D::CCamera::setFrustum float  left,
float  right,
float  bottom,
float  top,
float  znear,
float  zfar,
bool  perspective = true
 

Setup the camera mode as a perspective/ortho camera. NB: znear and zfar must be >0 (if perspective).

Definition at line 61 of file camera.cpp.

References _Frustum, and NL3D::CFrustum::init().

00062 {
00063         _Frustum.init( left, right,bottom, top, znear, zfar, perspective);
00064 }

void NL3D::CCamera::setFrustum const CFrustum f  )  [inline]
 

Set the frustum of the camera.

Definition at line 90 of file camera.h.

References _Frustum.

Referenced by CCamera(), and NL3D::CCameraUser::setFrustum().

00090 {_Frustum= f;}

void NL3D::CTransform::setGeneratingShadowMap bool  state  )  [inline, inherited]
 

For ShadowMapManager. true if the model is rendering its ShadowMap this frame.

Definition at line 514 of file transform.h.

References NL3D::CTransform::canCastShadowMap(), NL3D::CTransform::IsGeneratingShadowMap, and NL3D::CTransform::setStateFlag().

Referenced by NL3D::CShadowMapManager::addShadowCasterGenerate().

00514 {if(canCastShadowMap()) setStateFlag(IsGeneratingShadowMap, state);}

void NL3D::CTransform::setIsBigLightable bool  val  )  [protected, inherited]
 

Deriver must use this method with true to indicate the model is a big lightable.

Definition at line 574 of file transform.cpp.

References NL3D::CTransform::IsBigLightable, and NL3D::CTransform::setStateFlag().

Referenced by NL3D::CMeshBase::instanciateMeshBase().

00575 {
00576         setStateFlag(IsBigLightable, val);
00577 }

void NL3D::CTransform::setIsCluster bool  val  )  [inline, protected, inherited]
 

For CCluster only.

Definition at line 671 of file transform.h.

References NL3D::CTransform::IsCluster, and NL3D::CTransform::setStateFlag().

00671 {setStateFlag(IsCluster, val);}

void NL3D::CTransform::setIsForceAnimDetail bool  val  )  [protected, inherited]
 

Deriver must use this method with true if the model must be AnimDetail-ed whatever registerToChannelMixer() has been called or not

Definition at line 590 of file transform.cpp.

References NL3D::CTransform::_FatherSkeletonModel, NL3D::CSkeletonModel::dirtSkinRenderLists(), NL3D::CTransform::getStateFlag(), NL3D::CTransform::IsAnimDetailable, NL3D::CTransform::IsForceAnimDetail, NL3D::CTransform::isSkinned(), nlassert, and NL3D::CTransform::setStateFlag().

00591 {
00592         setStateFlag(IsForceAnimDetail, val );
00593 
00594         // Update flag, if we must be inserted in AnimDetail
00595         setStateFlag(IsAnimDetailable, _ChannelMixer || getStateFlag(IsForceAnimDetail) );
00596 
00597         // If skinned, then must inform skeleton parent that it must recompute skin render/animDetail lists
00598         if(isSkinned())
00599         {
00600                 nlassert(_FatherSkeletonModel);
00601                 _FatherSkeletonModel->dirtSkinRenderLists();
00602         }
00603 }

void NL3D::CTransform::setIsLightable bool  val  )  [protected, inherited]
 

Deriver must use this method with true to indicate the model support lighting.

Definition at line 552 of file transform.cpp.

References NL3D::CTransform::getStateFlag(), NL3D::CTransform::IsFinalLightable, NL3D::CTransform::IsLightable, NL3D::CTransform::IsUserLightable, and NL3D::CTransform::setStateFlag().

Referenced by NL3D::CMeshBase::instanciateMeshBase().

00553 {
00554         setStateFlag(IsLightable, val);
00555         // update IsFinalLightable
00556         setStateFlag(IsFinalLightable, (getStateFlag(IsLightable) && getStateFlag(IsUserLightable)) );
00557 }

void NL3D::CTransform::setIsLoadbalancable bool  val  )  [protected, inherited]
 

Deriver must use this method with true to indicate the model support loadBalancing.

Definition at line 605 of file transform.cpp.

References NL3D::CTransform::IsLoadBalancable, and NL3D::CTransform::setStateFlag().

00606 {
00607         setStateFlag(IsLoadBalancable, val );
00608 }

void NL3D::CTransform::setIsMeshBaseInstance bool  val  )  [inline, protected, inherited]
 

For CMeshBaseInstance only.

Definition at line 667 of file transform.h.

References NL3D::CTransform::IsMeshBaseInstance, and NL3D::CTransform::setStateFlag().

00667 {setStateFlag(IsMeshBaseInstance, val);}

void NL3D::CTransform::setIsRenderable bool  val  )  [protected, inherited]
 

Deriver must use this method with true to indicate the model can be rendered. "can be rendered" means if object has to be inserted in RenderTrav list. eg: a mesh must be inserted in a render list, but not a light, or a NULL transform. The default is false.

Definition at line 568 of file transform.cpp.

References NL3D::CTransform::IsRenderable, and NL3D::CTransform::setStateFlag().

00569 {
00570         setStateFlag(IsRenderable, val);
00571 }

void NL3D::CTransform::setIsShadowMapCaster bool  val  )  [inline, protected, inherited]
 

ShadowMap.

Definition at line 674 of file transform.h.

References NL3D::CTransform::IsShadowMapCaster, and NL3D::CTransform::setStateFlag().

00674 {setStateFlag(IsShadowMapCaster, val);}

void NL3D::CTransform::setIsShadowMapReceiver bool  val  )  [inline, protected, inherited]
 

Deriver must use this method with true to indicate the model is a big lightable.

Definition at line 675 of file transform.h.

References NL3D::CTransform::IsShadowMapReceiver, and NL3D::CTransform::setStateFlag().

00675 {setStateFlag(IsShadowMapReceiver, val);}

void NL3D::CTransform::setIsSkeleton bool  val  )  [protected, inherited]
 

For CSkeletonModel only.

Definition at line 579 of file transform.cpp.

References NL3D::CTransform::IsSkeleton, and NL3D::CTransform::setStateFlag().

00580 {
00581         setStateFlag(IsSkeleton, val);
00582 }

void NL3D::CTransform::setIsTransformShape bool  val  )  [inline, protected, inherited]
 

For CTransformShape only.

Definition at line 669 of file transform.h.

References NL3D::CTransform::IsTransformShape, and NL3D::CTransform::setStateFlag().

00669 {setStateFlag(IsTransformShape, val);}

void NL3D::CTransform::setLoadBalancingGroup const std::string &  group  )  [inherited]
 

Change the load Balancing group of a model. Every models are in a special LoadBalancingGroup. NB: the group is created if did not exist. NB: if models are skinned, it is their Skeleton which drive the group

By default, models lies in the "Default" group, but Skeletons for skinning and ParticlesSystems which are in "Skin" and "Fx" group respectively. The "Default" group is special because it is not balanced (ie models are only degraded from their distance to camera)

Definition at line 522 of file transform.cpp.

References NL3D::CTransform::_LoadBalancingGroup, NL3D::CScene::getLoadBalancingTrav(), NL3D::CLoadBalancingTrav::getOrCreateGroup(), and NL3D::CTransform::getOwnerScene().

Referenced by NL3D::CSkeletonShape::createInstance(), NL3D::CSegRemanenceShape::createInstance(), and NL3D::CParticleSystemShape::createInstance().

00523 {
00524         // Get the traversal.
00525         CLoadBalancingTrav      &trav= getOwnerScene()->getLoadBalancingTrav();
00526         // get the group from trav (create if needed), and set it.
00527         _LoadBalancingGroup= trav.getOrCreateGroup(group);
00528 }

void NL3D::CTransform::setLogicInfo ILogicInfo logicInfo  )  [inline, inherited]
 

Set the LogicInfo for this transfrom, eg to retrieve statc light information, see ILogicInfo. Ptr is kept in CTransfrom, so should call setLogicInfo(NULL) before to clean up.

Definition at line 389 of file transform.h.

References NL3D::CTransform::_LogicInfo.

Referenced by NL3D::CTransformUser::setLogicInfo().

00389 {_LogicInfo= logicInfo;}

void NL3D::ITransformable::setMatrix const CMatrix mat  )  [inline, inherited]
 

Work only in DirecTMatrix mode (nlassert).

Definition at line 174 of file transformable.h.

References NL3D::ITransformable::_LocalMatrixDate, NL3D::ITransformable::DirectMatrix, and nlassert.

Referenced by NL3D::ITransformable::lookAt(), and NL3D::CTransformableUser::setMatrix().

00175         {
00176                 nlassert(_Mode==DirectMatrix);
00177                 _LocalMatrix= mat;
00178                 // The matrix has changed.
00179                 _LocalMatrixDate++;
00180         }

void NL3D::CTransform::setMeanColor CRGBA  color  )  [inherited]
 

set the Mean color of the transform. The mean color can be used for many purpose, such as drawing objects if the textures are not loaded. It is used also for Lod Character. Default color is (255,255,255)

Definition at line 540 of file transform.cpp.

References NL3D::CTransform::_MeanColor.

00541 {
00542         // if the color is different from prec
00543         if(color!=_MeanColor)
00544         {
00545                 // change it.
00546                 _MeanColor= color;
00547         }
00548 }

void NL3D::CTransform::setOpacity bool  v  )  [inherited]
 

Definition at line 255 of file transform.cpp.

References NL3D::CTransform::_FatherSkeletonModel, NL3D::CSkeletonModel::dirtSkinRenderLists(), NL3D::CTransform::getStateFlag(), NL3D::CTransform::isSkinned(), nlassert, NL3D::CTransform::setStateFlag(), and v.

Referenced by NL3D::CFlareModel::CFlareModel(), NL3D::CParticleSystemModel::CParticleSystemModel(), NL3D::CSkeletonModel::CSkeletonModel(), NL3D::CVegetableBlendLayerModel::CVegetableBlendLayerModel(), NL3D::CWaterModel::CWaterModel(), NL3D::CMeshBase::instanciateMeshBase(), NL3D::CTransformUser::setOpacity(), NL3D::CMeshMultiLodInstance::traverseLoadBalancing(), NL3D::CSegRemanence::updateOpacityFromShape(), and NL3D::CParticleSystemModel::updateOpacityInfos().

00256 { 
00257         bool bTmp = getStateFlag(IsOpaque) == 0 ? false : true;
00258         if (bTmp != v)
00259         {
00260                 setStateFlag(IsOpaque, v);
00261                 if(isSkinned())
00262                 {
00263                         nlassert(_FatherSkeletonModel);
00264                         _FatherSkeletonModel->dirtSkinRenderLists();
00265                 }
00266         }
00267 }

void NL3D::CTransform::setOrderingLayer uint  layer  )  [inline, inherited]
 

Set the current layer for this transform. Typically, this is used to sort transparent objects. Isn't used with solid objects. For now : Layer 0 is for underwater Layer 1 is for water surfaces Layer 2 is for object above water

Definition at line 184 of file transform.h.

References NL3D::CTransform::_OrderingLayer, and uint.

Referenced by NL3D::CWaterModel::CWaterModel(), and NL3D::CTransformUser::setOrderingLayer().

00184 { _OrderingLayer = layer; }

void NL3D::CCamera::setPerspective float  fov,
float  aspectRatio,
float  znear,
float  zfar
 

Setup a perspective camera, giving a fov in radians.

Parameters:
fov the horizontal angle of view, in radians. (Pi/2 as example)
aspectRatio the ratio horizontal/vertical (1.33 as example).
znear the front clipping plane distance.
zfar the back clipping plane distance.

Definition at line 71 of file camera.cpp.

References _Frustum, and NL3D::CFrustum::initPerspective().

Referenced by NL3D::CCameraUser::setPerspective(), and update().

00072 {
00073         _Frustum.initPerspective(fov, aspectRatio, znear, zfar);
00074 }

void NL3D::ITransformable::setPivot float  x,
float  y,
float  z
[inline, inherited]
 

Work only in Rot* mode (nlassert).

Definition at line 169 of file transformable.h.

References NL3D::ITransformable::setPivot(), x, y, and z.

00170         {
00171                 setPivot(CVector(x, y, z));
00172         }

void NL3D::ITransformable::setPivot const CVector pivot  )  [inline, inherited]
 

Work only in Rot* mode (nlassert).

Definition at line 162 of file transformable.h.

References NL3D::ITransformable::_Pivot, nlassert, NL3D::ITransformable::PivotValue, NL3D::ITransformable::RotEuler, NL3D::ITransformable::RotQuat, NL3D::IAnimatable::touch(), and NL3D::CAnimatedValueBlendable< T >::Value.

Referenced by NL3D::ITransformable::lookAt(), NL3D::CTransformableUser::setPivot(), and NL3D::ITransformable::setPivot().

00163         {
00164                 nlassert(_Mode==RotEuler || _Mode==RotQuat);
00165                 _Pivot.Value= pivot;
00166                 touch(PivotValue, OwnerBit);
00167         }

void NL3D::ITransformable::setPos float  x,
float  y,
float  z
[inline, inherited]
 

Work only in Rot* mode(nlassert).

Definition at line 121 of file transformable.h.

References NL3D::ITransformable::setPos(), x, y, and z.

00122         {
00123                 setPos(CVector(x,y,z));
00124         }

void NL3D::ITransformable::setPos const CVector pos  )  [inline, inherited]
 

Work only in Rot* mode(nlassert).

Definition at line 114 of file transformable.h.

References nlassert, NL3D::ITransformable::PosValue, NL3D::ITransformable::RotEuler, NL3D::ITransformable::RotQuat, NL3D::IAnimatable::touch(), and NL3D::CAnimatedValueBlendable< T >::Value.

Referenced by build(), NL3D::ITransformable::lookAt(), NL3D::CTransformableUser::setPos(), NL3D::ITransformable::setPos(), NL3D::CInstanceGroup::setPos(), and NL3D::CPSLight::step().

00115         {
00116                 nlassert(_Mode==RotEuler || _Mode==RotQuat);
00117                 _Pos.Value= pos;
00118                 touch(PosValue, OwnerBit);
00119         }

void NL3D::CCamera::setRoll float  roll  )  [inline]
 

Work only if enableTargetAnimation.

Definition at line 147 of file camera.h.

References _Roll, _TargetAnimationEnabled, nlassert, RollValue, NL3D::IAnimatable::touch(), and NL3D::CAnimatedValueBlendable< float >::Value.

Referenced by build().

00148         {
00149                 nlassert(_TargetAnimationEnabled);
00150                 _Roll.Value = roll;
00151                 touch(RollValue, OwnerBit);
00152         }

void NL3D::ITransformable::setRotEuler float  rotX,
float  rotY,
float  rotZ
[inline, inherited]
 

Work only in RotEuler mode(nlassert).

Definition at line 133 of file transformable.h.

References NL3D::ITransformable::setRotEuler().

00134         {
00135                 setRotEuler(CVector(rotX, rotY, rotZ));
00136         }

void NL3D::ITransformable::setRotEuler const CVector rot  )  [inline, inherited]
 

Work only in RotEuler mode(nlassert).

Definition at line 126 of file transformable.h.

References NL3D::ITransformable::_RotEuler, nlassert, NL3D::ITransformable::RotEuler, NL3D::ITransformable::RotEulerValue, NL3D::IAnimatable::touch(), and NL3D::CAnimatedValueBlendable< T >::Value.

Referenced by NL3D::CTransformableUser::setRotEuler(), and NL3D::ITransformable::setRotEuler().

00127         {
00128                 nlassert(_Mode==RotEuler);
00129                 _RotEuler.Value= rot;
00130                 touch(RotEulerValue, OwnerBit);
00131         }

void NL3D::ITransformable::setRotQuat const CQuat quat  )  [inline, inherited]
 

Work only in RotQuat mode (nlassert).

Definition at line 138 of file transformable.h.

References NL3D::ITransformable::_RotQuat, nlassert, NL3D::ITransformable::RotQuat, NL3D::ITransformable::RotQuatValue, NL3D::IAnimatable::touch(), and NL3D::CAnimatedValueBlendable< T >::Value.

Referenced by NL3D::CTargetAnimCtrl::execute(), NL3D::ITransformable::lookAt(), NL3D::CTransformableUser::setRotQuat(), and NL3D::CInstanceGroup::setRotQuat().

00139         {
00140                 nlassert(_Mode==RotQuat);
00141                 _RotQuat.Value= quat;
00142                 touch(RotQuatValue, OwnerBit);
00143         }

void NL3D::ITransformable::setScale float  scale  )  [inline, inherited]
 

Work only in Rot* mode (nlassert).

Definition at line 157 of file transformable.h.

References NL3D::ITransformable::setScale().

00158         {
00159                 setScale(CVector(scale, scale, scale));
00160         }

void NL3D::ITransformable::setScale float  scaleX,
float  scaleY,
float  scaleZ
[inline, inherited]
 

Work only in Rot* mode (nlassert).

Definition at line 152 of file transformable.h.

References NL3D::ITransformable::setScale().

00153         {
00154                 setScale(CVector(scaleX, scaleY, scaleZ));
00155         }

void NL3D::ITransformable::setScale const CVector scale  )  [inline, inherited]
 

Work only in Rot* mode (nlassert).

Definition at line 145 of file transformable.h.

References nlassert, NL3D::ITransformable::RotEuler, NL3D::ITransformable::RotQuat, NL3D::ITransformable::ScaleValue, NL3D::IAnimatable::touch(), and NL3D::CAnimatedValueBlendable< T >::Value.

Referenced by NL3D::ITransformable::lookAt(), NL3D::CTransformableUser::setScale(), and NL3D::ITransformable::setScale().

00146         {
00147                 nlassert(_Mode==RotEuler || _Mode==RotQuat);
00148                 _Scale.Value= scale;
00149                 touch(ScaleValue, OwnerBit);
00150         }

void NL3D::CCamera::setTargetPos float  x,
float  y,
float  z
[inline]
 

Work only if enableTargetAnimation.

Definition at line 142 of file camera.h.

References setTargetPos(), x, y, and z.

00143         {
00144                 setTargetPos(CVector(x,y,z));
00145         }

void NL3D::CCamera::setTargetPos const CVector pos  )  [inline]
 

Work only if enableFovAnimation.

Definition at line 135 of file camera.h.

References _Target, _TargetAnimationEnabled, nlassert, TargetValue, NL3D::IAnimatable::touch(), and NL3D::CAnimatedValueBlendable< T >::Value.

Referenced by build(), and setTargetPos().

00136         {
00137                 nlassert(_TargetAnimationEnabled);
00138                 _Target.Value= pos;
00139                 touch(TargetValue, OwnerBit);
00140         }

void NL3D::ITransformable::setTransformMode TTransformMode  mode,
CMatrix::TRotOrder  ro = CMatrix::ZXY
[inline, inherited]
 

Change the transform mode. Components or matrix are not reseted.

Definition at line 100 of file transformable.h.

References NL3D::ITransformable::_RotOrder, NL3D::ITransformable::PosValue, and NL3D::IAnimatable::touch().

Referenced by build(), enableTargetAnimation(), NL3D::CPSMesh::newElement(), NL3D::CTransformableUser::setTransformMode(), and NL3D::CPSMesh::updatePos().

00101         {
00102                 _Mode= mode;
00103                 _RotOrder= ro;
00104                 // just for information.
00105                 touch(PosValue, OwnerBit);
00106         }

void NL3D::CTransform::setTransparency bool  v  )  [inherited]
 

Accessors for opacity/transparency

Definition at line 240 of file transform.cpp.

References NL3D::CTransform::_FatherSkeletonModel, NL3D::CSkeletonModel::dirtSkinRenderLists(), NL3D::CTransform::getStateFlag(), NL3D::CTransform::isSkinned(), nlassert, NL3D::CTransform::setStateFlag(), and v.

Referenced by NL3D::CFlareModel::CFlareModel(), NL3D::CParticleSystemModel::CParticleSystemModel(), NL3D::CSkeletonModel::CSkeletonModel(), NL3D::CVegetableBlendLayerModel::CVegetableBlendLayerModel(), NL3D::CWaterModel::CWaterModel(), NL3D::CMeshBase::instanciateMeshBase(), NL3D::CTransformUser::setTransparency(), NL3D::CMeshMultiLodInstance::traverseLoadBalancing(), NL3D::CSegRemanence::updateOpacityFromShape(), NL3D::CParticleSystemModel::updateOpacityInfos(), and NL3D::CSkeletonModel::updateSkinRenderLists().

00241 { 
00242         bool bTmp = getStateFlag(IsTransparent) == 0 ? false : true;
00243         if (bTmp != v)
00244         {
00245                 setStateFlag(IsTransparent, v);
00246                 if(isSkinned())
00247                 {
00248                         nlassert(_FatherSkeletonModel);
00249                         _FatherSkeletonModel->dirtSkinRenderLists();
00250                 }
00251         }
00252 }

void NL3D::CTransform::setUserClipping bool  enable  )  [inherited]
 

Definition at line 1310 of file transform.cpp.

References NL3D::CTransform::setStateFlag(), and NL3D::CTransform::UserClipping.

Referenced by NL3D::CTransformUser::setUserClipping().

01311 {
01312         setStateFlag (UserClipping, enable);
01313 }

void NL3D::CTransform::setUserLightable bool  enable  )  [inherited]
 

Set the UserLightable flag. if false, isLightable() will always return false. Doing this, user can disable lighting on a model which may be interesting for speed. Default behavior is UserLightable==true.

Definition at line 559 of file transform.cpp.

References NL3D::CTransform::getStateFlag(), NL3D::CTransform::IsFinalLightable, NL3D::CTransform::IsLightable, NL3D::CTransform::IsUserLightable, and NL3D::CTransform::setStateFlag().

Referenced by NL3D::CTransformUser::setUserLightable().

00560 {
00561         setStateFlag(IsUserLightable, enable);
00562         // update IsFinalLightable
00563         setStateFlag(IsFinalLightable, (getStateFlag(IsLightable) && getStateFlag(IsUserLightable)) );
00564 }

void NL3D::CTransform::setWorldMatrix const CMatrix mat  )  [inline, inherited]
 

Definition at line 302 of file transform.h.

Referenced by NL3D::CParticleSystemManager::processAnimate().

00302 { _WorldMatrix = mat;}

void NL3D::CTransform::show  )  [inherited]
 

Show the objet and his sons.

Definition at line 271 of file transform.cpp.

References NL3D::CTransform::_FatherSkeletonModel, NL3D::CTransform::_TransformDirty, NL3D::CSkeletonModel::dirtSkinRenderLists(), NL3D::CTransform::isSkinned(), nlassert, and NL3D::CTransform::Visibility.

Referenced by NL3D::CTransformUser::show(), and NL3D::CLandscapeUser::show().

00272 {
00273         // Optim: do nothing if already set
00274         if(Visibility!= CHrcTrav::Show)
00275         {
00276                 _TransformDirty= true;
00277                 Visibility= CHrcTrav::Show;
00278                 // If skinned, then must inform skeleton parent that it must recompute skin render/animDetail lists
00279                 if(isSkinned())
00280                 {
00281                         nlassert(_FatherSkeletonModel);
00282                         _FatherSkeletonModel->dirtSkinRenderLists();
00283                 }
00284         }
00285 }

virtual bool NL3D::CTransform::supportShadowSkinGrouping  )  const [inline, protected, virtual, inherited]
 

Special Skinning For ShadowMapping.

Reimplemented in NL3D::CMeshMRMInstance, and NL3D::CMeshMRMSkinnedInstance.

Definition at line 611 of file transform.h.

00611 {return false;}

virtual bool NL3D::CTransform::supportSkinGrouping  )  const [inline, protected, virtual, inherited]
 

Deriver may support SkinGrouping if isSkinnable(). It renders the skin with current ctx of the skeletonModel, but torn in 2 pass: fillVB,a nd renderPrimitives Deriver may check NL3D_MESH_SKIN_MANAGER_VERTEXFORMAT and NL3D_MESH_SKIN_MANAGER_MAXVERTICES

Reimplemented in NL3D::CMeshMRMInstance, and NL3D::CMeshMRMSkinnedInstance.

Definition at line 597 of file transform.h.

00597 {return false;}

void NL3D::IAnimatable::touch uint  valueId,
uint  ownerValueId
[inline, inherited]
 

Touch a value because it has been modified.

Parameters:
valueId is the animated value ID in the object we want to touch.
ownerValueId is the bit of the IAnimatable part which owns this animated value.

Definition at line 168 of file animatable.h.

References NL3D::IAnimatable::propagateTouch(), NL3D::IAnimatable::setFlag(), and uint.

Referenced by NL3D::CChannelMixer::eval(), NL3D::CChannelMixer::evalSingleChannel(), NL3D::CParticleSystemModel::reallocRsc(), NL3D::CChannelMixer::refreshList(), setFov(), NL3D::ITransformable::setPivot(), NL3D::ITransformable::setPos(), setRoll(), NL3D::ITransformable::setRotEuler(), NL3D::ITransformable::setRotQuat(), NL3D::ITransformable::setScale(), setTargetPos(), NL3D::ITransformable::setTransformMode(), and NL3D::CParticleSystemInstanceUser::setUserParam().

00169         {
00170                 // Set the bit
00171                 setFlag(valueId);
00172                 // Set the owner bit
00173                 setFlag(ownerValueId);
00174 
00175                 // propagate the touch to the fathers.
00176                 propagateTouch();
00177         }

void NL3D::CTransform::traverseAnimDetail  )  [virtual, inherited]
 

call updateWorldMatrixFromFather(), then traverseAnimDetailWithoutUpdateWorldMatrix()

Reimplemented in NL3D::CMeshBaseInstance, NL3D::CParticleSystemModel, NL3D::CQuadGridClipManager, NL3D::CRootModel, NL3D::CSegRemanence, NL3D::CSkeletonModel, and NL3D::CWaveMakerModel.

Definition at line 953 of file transform.cpp.

References NL3D::CTransform::traverseAnimDetailWithoutUpdateWorldMatrix(), and NL3D::CTransform::updateWorldMatrixFromFather().

Referenced by NL3D::CAnimDetailTrav::traverse(), and NL3D::CAnimDetailTrav::traverseHrcRecurs().

00954 {
00955         // First, test if I must update my worldMatrix because of the ancestorSkeleton scheme
00956         updateWorldMatrixFromFather();
00957 
00958         // eval channelMixer.
00959         traverseAnimDetailWithoutUpdateWorldMatrix();
00960 
00961         // NB: if want to add something, do it in traverseAnimDetailWithoutUpdateWorldMatrix(), because
00962         // CSkeletonModel doesn't call CTransform::traverseAnimDetail()
00963 }

void NL3D::CTransform::traverseAnimDetailWithoutUpdateWorldMatrix  )  [protected, inherited]
 

traverse without updatin WorldMatrixFromFather:

  • animdetail if the model channelmixer is not NULL, and if model not clipped

Definition at line 938 of file transform.cpp.

References NL3D::CChannelMixer::eval(), and NL3D::CTransform::getOwnerScene().

Referenced by NL3D::CTransform::traverseAnimDetail().

00939 {
00940         // AnimDetail behavior: animate only if not clipped.
00941         // NB: no need to test because of VisibilityList use.
00942 
00943         // test if the refptr is NULL or not (RefPtr).
00944         CChannelMixer   *chanmix= _ChannelMixer;
00945         if(chanmix)
00946         {
00947                 // eval detail!!
00948                 chanmix->eval(true, getOwnerScene()->getAnimDetailTrav().CurrentDate);
00949         }
00950 }

void NL3D::CTransform::traverseClip  )  [virtual, inherited]
 

The base traverseClip method. The behavior is to:

  • test if _WorldVis is visible.
  • test if is clipped with clip() OR IF SKELETON MODEL, USE SKELETON MODEL clip!!
  • if visible and not clipped, set _Visible=true (else false). and
    • add the CTransform* to the ClipTrav list
  • if _Visible==true, and renderable, add it to the RenderTraversal: RenderTrav->addRenderModel(model);
  • always traverseSons(), to clip the sons.

Reimplemented in NL3D::CCluster, NL3D::CLandscapeModel, NL3D::CParticleSystemModel, NL3D::CQuadGridClipManager, and NL3D::CRootModel.

Definition at line 806 of file transform.cpp.

References NL3D::CTransform::_AncestorSkeletonModel, NL3D::CTransform::_ClipDate, NL3D::CTransform::_FatherSkeletonModel, NL3D::CTransform::_ForceCLodSticked, NL3D::CTransform::_RenderFilterType, NL3D::CTransform::_StateFlags, NL3D::CTransform::_Visible, NL3D::CTransform::_WorldVis, NL3D::CLightTrav::addLightedModel(), NL3D::CRenderTrav::addRenderModel(), NL3D::CLoadBalancingTrav::addVisibleModel(), NL3D::CAnimDetailTrav::addVisibleModel(), NL3D::CClipTrav::addVisibleModel(), NL3D::CTransform::clip(), NL3D::CTransform::clipGetChild(), NL3D::CTransform::clipGetNumChildren(), NL3D::CClipTrav::CurrentDate, NL3D::CScene::getAnimDetailTrav(), NL3D::CScene::getClipTrav(), NL3D::CScene::getFilterRenderFlags(), NL3D::CScene::getLightTrav(), NL3D::CScene::getLoadBalancingTrav(), NL3D::CTransform::getOwnerScene(), NL3D::CScene::getRenderTrav(), NL3D::CTransform::isAnimDetailable(), NL3D::CTransform::isClipVisible(), NL3D::CSkeletonModel::isDisplayedAsLodCharacter(), NL3D::CTransform::isLightable(), NL3D::CTransform::isLoadBalancable(), NL3D::CTransform::isRenderable(), num, uint, and NL3D::CTransform::UserClipping.

Referenced by NL3D::CCluster::recursTraverseClip(), NL3D::CClipTrav::traverse(), NL3D::CRootModel::traverseClip(), and NL3D::CParticleSystemModel::traverseClip().

00807 {
00808         // disable H_AUTO, because slowdown when lot of models (eg 1000-2000 tested in forest)
00809         //H_AUTO( NL3D_TransformClip );
00810 
00811         CScene                  *scene= getOwnerScene();
00812         CClipTrav               &clipTrav= scene->getClipTrav();
00813 
00814         if ((_ClipDate == clipTrav.CurrentDate) && _Visible)
00815                 return;
00816         _ClipDate = clipTrav.CurrentDate;
00817 
00818         // clip: update Visible flag.
00819         _Visible= false;
00820         // if at least visible.
00821         if(_WorldVis)
00822         {
00823                 // If linked to a SkeletonModel anywhere in the hierarchy, don't clip, and use skeleton model clip result.
00824                 // This works because we are sons of a special node which is not in the clip traversal, and
00825                 // which is traversed at end of the traversal.
00826                 if( _AncestorSkeletonModel!=NULL )
00827                 {
00828                         _Visible= _AncestorSkeletonModel->isClipVisible();
00829                         // Special test: if we are sticked to a skeletonModel, and if we are still visible, maybe we don't have to
00830                         if(_Visible && _FatherSkeletonModel)
00831                         {
00832                                 // if our skeletonModel father is displayed with a Lod, maybe we are not to be displayed
00833                                 if(_FatherSkeletonModel->isDisplayedAsLodCharacter())
00834                                 {
00835                                         // We are visible only if we where sticked to the skeleton with forceCLod==true.
00836                                         // This is also true if we are actually a skeletonModel
00837                                         if(!_ForceCLodSticked)
00838                                                 // otherWise we are not visible. eg: this is the case of skins and some sticked object
00839                                                 _Visible= false;
00840                                 }
00841                         }
00842                 }
00843                 // else, clip.
00844                 else
00845                 {
00846                         // If the instance is not filtered
00847                         if(scene->getFilterRenderFlags() & _RenderFilterType)
00848                         {
00849                                 // User cliping enabled ?
00850                                 if (_StateFlags & UserClipping)
00851                                         _Visible= true;
00852                                 else
00853                                         _Visible= clip();
00854                         }
00855                 }
00856         }
00857 
00858         // if visible, add to list.
00859         if(_Visible)
00860         {
00861                 // add this model to the visibility list.
00862                 clipTrav.addVisibleModel(this);
00863 
00864                 // Has not an ancestor skeleton model?
00865                 if( _AncestorSkeletonModel==NULL )
00866                 {
00867                         // If needed, insert the model in the lighted list.
00868                         // don't insert if has an ancestorSkeletonModel, because in this case, result is driven by 
00869                         // the _LightContribution of the _AncestorSkeletonModel.
00870                         if( isLightable() )
00871                                 scene->getLightTrav().addLightedModel(this);
00872 
00873                         // If needed, insert the model in the animDetail list.
00874                         // don't insert if has an ancestoreSkeletonModel, because in this case, this ancestore will 
00875                         // animDetail through the hierarchy...
00876                         if( isAnimDetailable() )
00877                                 scene->getAnimDetailTrav().addVisibleModel(this);
00878                 }
00879 
00880                 // If needed, Add it to the loadBalancing trav
00881                 if( isLoadBalancable() )
00882                         scene->getLoadBalancingTrav().addVisibleModel(this);
00883 
00884                 // If needed, insert the model in the render list.
00885                 if( isRenderable() )
00886                         scene->getRenderTrav().addRenderModel(this);
00887         }
00888 
00889         // Traverse the Clip sons.
00890         uint    num= clipGetNumChildren();
00891         for(uint i=0;i<num;i++)
00892                 clipGetChild(i)->traverseClip();
00893 }

void NL3D::CTransform::traverseHrc  )  [virtual, inherited]
 

Each method is called in its associated traversal.

Reimplemented in NL3D::CCluster, NL3D::CLandscapeModel, NL3D::CMeshBaseInstance, NL3D::CQuadGridClipManager, and NL3D::CRootModel.

Definition at line 786 of file transform.cpp.

References NL3D::CTransform::hrcGetChild(), NL3D::CTransform::hrcGetNumChildren(), num, uint, and NL3D::CTransform::updateWorld().

Referenced by NL3D::CHrcTrav::traverse(), and NL3D::CRootModel::traverseHrc().

00787 {
00788         // Recompute the matrix, according to _HrcParent matrix mode, and local matrix.
00789         updateWorld();
00790 
00791         // Traverse the Hrc sons.
00792         uint    num= hrcGetNumChildren();
00793         for(uint i=0;i<num;i++)
00794                 hrcGetChild(i)->traverseHrc();
00795 }

void NL3D::CTransform::traverseLight  )  [virtual, inherited]
 

traverse the lightedModel per default: recompute LightContribution is isLightable()

Reimplemented in NL3D::CPointLightModel, NL3D::CQuadGridClipManager, and NL3D::CRootModel.

Definition at line 1080 of file transform.cpp.

References NL3D::CTransform::_LightContribution, NL3D::CTransform::_LogicInfo, NL3D::CLightContribution::AttFactor, NL3D::CPointLight::computeLinearAttenuation(), NL3D::CLightingManager::computeModelLightContributions(), NL3D::CTransform::getAABBox(), NLMISC::CAABBox::getCenter(), NL3D::CScene::getLightTrav(), NL3D::CTransform::getOwnerScene(), NL3D::CPointLight::getPosition(), NL3D::CTransform::getWorldMatrix(), NL3D::CTransform::isNeedUpdateFrozenStaticLightSetup(), NL3D::CTransform::isNeedUpdateLighting(), NL3D::CLightTrav::LightingManager, NL3D::CLightContribution::NumFrozenStaticLight, NLMISC::OptFastFloor(), NL3D::CLightContribution::PointLight, NL3D::CTransform::setStateFlag(), sint, uint, and uint8.

01081 {
01082         // if the model do not need to update his lighting, just skip.
01083         if(!isNeedUpdateLighting())
01084                 return;
01085 
01086 
01087         // If a freezeStaticLightSetup() has been called on this model recently.
01088         if(isNeedUpdateFrozenStaticLightSetup())
01089         {
01090                 // Now, the correct matrix is computed.
01091                 // get the untransformed bbox from the model.
01092                 CAABBox         bbox;
01093                 getAABBox(bbox);
01094                 // get transformed center pos of bbox
01095                 CVector worldModelPos= getWorldMatrix() * bbox.getCenter();
01096 
01097                 // So we can compute AttFactor for each static light influencing this static object
01098                 uint    numPointLights= _LightContribution.NumFrozenStaticLight;
01099                 for(uint i=0;i<numPointLights;i++)
01100                 {
01101                         const CPointLight       *pl= _LightContribution.PointLight[i];
01102                         // don't worry about the precision of floor, because of *255.
01103                         float   distToModel= (pl->getPosition() - worldModelPos).norm();
01104                         sint    attFactor= NLMISC::OptFastFloor( 255 * pl->computeLinearAttenuation(worldModelPos, distToModel) );
01105                         _LightContribution.AttFactor[i]= (uint8)attFactor;
01106                 }
01107 
01108                 // clean.
01109                 setStateFlag(CTransform::IsNeedUpdateFrozenStaticLightSetup, false);
01110         }
01111 
01112 
01113         // see CTransform::clip(), here I am Lightable(), and I have no _AncestorSkeletonModel
01114         // So I am sure that I really need to recompute my ModelLightContributions.
01115         getOwnerScene()->getLightTrav().LightingManager.computeModelLightContributions(this,
01116                 _LightContribution, _LogicInfo);
01117 
01118         // done!
01119         setStateFlag(CTransform::IsNeedUpdateLighting, false);
01120 }

void NL3D::CTransform::traverseLoadBalancing  )  [virtual, inherited]
 

no-op by default

Reimplemented in NL3D::CMeshMultiLodInstance, NL3D::CQuadGridClipManager, NL3D::CRootModel, and NL3D::CTransformShape.

Definition at line 974 of file transform.cpp.

Referenced by NL3D::CLoadBalancingTrav::traverseVisibilityList().

00975 {
00976         // noop
00977 }

void NL3D::CTransform::traverseRender  )  [virtual, inherited]
 

no-op by default

Reimplemented in NL3D::CFlareModel, NL3D::CLandscapeModel, NL3D::CMeshInstance, NL3D::CParticleSystemModel, NL3D::CQuadGridClipManager, NL3D::CRootModel, NL3D::CSkeletonModel, NL3D::CTransformShape, NL3D::CVegetableBlendLayerModel, and NL3D::CWaterModel.

Definition at line 1131 of file transform.cpp.

Referenced by NL3D::CRenderTrav::traverse().

01132 {
01133         // no-op
01134 }

void NL3D::CTransform::unfreezeHRC  )  [inherited]
 

see freezeHRC().

Definition at line 406 of file transform.cpp.

References NL3D::CTransform::_FreezeHRCState, NL3D::CTransform::_HrcParent, NL3D::CTransform::_HrcParentUnfreeze, NL3D::CTransform::_LightedModelIt, NL3D::CLightingManager::eraseStaticLightedModel(), NL3D::CTransform::FreezeHRCStateDisabled, NL3D::CScene::getLightTrav(), NL3D::CTransform::getOwnerScene(), NL3D::CScene::getRoot(), NL3D::CTransform::hrcLinkSon(), NL3D::CTransform::isLightable(), NL3D::CLightTrav::LightingManager, NL3D::CTransform::linkToUpdateList(), nlassert, NL3D::CTransform::QuadGridClipEnabled, NL3D::CTransform::setStateFlag(), and NL3D::CTransform::unlinkFromQuadCluster().

Referenced by NL3D::CSkeletonModel::bindSkin(), NL3D::CMeshBaseInstance::traverseHrc(), and NL3D::CInstanceGroup::unfreezeHRC().

00407 {
00408         // if this model is no HRC frozen disabled
00409         if(_FreezeHRCState!=FreezeHRCStateDisabled)
00410         {
00411                 // if model correctly frozen.
00412                 if(_FreezeHRCState == CTransform::FreezeHRCStateEnabled )
00413                 {
00414                         // Should not be linked : can't link after a freezeHRC
00415                         nlassert (_HrcParent == NULL);
00416 
00417                         // Set as unfreeze else, hrcLinkSon doesn't work
00418                         _FreezeHRCState= FreezeHRCStateDisabled;
00419 
00420                         // Link this model to the previous HRC parent.
00421                         if (_HrcParentUnfreeze)
00422                                 _HrcParentUnfreeze->hrcLinkSon( this );
00423                         else
00424                                 getOwnerScene()->getRoot()->hrcLinkSon( this );
00425 
00426                         // Link this object to the validateList.
00427                         linkToUpdateList();
00428 
00429                         // if lightable()
00430                         if( isLightable() )
00431                         {
00432                                 CLightTrav      &lightTrav= getOwnerScene()->getLightTrav();
00433                                 // Lighting: must remove the object from the quadGrid.
00434                                 // NB: works if _LightedModelIt==NULL. result is that _LightedModelIt= NULL.
00435                                 _LightedModelIt= lightTrav.LightingManager.eraseStaticLightedModel(_LightedModelIt);
00436                         }
00437 
00438                 }
00439                 else
00440                         _FreezeHRCState= FreezeHRCStateDisabled;
00441 
00442                 // unlink me from any QuadCluster, and disable QuadCluster
00443                 unlinkFromQuadCluster();
00444                 setStateFlag(QuadGridClipEnabled, false);
00445         }
00446 }

void NL3D::CTransform::unfreezeStaticLightSetup  )  [inherited]
 

unFreeze the Static Light Setup. Must be called if static pointLights are deleted. NB: it calls resetLighting() first. NB: do not need to call it if pointLights and this transform are deleted at same time.

Definition at line 1061 of file transform.cpp.

References NL3D::CTransform::_LightContribution, NL3D::CLightContribution::FrozenAmbientLight, NL3D::CLightContribution::FrozenStaticLightSetup, NL3D::CTransform::IsNeedUpdateFrozenStaticLightSetup, NL3D::CLightContribution::NumFrozenStaticLight, NL3D::CLightContribution::PointLight, NL3D::CTransform::resetLighting(), and NL3D::CTransform::setStateFlag().

Referenced by NL3D::CInstanceGroup::removeFromScene().

01062 {
01063         // resetLighting() first.
01064         resetLighting();
01065 
01066         // Disable StaticLightSetup.
01067         _LightContribution.FrozenStaticLightSetup= false;
01068         _LightContribution.NumFrozenStaticLight= 0;
01069         // End the list
01070         _LightContribution.PointLight[0]= NULL;
01071         // No more FrozenAmbientLight
01072         _LightContribution.FrozenAmbientLight= NULL;
01073 
01074         // Don't need to update StaticLightSetup since no more exist.
01075         setStateFlag(IsNeedUpdateFrozenStaticLightSetup, false);
01076 }

virtual void NL3D::CTransform::unlinkFromQuadCluster  )  [inline, protected, virtual, inherited]
 

special feature for CQuadGridClipManager. called at unfreezeHRC(). Used by CTransformShape.

Reimplemented in NL3D::CTransformShape.

Definition at line 561 of file transform.h.

Referenced by NL3D::CTransform::unfreezeHRC().

00561 {}

void NL3D::CCamera::update  )  [protected, virtual]
 

Implement the update method.

Reimplemented from NL3D::CTransform.

Definition at line 164 of file camera.cpp.

References _Fov, _FovAnimationAspectRatio, _FovAnimationEnabled, _Frustum, _Roll, _Target, _TargetAnimationEnabled, NL3D::CFrustum::Far, FovValue, NL3D::ITransformable::lookAt(), NL3D::CFrustum::Near, RollValue, setPerspective(), TargetValue, NL3D::CAnimatedValueBlendable< T >::Value, and NL3D::CAnimatedValueBlendable< float >::Value.

00165 {
00166         // test animations
00167         if(IAnimatable::isTouched(OwnerBit) || IAnimatable::isTouched(ITransformable::OwnerBit))
00168         {
00169                 // FOV.
00170                 if( _FovAnimationEnabled && IAnimatable::isTouched(FovValue))
00171                 {
00172                         // keep the same near/far.
00173                         setPerspective(_Fov.Value, _FovAnimationAspectRatio, _Frustum.Near, _Frustum.Far);
00174                         IAnimatable::clearFlag(FovValue);
00175                 }
00176 
00177                 // Target / Roll.
00178                 // If target/Roll is animated, compute our own quaternion.
00179                 if( _TargetAnimationEnabled && (IAnimatable::isTouched(TargetValue) || IAnimatable::isTouched(RollValue) || IAnimatable::isTouched(PosValue)) )
00180                 {
00181                         lookAt (getPos (), _Target.Value, -_Roll.Value);
00182 
00183                         IAnimatable::clearFlag(TargetValue);
00184                         IAnimatable::clearFlag(RollValue);
00185                 }
00186         }
00187 
00188         CTransform::update();
00189 
00190         // We are OK!
00191         IAnimatable::clearFlag(OwnerBit);
00192 }

void NL3D::CTransform::updateClipTravForAncestorSkeleton  )  [protected, inherited]
 

Definition at line 748 of file transform.cpp.

References NL3D::CTransform::_AncestorSkeletonModel, NL3D::CTransform::_ClipLinkedInSonsOfAncestorSkeletonModelGroup, NL3D::CTransform::clipAddChild(), NL3D::CTransform::clipGetNumParents(), NL3D::CTransform::clipGetParent(), NL3D::CTransform::clipUnlinkFromAll(), NL3D::CScene::getClipTrav(), NL3D::CTransform::getOwnerScene(), NL3D::CScene::getRoot(), and NL3D::CScene::SonsOfAncestorSkeletonModelGroup.

Referenced by NL3D::CTransform::updateWorld().

00749 {
00750         CClipTrav               &clipTrav= getOwnerScene()->getClipTrav();
00751 
00752         // If I have an ancestor Skeleton Model, I must be binded in ClipTrav to the SonsOfAncestorSkeletonModelGroup
00753         if(_AncestorSkeletonModel && !_ClipLinkedInSonsOfAncestorSkeletonModelGroup)
00754         {
00755                 // must unlink from ALL olds models.
00756                 clipUnlinkFromAll();
00757 
00758                 // And link to SonsOfAncestorSkeletonModelGroup.
00759                 getOwnerScene()->SonsOfAncestorSkeletonModelGroup->clipAddChild(this);
00760 
00761                 // update the flag.
00762                 _ClipLinkedInSonsOfAncestorSkeletonModelGroup= true;
00763         }
00764 
00765 
00766         // else I must be binded to the standard Root.
00767         if(!_AncestorSkeletonModel && _ClipLinkedInSonsOfAncestorSkeletonModelGroup)
00768         {
00769                 // verify first I am really still linked to the SonsOfAncestorSkeletonModelGroup.
00770                 // This test is important, because link may have changed for any reason (portals, clipManager....).
00771                 if( clipGetNumParents() == 1 && clipGetParent(0)==getOwnerScene()->SonsOfAncestorSkeletonModelGroup )
00772                 {
00773                         // must unlink from ALL olds models.
00774                         clipUnlinkFromAll();
00775                         // and now, link to std root.
00776                         getOwnerScene()->getRoot()->clipAddChild(this);
00777                 }
00778 
00779                 // update the flag
00780                 _ClipLinkedInSonsOfAncestorSkeletonModelGroup= false;
00781         }
00782 }

void NL3D::CTransform::updateWorld  )  [protected, inherited]
 

Update the world state according to the parent world state and the local states.

Definition at line 663 of file transform.cpp.

References NL3D::CTransform::_AncestorSkeletonModel, NL3D::CTransform::_DontUnfreezeChildren, NL3D::CTransform::_FatherSkeletonModel, NL3D::CTransform::_Frozen, NL3D::CTransform::_HrcParent, NL3D::CTransform::_LightContribution, NL3D::CTransform::_LocalDate, NL3D::CTransform::_LocalMatrix, NL3D::CTransform::_LocalVis, NL3D::CHrcTrav::_MovingObjects, NL3D::CTransform::_WorldDate, NL3D::CTransform::_WorldMatrix, NL3D::CTransform::_WorldVis, NL3D::CHrcTrav::CurrentDate, NL3D::CTransform::ForceClipRoot, NL3D::CLightContribution::FrozenStaticLightSetup, NL3D::CScene::getHrcTrav(), NL3D::CTransform::getOwnerScene(), NL3D::CTransform::getStateFlag(), NL3D::CTransform::isLightable(), NL3D::CTransform::isTransformShape(), NL3D::CTransform::resetLighting(), and NL3D::CTransform::updateClipTravForAncestorSkeleton().

Referenced by NL3D::CTransform::traverseHrc().

00664 {
00665         const   CMatrix         *pFatherWM;
00666         bool                            visFather;
00667 
00668         // If not root case, link to Fahter.
00669         if(_HrcParent)
00670         {
00671                 pFatherWM= &(_HrcParent->_WorldMatrix);
00672                 visFather= _HrcParent->_WorldVis;
00673 
00674                 // if _HrcParent is not frozen (for any reason), disable us!
00675 
00676                 if (!_HrcParent->_Frozen && !_HrcParent->_DontUnfreezeChildren)
00677                         _Frozen= false;
00678 
00679                 // herit _AncestorSkeletonModel
00680                 if (_HrcParent->_AncestorSkeletonModel)
00681                         // If my father has an _AncestorSkeletonModel, get it.
00682                         _AncestorSkeletonModel= _HrcParent->_AncestorSkeletonModel;
00683                 else
00684                         // else I have an ancestor skel model if I am sticked/binded directly to a skeleton model.
00685                         _AncestorSkeletonModel= _FatherSkeletonModel;
00686         }
00687         // else, default!!
00688         else
00689         {
00690                 pFatherWM= &(CMatrix::Identity);
00691                 visFather= true;
00692 
00693                 // at the root of the hierarchy, we have no parent, hence no FatherSkeletonModel nor _AncestorSkeletonModel.
00694                 _AncestorSkeletonModel= NULL;
00695 
00696                 // NB: Root is Frozen by essence :), so don't modify the frozen state here.
00697         }
00698 
00699         // Combine matrix
00700         if(_LocalDate>_WorldDate || (_HrcParent && _HrcParent->_WorldDate>_WorldDate) )
00701         {
00702                 // Must recompute the world matrix.  ONLY IF I AM NOT SKINNED/STICKED TO A SKELETON in the hierarchy!
00703                 if( _AncestorSkeletonModel==NULL )
00704                 {
00705                         _WorldMatrix=  *pFatherWM * _LocalMatrix;
00706                         _WorldDate= getOwnerScene()->getHrcTrav().CurrentDate;
00707 
00708                         // Add the model to the moving object list, only if I am a transform shape
00709                         if (!_Frozen && isTransformShape() && !getStateFlag(ForceClipRoot))
00710                                 getOwnerScene()->getHrcTrav()._MovingObjects.push_back (static_cast<CTransformShape*>(this));
00711                 }
00712         }
00713 
00714         // Update dynamic lighting.
00715         /*
00716                 If the model is not frozen in StaticLight, then must update lighting each frame.
00717                 Even if the object doesn't move, a new dynamic light may enter in its aera. Hence we must test
00718                 it in the light quadrid. StaticLight-ed Objects don't need it because they are inserted in a special quadgrid, 
00719                 where dynamics lights touch all StaticLight-ed object to force their computing
00720 
00721                 NB: not done if _AncestorSkeletonModel!=NULL. no need because  in this case, 
00722                 result is driven by the _LightContribution of the _AncestorSkeletonModel.
00723         */
00724         if( !_LightContribution.FrozenStaticLightSetup && _AncestorSkeletonModel==NULL )
00725         {
00726                 // if the model is lightable reset lighting
00727                 if( isLightable() )
00728                         resetLighting();
00729         }
00730 
00731         // Combine visibility.
00732         switch(_LocalVis)
00733         {
00734                 case CHrcTrav::Herit: _WorldVis= visFather; break;
00735                 case CHrcTrav::Hide: _WorldVis= false; break;
00736                 case CHrcTrav::Show: _WorldVis= true; break;
00737                 default: break;
00738         }
00739 
00740 
00741         // If I have an ancestor Skeleton Model, I must be binded in ClipTrav to the SonsOfAncestorSkeletonModelGroup
00742         updateClipTravForAncestorSkeleton();
00743 
00744 }

void NL3D::CTransform::updateWorldMatrixFromFather  )  [protected, inherited]
 

For Skeleton Object Stick. update the wolrd matrix. no-op if skinned. no-op if no AcnestorSkeletonModel. use standard father WorldMatrix if !_FatherSkeletonModel else get the correct boneId WorldMatrix from _FatherSkeletonModel

Definition at line 905 of file transform.cpp.

References NL3D::CTransform::_AncestorSkeletonModel, NL3D::CTransform::_FatherBoneId, NL3D::CTransform::_FatherSkeletonModel, NL3D::CTransform::_LocalMatrix, NL3D::CTransform::_WorldMatrix, NL3D::CSkeletonModel::Bones, NL3D::CTransform::hrcGetParent(), and NL3D::CTransform::isSkinned().

Referenced by NL3D::CTransform::forceCompute(), and NL3D::CTransform::traverseAnimDetail().

00906 {
00907         // If I am not skinned, and If I have a skeleton ancestor
00908         if(!isSkinned() && _AncestorSkeletonModel )
00909         {
00910                 // Compute the HRC _WorldMatrix.
00911                 // if I am not sticked.
00912                 if(!_FatherSkeletonModel)
00913                 {
00914                         // get the normal father worldMatrix in Hrc.
00915                         CTransform      *fatherTransform= hrcGetParent();
00916                         // if exist
00917                         if(fatherTransform)
00918                         {
00919                                 const CMatrix &parentWM= fatherTransform->_WorldMatrix;
00920                                 // combine worldMatrix
00921                                 _WorldMatrix= parentWM * _LocalMatrix;
00922                         }
00923                         else
00924                                 _WorldMatrix= _LocalMatrix;
00925                 }
00926                 else
00927                 {
00928                         // get the worldMatrix of the bone if I am sticked.
00929                         const CMatrix &parentWM= _FatherSkeletonModel->Bones[_FatherBoneId].getWorldMatrix();
00930                         // combine worldMatrix
00931                         _WorldMatrix= parentWM * _LocalMatrix;
00932                 }
00933         }
00934 }

bool NL3D::CTransform::useMergedPointLight  )  const [inline, inherited]
 

return true if the current light contribution of this model use a MergedPointLight

Definition at line 369 of file transform.h.

References NL3D::CTransform::_LightContribution, and NL3D::CLightContribution::UseMergedPointLight.

00369 {return _LightContribution.UseMergedPointLight;}


Friends And Related Function Documentation

friend struct CPtrInfo [friend, inherited]
 

Definition at line 67 of file smart_ptr.h.


Field Documentation

CSkeletonModel* NL3D::CTransform::_AncestorSkeletonModel [protected, inherited]
 

Definition at line 851 of file transform.h.

Referenced by NL3D::CClipTrav::clipSkeletonShadowMaps(), NL3D::CTransform::CTransform(), NL3D::CTransform::getAncestorSkeletonModel(), NL3D::CAnimDetailTrav::traverse(), NL3D::CTransform::traverseClip(), NL3D::CTransform::updateClipTravForAncestorSkeleton(), NL3D::CTransform::updateWorld(), and NL3D::CTransform::updateWorldMatrixFromFather().

sint64 NL3D::CTransform::_ClipDate [protected, inherited]
 

date of last traverseClip()

Definition at line 865 of file transform.h.

Referenced by NL3D::CTransform::CTransform(), and NL3D::CTransform::traverseClip().

bool NL3D::CTransform::_ClipLinkedInSonsOfAncestorSkeletonModelGroup [protected, inherited]
 

Definition at line 849 of file transform.h.

Referenced by NL3D::CSkeletonModel::bindSkin(), NL3D::CTransform::CTransform(), and NL3D::CTransform::updateClipTravForAncestorSkeleton().

CTrackDefaultVector NL3D::CCamera::_DefaultPos [private]
 

Definition at line 252 of file camera.h.

Referenced by build(), getDefaultPos(), and getDefaultTrack().

CTrackDefaultVector NL3D::CCamera::_DefaultTargetPos [private]
 

Definition at line 253 of file camera.h.

Referenced by build(), getDefaultTargetPos(), and getDefaultTrack().

bool NL3D::CTransform::_DontUnfreezeChildren [protected, inherited]
 

Definition at line 848 of file transform.h.

Referenced by NL3D::CTransform::CTransform(), NL3D::CTransform::setDontUnfreezeChildren(), and NL3D::CTransform::updateWorld().

uint NL3D::CTransform::_FatherBoneId [protected, inherited]
 

Deriver must change this method if isSkinnable(). It return a list of sphere relative to each bone of the father skeleton. Use with getSkinBoneUsage() to know to wich bone this sphere apply NB: if a sphere radius is -1, it means that the bone is not used (for any reason...) default is to return NULL.

Definition at line 618 of file transform.h.

Referenced by NL3D::CSkeletonModel::computeCLodVertexAlpha(), NL3D::CSkeletonModel::detachSkeletonSon(), NL3D::CTransform::forceCompute(), NL3D::CSkeletonModel::stickObjectEx(), and NL3D::CTransform::updateWorldMatrixFromFather().

CSkeletonModel* NL3D::CTransform::_FatherSkeletonModel [protected, inherited]
 

Deriver must change this method if isSkinnable(). It return a list of sphere relative to each bone of the father skeleton. Use with getSkinBoneUsage() to know to wich bone this sphere apply NB: if a sphere radius is -1, it means that the bone is not used (for any reason...) default is to return NULL.

Definition at line 616 of file transform.h.

Referenced by NL3D::CSkeletonModel::bindSkin(), NL3D::CTransform::CTransform(), NL3D::CSkeletonModel::detachSkeletonSon(), NL3D::CTransform::forceCompute(), NL3D::CSkeletonModel::forceComputeBone(), NL3D::CTransform::getSkeletonModel(), NL3D::CTransform::heritVisibility(), NL3D::CTransform::hide(), NL3D::CTransform::registerToChannelMixer(), NL3D::CTransform::setIsForceAnimDetail(), NL3D::CTransform::setOpacity(), NL3D::CTransform::setTransparency(), NL3D::CTransform::show(), NL3D::CSkeletonModel::stickObjectEx(), NL3D::CTransform::traverseClip(), NL3D::CTransform::updateWorld(), NL3D::CTransform::updateWorldMatrixFromFather(), and NL3D::CTransform::~CTransform().

CAnimatedValueFloat NL3D::CCamera::_Fov [private]
 

Definition at line 248 of file camera.h.

Referenced by CCamera(), getFov(), getValue(), setFov(), and update().

float NL3D::CCamera::_FovAnimationAspectRatio [private]
 

Definition at line 245 of file camera.h.

Referenced by CCamera(), enableFovAnimation(), and update().

bool NL3D::CCamera::_FovAnimationEnabled [private]
 

Definition at line 243 of file camera.h.

Referenced by CCamera(), enableFovAnimation(), getFov(), setFov(), and update().

bool NL3D::CTransform::_Frozen [protected, inherited]
 

Definition at line 847 of file transform.h.

Referenced by NL3D::CTransform::CTransform(), NL3D::CTransform::freeze(), NL3D::CTransform::freezeHRC(), NL3D::CTransform::update(), and NL3D::CTransform::updateWorld().

CFrustum NL3D::CCamera::_Frustum [protected]
 

Definition at line 231 of file camera.h.

Referenced by buildCameraPyramid(), getFrustum(), isOrtho(), isPerspective(), setFrustum(), setPerspective(), and update().

sint NL3D::CTransform::_IndexInVisibleList [protected, inherited]
 

date of last traverseClip()

Definition at line 869 of file transform.h.

Referenced by NL3D::CClipTrav::addVisibleModel(), NL3D::CTransform::CTransform(), and NL3D::CTransform::~CTransform().

CLightContribution NL3D::CTransform::_LightContribution [protected, inherited]
 

The contribution of all lights. This enlarge the struct only of approx 15%.

Definition at line 626 of file transform.h.

Referenced by NL3D::CTransform::freezeStaticLightSetup(), NL3D::CTransform::getLightContribution(), NL3D::CSkeletonModel::renderSkins(), NL3D::CTransform::resetLighting(), NL3D::CTransform::traverseLight(), NL3D::CTransform::unfreezeStaticLightSetup(), NL3D::CTransform::updateWorld(), and NL3D::CTransform::useMergedPointLight().

CLightingManager::CQGItLightedModel NL3D::CTransform::_LightedModelIt [protected, inherited]
 

each transform may be in a quadGird of lighted models (see CLightingManager)

Definition at line 634 of file transform.h.

Referenced by NL3D::CTransform::unfreezeHRC(), NL3D::CTransform::update(), and NL3D::CTransform::~CTransform().

CLoadBalancingGroup* NL3D::CTransform::_LoadBalancingGroup [protected, inherited]
 

Definition at line 894 of file transform.h.

Referenced by NL3D::CTransform::CTransform(), NL3D::CTransform::getLoadBalancingGroup(), NL3D::CTransform::initModel(), and NL3D::CTransform::setLoadBalancingGroup().

sint64 NL3D::CTransform::_LocalDate [protected, inherited]
 

Definition at line 841 of file transform.h.

Referenced by NL3D::CTransform::CTransform(), NL3D::CTransform::update(), and NL3D::CTransform::updateWorld().

CMatrix NL3D::CTransform::_LocalMatrix [protected, inherited]
 

Hrc IN variables.

Reimplemented from NL3D::ITransformable.

Definition at line 839 of file transform.h.

Referenced by NL3D::CTransform::CTransform(), NL3D::CTransform::update(), NL3D::CTransform::updateWorld(), and NL3D::CTransform::updateWorldMatrixFromFather().

CHrcTrav::TVisibility NL3D::CTransform::_LocalVis [protected, inherited]
 

Definition at line 840 of file transform.h.

Referenced by NL3D::CTransform::CTransform(), NL3D::CTransform::update(), and NL3D::CTransform::updateWorld().

uint32 NL3D::CTransform::_RenderFilterType [protected, inherited]
 

State for renderFiltering. Default is 0xFFFFFFFF (always displayed) Deriver work to change this value

Definition at line 830 of file transform.h.

Referenced by NL3D::CTransform::CTransform(), and NL3D::CTransform::traverseClip().

CAnimatedValueFloat NL3D::CCamera::_Roll [private]
 

Definition at line 250 of file camera.h.

Referenced by CCamera(), enableTargetAnimation(), getRoll(), getValue(), setRoll(), and update().

CAnimatedValueVector NL3D::CCamera::_Target [private]
 

Definition at line 249 of file camera.h.

Referenced by CCamera(), getTargetPos(), getValue(), setTargetPos(), and update().

bool NL3D::CCamera::_TargetAnimationEnabled [private]
 

Definition at line 244 of file camera.h.

Referenced by CCamera(), enableTargetAnimation(), getRoll(), getTargetPos(), setRoll(), setTargetPos(), and update().

bool NL3D::CTransform::_Visible [protected, inherited]
 

set to true is the object is visible (not clipped).

Definition at line 867 of file transform.h.

Referenced by NL3D::CTransform::CTransform(), NL3D::CTransform::isClipVisible(), and NL3D::CTransform::traverseClip().

sint64 NL3D::CTransform::_WorldDate [protected, inherited]
 

Definition at line 845 of file transform.h.

Referenced by NL3D::CTransform::CTransform(), NL3D::CTransform::hrcLinkSon(), NL3D::CTransform::hrcUnlink(), and NL3D::CTransform::updateWorld().

CMatrix NL3D::CTransform::_WorldMatrix [protected, inherited]
 

Hrc OUT variables.

Definition at line 843 of file transform.h.

Referenced by NL3D::CTransform::updateWorld(), and NL3D::CTransform::updateWorldMatrixFromFather().

bool NL3D::CTransform::_WorldVis [protected, inherited]
 

Definition at line 844 of file transform.h.

Referenced by NL3D::CTransform::CTransform(), NL3D::CTransform::isHrcVisible(), NL3D::CTransform::traverseClip(), and NL3D::CTransform::updateWorld().

sint NLMISC::CRefCount::crefs [mutable, inherited]
 

Definition at line 79 of file smart_ptr.h.

Referenced by NLMISC::CRefCount::CRefCount(), NLMISC::CRefCount::getRefCount(), and NLMISC::CRefCount::~CRefCount().

CTrackDefaultFloat NL3D::CCamera::DefaultFov [static, private]
 

Referenced by getDefaultTrack().

CTrackDefaultFloat NL3D::CCamera::DefaultRoll [static, private]
 

Referenced by getDefaultTrack().

CRefCount::CPtrInfo NLMISC::CRefCount::NullPtrInfo [static, inherited]
 

Referenced by NLMISC::CRefCount::CRefCount().

CPtrInfo* NLMISC::CRefCount::pinfo [mutable, inherited]
 

Definition at line 80 of file smart_ptr.h.

Referenced by NLMISC::CRefCount::CRefCount(), and NLMISC::CRefCount::~CRefCount().


The documentation for this class was generated from the following files:
Generated on Tue Mar 16 06:44:51 2004 for NeL by doxygen 1.3.6