// NeL - MMORPG Framework
// Copyright (C) 2010 Winch Gate Property Limited
//
// This program is free software: you can redistribute it and/or modify
// it under the terms of the GNU Affero General Public License as
// published by the Free Software Foundation, either version 3 of the
// License, or (at your option) any later version.
//
// This program is distributed in the hope that it will be useful,
// but WITHOUT ANY WARRANTY; without even the implied warranty of
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
// GNU Affero General Public License for more details.
//
// You should have received a copy of the GNU Affero General Public License
// along with this program. If not, see .
#include "std3d.h"
#include "nel/3d/u_transform.h"
#include "nel/3d/transform.h"
#include "nel/3d/instance_group_user.h"
#include "nel/misc/hierarchical_timer.h"
#include "nel/3d/scene_group.h"
#include "nel/3d/scene.h"
H_AUTO_DECL( NL3D_Transform_Set_Cluster_System )
#define NL3D_HAUTO_SET_CLUSTER_SYSTEM H_AUTO_USE( NL3D_Transform_Set_Cluster_System )
using namespace NLMISC;
#ifdef DEBUG_NEW
#define new DEBUG_NEW
#endif
namespace NL3D
{
// ***************************************************************************
void UTransform::setClusterSystem (UInstanceGroup *pIG)
{
NL3D_HAUTO_SET_CLUSTER_SYSTEM
CTransform *object = getObjectPtr();
if (object->getForceClipRoot())
{
nlwarning("Transform has been flagged to be glued to the root, and thus can't be clusterized. See UTransform::setForceClipRoot(bool).");
return;
}
if ((pIG == NULL) || (pIG == (UInstanceGroup*)-1))
{
if (pIG == NULL)
object->setClusterSystem (NULL);
else
object->setClusterSystem ((CInstanceGroup*)-1);
}
else
object->setClusterSystem (&((CInstanceGroupUser*)pIG)->getInternalIG());
}
// ***************************************************************************
UInstanceGroup *UTransform::getClusterSystem () const
{
CTransform *object = getObjectPtr();
CInstanceGroup *ig= object->getClusterSystem();
if(ig==((CInstanceGroup*)-1))
return ((UInstanceGroup*)-1);
else if(ig==NULL)
return NULL;
else
return ig->getUserInterface();
}
// ***************************************************************************
void UTransform::getLastParentClusters(std::vector &clusters) const
{
CTransform *object = getObjectPtr();
CScene *scene = object->getOwnerScene();
// look in the list of parent of the transform object and extract the CCluster parents
if (scene == NULL)
return;
CClipTrav &clipTrav= scene->getClipTrav();
uint num= object->clipGetNumParents();
for(uint i=0;i(object->clipGetParent(i));
if (pcluster != NULL)
clusters.push_back(pcluster);
}
// If the object is link to a QuadCluster, add the RootCluster to the list
CTransformShape *trShp= dynamic_cast( object );
if( trShp && trShp->isLinkToQuadCluster() )
clusters.push_back(clipTrav.RootCluster);
}
// ***************************************************************************
void UTransform::freezeHRC()
{
CTransform *object = getObjectPtr();
object->freezeHRC();
}
// ***************************************************************************
void UTransform::unfreezeHRC()
{
CTransform *object = getObjectPtr();
while (object)
{
object->unfreezeHRC();
object = object->hrcGetParent();
}
}
// ***************************************************************************
void UTransform::setLoadBalancingGroup(const std::string &group)
{
CTransform *object = getObjectPtr();
object->setLoadBalancingGroup(group);
}
// ***************************************************************************
const std::string &UTransform::getLoadBalancingGroup() const
{
CTransform *object = getObjectPtr();
return object->getLoadBalancingGroup();
}
// ***************************************************************************
void UTransform::setMeanColor(NLMISC::CRGBA color)
{
CTransform *object = getObjectPtr();
object->setMeanColor(color);
}
// ***************************************************************************
NLMISC::CRGBA UTransform::getMeanColor() const
{
CTransform *object = getObjectPtr();
return object->getMeanColor();
}
// ***************************************************************************
const CMatrix &UTransform::getLastWorldMatrixComputed() const
{
CTransform *object = getObjectPtr();
return object->getWorldMatrix();
}
// ***************************************************************************
void UTransform::enableCastShadowMap(bool state)
{
CTransform *object = getObjectPtr();
object->enableCastShadowMap(state);
}
// ***************************************************************************
bool UTransform::canCastShadowMap() const
{
CTransform *object = getObjectPtr();
return object->canCastShadowMap();
}
// ***************************************************************************
void UTransform::enableReceiveShadowMap(bool state)
{
CTransform *object = getObjectPtr();
object->enableReceiveShadowMap(state);
}
// ***************************************************************************
bool UTransform::canReceiveShadowMap() const
{
CTransform *object = getObjectPtr();
return object->canReceiveShadowMap();
}
// ***************************************************************************
void UTransform::parent(UTransform newFather)
{
CTransform *object = getObjectPtr();
if (object->getForceClipRoot())
{
nlwarning("Transform has been flagged to be glued to the root, can't change parent. See UTransform::setForceClipRoot(bool).");
return;
}
if(!newFather.empty())
{
// link me to other.
CTransform *other= newFather.getObjectPtr();
if(other->getOwnerScene()!=object->getOwnerScene())
nlerror("Try to parent 2 object from 2 differnet scenes!!");
other->hrcLinkSon( object );
}
else
{
// link me to Root.
object->getOwnerScene()->getRoot()->hrcLinkSon( object );
}
}
// ***************************************************************************
void UTransform::hide()
{
CTransform *object = getObjectPtr();
object->hide();
}
// ***************************************************************************
void UTransform::show()
{
CTransform *object = getObjectPtr();
object->show();
}
// ***************************************************************************
void UTransform::setUserClipping(bool enable)
{
CTransform *object = getObjectPtr();
object->setUserClipping(enable);
}
// ***************************************************************************
bool UTransform::getUserClipping() const
{
CTransform *object = getObjectPtr();
return object->getUserClipping();
}
// ***************************************************************************
void UTransform::heritVisibility()
{
CTransform *object = getObjectPtr();
object->heritVisibility();
}
// ***************************************************************************
UTransform::TVisibility UTransform::getVisibility()
{
CTransform *object = getObjectPtr();
return (UTransform::TVisibility)(uint32)object->getVisibility();
}
// ***************************************************************************
void UTransform::setOrderingLayer(uint layer)
{
CTransform *object = getObjectPtr();
object->setOrderingLayer(layer);
}
// ***************************************************************************
uint UTransform::getOrderingLayer() const
{
CTransform *object = getObjectPtr();
return object->getOrderingLayer();
}
// ***************************************************************************
void UTransform::setUserLightable(bool enable)
{
CTransform *object = getObjectPtr();
object->setUserLightable(enable);
}
// ***************************************************************************
bool UTransform::getUserLightable() const
{
CTransform *object = getObjectPtr();
return object->getUserLightable();
}
// ***************************************************************************
void UTransform::setLogicInfo(ILogicInfo *logicInfo)
{
CTransform *object = getObjectPtr();
object->setLogicInfo(logicInfo);
}
// ***************************************************************************
bool UTransform::getLastWorldVisState() const
{
CTransform *object = getObjectPtr();
return object->isHrcVisible();
}
// ***************************************************************************
bool UTransform::getLastClippedState() const
{
CTransform *object = getObjectPtr();
return object->isClipVisible();
}
// ***************************************************************************
void UTransform::setTransparency(bool v)
{
CTransform *object = getObjectPtr();
object->setTransparency(v);
}
// ***************************************************************************
void UTransform::setOpacity(bool v)
{
CTransform *object = getObjectPtr();
object->setOpacity(v);
}
// ***************************************************************************
void UTransform::setBypassLODOpacityFlag(bool bypass)
{
CTransform *object = getObjectPtr();
object->setBypassLODOpacityFlag(bypass);
}
// ***************************************************************************
uint32 UTransform::isOpaque()
{
CTransform *object = getObjectPtr();
return object->isOpaque();
}
// ***************************************************************************
uint32 UTransform::isTransparent()
{
CTransform *object = getObjectPtr();
return object->isTransparent();
}
// ***************************************************************************
void UTransform::setForceClipRoot(bool forceClipRoot)
{
CTransform *object = getObjectPtr();
object->setForceClipRoot(forceClipRoot);
}
// ***************************************************************************
bool UTransform::getForceClipRoot() const
{
CTransform *object = getObjectPtr();
return object->getForceClipRoot();
}
// ***************************************************************************
void UTransform::setTransparencyPriority(uint8 priority)
{
CTransform *object = getObjectPtr();
object->setTransparencyPriority(priority);
}
// ***************************************************************************
void UTransform::setShadowMapDirectionZThreshold(float zthre)
{
CTransform *object = getObjectPtr();
object->setShadowMapDirectionZThreshold(zthre);
}
// ***************************************************************************
float UTransform::getShadowMapDirectionZThreshold() const
{
CTransform *object = getObjectPtr();
return object->getShadowMapDirectionZThreshold();
}
// ***************************************************************************
void UTransform::setShadowMapMaxDepth(float depth)
{
CTransform *object = getObjectPtr();
object->setShadowMapMaxDepth(depth);
}
// ***************************************************************************
float UTransform::getShadowMapMaxDepth() const
{
CTransform *object = getObjectPtr();
return object->getShadowMapMaxDepth();
}
// ***************************************************************************
bool UTransform::supportFastIntersect() const
{
CTransform *object = getObjectPtr();
return object->supportFastIntersect();
}
// ***************************************************************************
bool UTransform::fastIntersect(const NLMISC::CVector &p0, const NLMISC::CVector &dir, float &dist2D, float &distZ, bool computeDist2D)
{
CTransform *object = getObjectPtr();
return object->fastIntersect(p0, dir, dist2D, distZ, computeDist2D);
}
} // NL3D