gremlin/libs/spark/src/Extensions/Emitters/SPK_NormalEmitter.cpp
2011-01-05 23:02:10 +01:00

76 lines
2.7 KiB
C++

//////////////////////////////////////////////////////////////////////////////////
// SPARK particle engine //
// Copyright (C) 2008-2009 - Julien Fryer - julienfryer@gmail.com //
// //
// This software is provided 'as-is', without any express or implied //
// warranty. In no event will the authors be held liable for any damages //
// arising from the use of this software. //
// //
// Permission is granted to anyone to use this software for any purpose, //
// including commercial applications, and to alter it and redistribute it //
// freely, subject to the following restrictions: //
// //
// 1. The origin of this software must not be misrepresented; you must not //
// claim that you wrote the original software. If you use this software //
// in a product, an acknowledgment in the product documentation would be //
// appreciated but is not required. //
// 2. Altered source versions must be plainly marked as such, and must not be //
// misrepresented as being the original software. //
// 3. This notice may not be removed or altered from any source distribution. //
//////////////////////////////////////////////////////////////////////////////////
#include "Extensions/Emitters/SPK_NormalEmitter.h"
#include "Core/SPK_Particle.h"
namespace SPK
{
NormalEmitter::NormalEmitter(Zone* normalZone,bool inverted) :
Emitter(),
normalZone(normalZone),
inverted(inverted)
{}
void NormalEmitter::registerChildren(bool registerAll)
{
Emitter::registerChildren(registerAll);
registerChild(normalZone,registerAll);
}
void NormalEmitter::copyChildren(const NormalEmitter& emitter,bool createBase)
{
Emitter::copyChildren(emitter,createBase);
normalZone = dynamic_cast<Zone*>(copyChild(emitter.normalZone,createBase));
}
void NormalEmitter::destroyChildren(bool keepChildren)
{
destroyChild(normalZone,keepChildren);
Emitter::destroyChildren(keepChildren);
}
Registerable* NormalEmitter::findByName(const std::string& name)
{
Registerable* object = Emitter::findByName(name);
if ((object != NULL)||(normalZone == NULL))
return object;
return normalZone->findByName(name);
}
void NormalEmitter::setNormalZone(Zone* zone)
{
decrementChildReference(normalZone);
incrementChildReference(zone);
normalZone = zone;
}
void NormalEmitter::generateVelocity(Particle& particle,float speed) const
{
if (inverted) speed = -speed;
const Zone* zone = (normalZone == NULL ? getZone() : normalZone);
particle.velocity() = zone->computeNormal(particle.position()) * speed;
}
}