You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

144 lines
3.4 KiB

/*==LICENSE==*
CyanWorlds.com Engine - MMOG client, server and tools
Copyright (C) 2011 Cyan Worlds, Inc.
This program is free software: you can redistribute it and/or modify
it under the terms of the GNU 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 General Public License for more details.
You should have received a copy of the GNU General Public License
along with this program. If not, see <http://www.gnu.org/licenses/>.
You can contact Cyan Worlds, Inc. by email legal@cyan.com
or by snail mail at:
Cyan Worlds, Inc.
14617 N Newport Hwy
Mead, WA 99021
*==LICENSE==*/
#include "hsTypes.h"
#include "plDynaTorpedoMgr.h"
#include "plMessage/plBulletMsg.h"
#include "plCutter.h"
#include "plgDispatch.h"
#include "hsStream.h"
#include "hsResMgr.h"
#include "hsTimer.h"
#include "plTweak.h"
#include "plMath/plRandom.h"
static const UInt32 kNumPrintIDs = 0;
static plRandom sRand;
plDynaTorpedoMgr::plDynaTorpedoMgr()
{
fPartIDs.SetCount(kNumPrintIDs);
}
plDynaTorpedoMgr::~plDynaTorpedoMgr()
{
}
void plDynaTorpedoMgr::Read(hsStream* stream, hsResMgr* mgr)
{
plDynaRippleMgr::Read(stream, mgr);
plgDispatch::Dispatch()->RegisterForExactType(plBulletMsg::Index(), GetKey());
}
hsBool plDynaTorpedoMgr::IHandleShot(plBulletMsg* bull)
{
hsScalar partyTime = fPartyTime;
plConst(int) kNumShots(3);
int i;
for( i = 0; i < kNumShots; i++ )
{
hsVector3 up = IRandomUp(bull->Dir());
hsVector3 pert = bull->Dir() % up;
plConst(hsScalar) kMaxPert(1.f);
hsScalar maxPert = i ? kMaxPert * bull->Radius() : 0;
pert *= sRand.RandMinusOneToOne() * maxPert * fScale.fX;
pert += up * (sRand.RandMinusOneToOne() * maxPert * fScale.fY);
hsPoint3 pos = bull->From() + bull->Dir() * (bull->Range() * 0.5f);
pos += pert;
hsScalar scaleX = bull->Radius() * fScale.fX * fInitUVW.fX;
hsScalar scaleY = bull->Radius() * fScale.fY * fInitUVW.fY;
#if 0
plConst(hsScalar) kMinScale(0.5f);
if( i )
{
scaleX *= sRand.RandRangeF(kMinScale, 1.f);
scaleY *= sRand.RandRangeF(kMinScale, 1.f);
}
#elif 0
hsScalar div = 1.f / (1.f + hsScalar(i));
scaleX *= div;
scaleY *= div;
#else
plConst(hsScalar) kMinScale(0.25f);
plConst(hsScalar) kMaxScale(0.75f);
if( i )
{
hsScalar scale = sRand.RandRangeF(kMinScale, kMaxScale);
scaleX *= scale;
scaleY *= scale;
}
#endif
fCutter->SetLength(hsVector3(scaleX, scaleY, bull->Range()));
fCutter->Set(pos, up, -bull->Dir());
plDynaDecalInfo& info = IGetDecalInfo(UInt32(this), GetKey());
if( bull->PartyTime() > 0 )
fPartyTime = bull->PartyTime();
double secs = hsTimer::GetSysSeconds();
if( ICutoutTargets(secs) )
info.fLastTime = secs;
fPartyTime = 0;
}
fPartyTime = partyTime;
return true;
}
hsBool plDynaTorpedoMgr::MsgReceive(plMessage* msg)
{
plBulletMsg* bullMsg = plBulletMsg::ConvertNoRef(msg);
if( bullMsg )
{
if( bullMsg->Shot() )
{
return IHandleShot(bullMsg);
}
return true;
}
return plDynaRippleMgr::MsgReceive(msg);
}