2010-09-29 19:23:16 -04:00
|
|
|
//
|
|
|
|
// SuperTuxKart - a fun racing game with go-kart
|
|
|
|
// Copyright (C) 2010 Joerg Henrichs
|
|
|
|
//
|
|
|
|
// 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, write to the Free Software
|
|
|
|
// Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
|
|
|
|
|
|
|
|
#include "tracks/check_lap.hpp"
|
|
|
|
|
|
|
|
#include <string>
|
|
|
|
|
|
|
|
#include "io/xml_node.hpp"
|
2012-03-19 16:21:11 -04:00
|
|
|
#include "karts/abstract_kart.hpp"
|
2010-09-29 19:23:16 -04:00
|
|
|
#include "modes/linear_world.hpp"
|
|
|
|
#include "race/race_manager.hpp"
|
|
|
|
#include "tracks/track.hpp"
|
|
|
|
|
|
|
|
/** Constructor for a lap line.
|
|
|
|
* \param check_manager Pointer to the check manager, which is needed when
|
|
|
|
* resetting e.g. new lap counters.
|
|
|
|
* \param node XML node containing the parameters for this checkline.
|
|
|
|
*/
|
2012-02-12 16:25:06 -05:00
|
|
|
CheckLap::CheckLap(const XMLNode &node, unsigned int index)
|
|
|
|
: CheckStructure(node, index)
|
2010-09-29 19:23:16 -04:00
|
|
|
{
|
|
|
|
// Note that when this is called the karts have not been allocated
|
|
|
|
// in world, so we can't call world->getNumKarts()
|
|
|
|
m_previous_distance.resize(race_manager->getNumberOfKarts());
|
|
|
|
} // CheckLap
|
|
|
|
|
|
|
|
// ----------------------------------------------------------------------------
|
|
|
|
void CheckLap::reset(const Track &track)
|
|
|
|
{
|
|
|
|
CheckStructure::reset(track);
|
|
|
|
for(unsigned int i=0; i<m_previous_distance.size(); i++)
|
|
|
|
{
|
|
|
|
m_previous_distance[i] = 0;
|
|
|
|
}
|
|
|
|
} // reset
|
|
|
|
|
|
|
|
// ----------------------------------------------------------------------------
|
|
|
|
/** True if going from old_pos to new_pos crosses this checkline. This function
|
|
|
|
* is called from update (of the checkline structure).
|
|
|
|
* \param old_pos Position in previous frame.
|
|
|
|
* \param new_pos Position in current frame.
|
|
|
|
* \param indx Index of the kart, can be used to store kart specific
|
|
|
|
* additional data.
|
|
|
|
*/
|
2013-03-06 18:12:24 -05:00
|
|
|
bool CheckLap::isTriggered(const Vec3 &old_pos, const Vec3 &new_pos,
|
|
|
|
unsigned int indx)
|
2010-09-29 19:23:16 -04:00
|
|
|
{
|
|
|
|
float track_length = World::getWorld()->getTrack()->getTrackLength();
|
2012-12-16 19:33:47 -05:00
|
|
|
LinearWorld *lin_world = dynamic_cast<LinearWorld*>(World::getWorld());
|
|
|
|
// Can happen if a non-lap based race mode is used with a scene file that
|
|
|
|
// has check defined.
|
|
|
|
if(!lin_world)
|
|
|
|
return false;
|
|
|
|
float current_distance = lin_world->getDistanceDownTrackForKart(indx);
|
2010-09-29 19:23:16 -04:00
|
|
|
bool result =(m_previous_distance[indx]>0.95f*track_length &&
|
2010-11-30 18:34:02 -05:00
|
|
|
current_distance<7.0f);
|
2010-09-29 19:23:16 -04:00
|
|
|
if(UserConfigParams::m_check_debug && result)
|
|
|
|
{
|
|
|
|
printf("CHECK: Kart %s crossed start line from %f to %f.\n",
|
|
|
|
World::getWorld()->getKart(indx)->getIdent().c_str(),
|
|
|
|
m_previous_distance[indx], current_distance);
|
|
|
|
}
|
|
|
|
m_previous_distance[indx] = current_distance;
|
2011-09-11 19:59:49 -04:00
|
|
|
|
2010-09-29 19:23:16 -04:00
|
|
|
return result;
|
|
|
|
} // isTriggered
|