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.
183 lines
5.6 KiB
183 lines
5.6 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/>. |
|
|
|
Additional permissions under GNU GPL version 3 section 7 |
|
|
|
If you modify this Program, or any covered work, by linking or |
|
combining it with any of RAD Game Tools Bink SDK, Autodesk 3ds Max SDK, |
|
NVIDIA PhysX SDK, Microsoft DirectX SDK, OpenSSL library, Independent |
|
JPEG Group JPEG library, Microsoft Windows Media SDK, or Apple QuickTime SDK |
|
(or a modified version of those libraries), |
|
containing parts covered by the terms of the Bink SDK EULA, 3ds Max EULA, |
|
PhysX SDK EULA, DirectX SDK EULA, OpenSSL and SSLeay licenses, IJG |
|
JPEG Library README, Windows Media SDK EULA, or QuickTime SDK EULA, the |
|
licensors of this Program grant you additional |
|
permission to convey the resulting work. Corresponding Source for a |
|
non-source form of such a combination shall include the source code for |
|
the parts of OpenSSL and IJG JPEG Library used as well as that of the covered |
|
work. |
|
|
|
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==*/ |
|
////////////////////////////////////////////////////////////////////////////// |
|
// // |
|
// plPhysicalSndGroup Class // |
|
// Simplistic container class to store the matchup info for a given // |
|
// physical sound group. Assigning one of these objects to a physical // |
|
// specifies the sound group it's in as well as the sounds it should make // |
|
// when colliding against objects of other sound groups. // |
|
// // |
|
////////////////////////////////////////////////////////////////////////////// |
|
|
|
#include "hsResMgr.h" |
|
#include "plPhysicalSndGroup.h" |
|
#include "plAudio/plSound.h" |
|
#include "pnMessage/plRefMsg.h" |
|
#include "plMessage/plAnimCmdMsg.h" |
|
|
|
|
|
plPhysicalSndGroup::plPhysicalSndGroup() : fPlayingSlideSound(false) |
|
{ |
|
fGroup = kNone; |
|
} |
|
|
|
plPhysicalSndGroup::plPhysicalSndGroup( uint32_t grp ) : fPlayingSlideSound(false) |
|
{ |
|
fGroup = grp; |
|
} |
|
|
|
plPhysicalSndGroup::~plPhysicalSndGroup() |
|
{ |
|
} |
|
|
|
bool plPhysicalSndGroup::HasSlideSound(uint32_t against) |
|
{ |
|
return against < fSlideSounds.GetCount(); |
|
} |
|
|
|
bool plPhysicalSndGroup::HasImpactSound(uint32_t against) |
|
{ |
|
return against < fImpactSounds.GetCount(); |
|
} |
|
|
|
hsBool plPhysicalSndGroup::MsgReceive( plMessage *pMsg ) |
|
{ |
|
return hsKeyedObject::MsgReceive( pMsg ); |
|
} |
|
|
|
void plPhysicalSndGroup::Read( hsStream *s, hsResMgr *mgr ) |
|
{ |
|
hsKeyedObject::Read( s, mgr ); |
|
|
|
s->ReadLE( &fGroup ); |
|
|
|
uint32_t i, count = s->ReadLE32(); |
|
fImpactSounds.Reset(); |
|
|
|
for( i = 0; i < count; i++ ) |
|
fImpactSounds.Append( mgr->ReadKey( s ) ); |
|
|
|
count = s->ReadLE32(); |
|
fSlideSounds.Reset(); |
|
for( i = 0; i < count; i++ ) |
|
fSlideSounds.Append( mgr->ReadKey( s ) ); |
|
|
|
} |
|
|
|
void plPhysicalSndGroup::Write( hsStream *s, hsResMgr *mgr ) |
|
{ |
|
hsKeyedObject::Write( s, mgr ); |
|
|
|
s->WriteLE( fGroup ); |
|
|
|
uint32_t i; |
|
s->WriteLE32( fImpactSounds.GetCount() ); |
|
for( i = 0; i < fImpactSounds.GetCount(); i++ ) |
|
mgr->WriteKey( s, fImpactSounds[ i ] ); |
|
|
|
s->WriteLE32( fSlideSounds.GetCount() ); |
|
for( i = 0; i < fSlideSounds.GetCount(); i++ ) |
|
mgr->WriteKey( s, fSlideSounds[ i ] ); |
|
} |
|
|
|
void plPhysicalSndGroup::AddImpactSound( uint32_t against, plKey receiver ) |
|
{ |
|
if( fImpactSounds.GetCount() <= against ) |
|
{ |
|
fImpactSounds.Expand( against + 1 ); |
|
fImpactSounds.SetCount( against + 1 ); |
|
} |
|
|
|
fImpactSounds[ against ] = receiver; |
|
} |
|
|
|
void plPhysicalSndGroup::AddSlideSound( uint32_t against, plKey receiver ) |
|
{ |
|
if( fSlideSounds.GetCount() <= against ) |
|
{ |
|
fSlideSounds.Expand( against + 1 ); |
|
fSlideSounds.SetCount( against + 1 ); |
|
} |
|
|
|
fSlideSounds[ against ] = receiver; |
|
} |
|
|
|
void plPhysicalSndGroup::PlaySlideSound(uint32_t against) |
|
{ |
|
if(against >= fSlideSounds.Count()) |
|
return; |
|
plAnimCmdMsg* animMsg = TRACKED_NEW plAnimCmdMsg; |
|
animMsg->SetCmd(plAnimCmdMsg::kContinue); |
|
animMsg->Send(fSlideSounds[against]); |
|
fPlayingSlideSound = true; |
|
} |
|
|
|
void plPhysicalSndGroup::StopSlideSound(uint32_t against) |
|
{ |
|
if(against >= fSlideSounds.Count()) |
|
return; |
|
plAnimCmdMsg *animMsg = TRACKED_NEW plAnimCmdMsg; |
|
animMsg->SetCmd(plAnimCmdMsg::kStop); |
|
animMsg->Send(fSlideSounds[against]); |
|
fPlayingSlideSound = false; |
|
} |
|
|
|
void plPhysicalSndGroup::PlayImpactSound(uint32_t against) |
|
{ |
|
if(against >= fImpactSounds.Count()) |
|
return; |
|
plAnimCmdMsg* animMsg = TRACKED_NEW plAnimCmdMsg; |
|
animMsg->SetCmd(plAnimCmdMsg::kContinue); |
|
animMsg->Send(fImpactSounds[against]); |
|
} |
|
|
|
void plPhysicalSndGroup::SetSlideSoundVolume(uint32_t against, float volume) |
|
{ |
|
if(against >= fSlideSounds.Count()) |
|
return; |
|
plAnimCmdMsg* animMsg = TRACKED_NEW plAnimCmdMsg; |
|
animMsg->SetCmd(plAnimCmdMsg::kSetSpeed); |
|
animMsg->fSpeed = volume; |
|
animMsg->Send(fSlideSounds[against]); |
|
|
|
}
|
|
|