openspades/Sources/Client/Grenade.cpp
2013-08-29 11:45:22 +09:00

112 lines
2.7 KiB
C++

/*
Copyright (c) 2013 yvt
This file is part of OpenSpades.
OpenSpades 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.
OpenSpades 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 OpenSpades. If not, see <http://www.gnu.org/licenses/>.
*/
#include "Grenade.h"
#include "GameMap.h"
#include "World.h"
#include "PhysicsConstants.h"
#include "IWorldListener.h"
#include "../Core/Debug.h"
namespace spades {
namespace client {
Grenade::Grenade(World *w,
Vector3 pos,
Vector3 vel,
float fuse){
SPADES_MARK_FUNCTION();
position = pos;
velocity = vel;
this->fuse = fuse;
world = w;
}
Grenade::~Grenade(){
SPADES_MARK_FUNCTION();
}
bool Grenade::Update(float dt) {
SPADES_MARK_FUNCTION();
fuse -= dt;
if(fuse < 0.f){
Explode();
return true;
}
if(MoveGrenade(dt) == 2){
if(world->GetListener())
world->GetListener()->GrenadeBounced(this);
}
return false;
}
void Grenade::Explode() {
SPADES_MARK_FUNCTION();
if(world->GetListener())
world->GetListener()->GrenadeExploded(this);
}
int Grenade::MoveGrenade(float fsynctics) {
SPADES_MARK_FUNCTION();
float f = fsynctics * 32.f;
Vector3 oldPos = position;
velocity.z += fsynctics;
position += velocity * f;
IntVector3 lp = position.Floor();
IntVector3 lp2 = oldPos.Floor();
GameMap *m = world->GetMap();
if(lp.z >= 63 && lp2.z < 63) {
if(world->GetListener())
world->GetListener()->GrenadeDroppedIntoWater(this);
}
int ret = 0;
if(m->ClipWorld(position.x, position.y, position.z)){
// hit a wall
ret = 1;
if(fabsf(velocity.x) > BOUNCE_SOUND_THRESHOLD ||
fabsf(velocity.y) > BOUNCE_SOUND_THRESHOLD ||
fabsf(velocity.z) > BOUNCE_SOUND_THRESHOLD)
ret = 2;
if (lp.z != lp2.z && ((lp.x == lp2.x && lp.y == lp2.y) ||
!m->ClipWorld(lp.x, lp.y, lp2.z)))
velocity.z = -velocity.z;
else if(lp.x != lp2.x && ((lp.y == lp2.y && lp.z == lp2.z) ||
!m->ClipWorld(lp2.x, lp.y, lp.z)))
velocity.x = -velocity.x;
else if(lp.y != lp2.y && ((lp.x == lp2.x && lp.z == lp2.z) ||
!m->ClipWorld(lp.x, lp2.y, lp.z)))
velocity.y = -velocity.y;
position = oldPos;
velocity *= .36f;
}
return ret;
}
}
}