Delete old unused file

git-svn-id: svn+ssh://svn.code.sf.net/p/supertuxkart/code/main/trunk@12448 178a84e3-b1eb-0310-8ba1-8eac791a3b58
This commit is contained in:
auria 2013-02-03 22:31:24 +00:00
parent d12254237d
commit a81fe6fbae
4 changed files with 2 additions and 779 deletions

View File

@ -171,7 +171,6 @@ src/states_screens/dialogs/gp_info_dialog.cpp
src/states_screens/dialogs/message_dialog.cpp src/states_screens/dialogs/message_dialog.cpp
src/states_screens/dialogs/player_info_dialog.cpp src/states_screens/dialogs/player_info_dialog.cpp
src/states_screens/dialogs/press_a_key_dialog.cpp src/states_screens/dialogs/press_a_key_dialog.cpp
src/states_screens/dialogs/race_over_dialog.cpp
src/states_screens/dialogs/race_paused_dialog.cpp src/states_screens/dialogs/race_paused_dialog.cpp
src/states_screens/dialogs/select_challenge.cpp src/states_screens/dialogs/select_challenge.cpp
src/states_screens/dialogs/story_mode_new.cpp src/states_screens/dialogs/story_mode_new.cpp
@ -429,7 +428,6 @@ src/states_screens/dialogs/gp_info_dialog.hpp
src/states_screens/dialogs/message_dialog.hpp src/states_screens/dialogs/message_dialog.hpp
src/states_screens/dialogs/player_info_dialog.hpp src/states_screens/dialogs/player_info_dialog.hpp
src/states_screens/dialogs/press_a_key_dialog.hpp src/states_screens/dialogs/press_a_key_dialog.hpp
src/states_screens/dialogs/race_over_dialog.hpp
src/states_screens/dialogs/race_paused_dialog.hpp src/states_screens/dialogs/race_paused_dialog.hpp
src/states_screens/dialogs/select_challenge.hpp src/states_screens/dialogs/select_challenge.hpp
src/states_screens/dialogs/story_mode_new.hpp src/states_screens/dialogs/story_mode_new.hpp

View File

@ -27,7 +27,6 @@
#include "modes/world.hpp" #include "modes/world.hpp"
#include "tracks/track.hpp" #include "tracks/track.hpp"
#include "network/network_manager.hpp" #include "network/network_manager.hpp"
#include "states_screens/dialogs/race_over_dialog.hpp"
#include <irrlicht.h> #include <irrlicht.h>
@ -233,19 +232,9 @@ void WorldStatus::update(const float dt)
break; break;
} }
case RESULT_DISPLAY_PHASE : case RESULT_DISPLAY_PHASE :
{ {
// Wait for the race over GUI/modal dialog to appear
// Previously the in race race over results are shown,
// and getCurrent() returns NULL.
RaceOverDialog *m =
dynamic_cast<RaceOverDialog*>(GUIEngine::ModalDialog
::getCurrent());
if( m && m->menuIsFinished() )
{
m_phase = FINISH_PHASE;
}
break; break;
} }
case FINISH_PHASE: case FINISH_PHASE:
// Nothing to do here. // Nothing to do here.
break; break;

View File

@ -1,710 +0,0 @@
// SuperTuxKart - a fun racing game with go-kart
// Copyright (C) 2009 Marianne Gagnon
//
// 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 "states_screens/dialogs/race_over_dialog.hpp"
#include "challenges/unlock_manager.hpp"
#include "guiengine/engine.hpp"
#include "guiengine/scalable_font.hpp"
#include "guiengine/widgets.hpp"
#include "io/file_manager.hpp"
#include "input/input_manager.hpp"
#include "karts/abstract_kart.hpp"
#include "karts/kart_properties.hpp"
#include "karts/kart_properties_manager.hpp"
#include "modes/overworld.hpp"
#include "modes/three_strikes_battle.hpp"
#include "modes/world.hpp"
#include "modes/world_with_rank.hpp"
#include "network/network_manager.hpp"
#include "race/race_manager.hpp"
#include "states_screens/feature_unlocked.hpp"
#include "states_screens/main_menu_screen.hpp"
#include "states_screens/race_setup_screen.hpp"
#include "states_screens/state_manager.hpp"
#include "utils/string_utils.hpp"
#include "utils/translation.hpp"
#include <IGUIEnvironment.h>
#include <IGUIImage.h>
using namespace GUIEngine;
using namespace irr::core;
using namespace irr::gui;
using namespace irr::video;
/**
This dialog can take many different shapes. Here's the global layout :
+-----------------------------------------------+
| rankings | highscores |
| | (optional) |
| | |
| | |
| | |
| | |
| | |
| | |
| | |
| | |
+-------------------------------+---------------+ <-- m_buttons_y_from
| (New race) |
+-----------------------------------------------+
| Unlock message (Race again) (continue GP) |
+-----------------------------------------------+
| (See unlocked) (Back to menu) (abort GP) |
+-----------------------------------------------+
(1) (2) (3)
There are 3 possible sets of buttons/labels that can appear at the bottom :
(1) these buttons are shown when some feature is unlocked
(2) these buttons are shown at the end of a single race (and no features have been unlocked)
(3) these buttons are shown at the end of a race within a GP (and no features have been unlocked)
*/
// ------------------------------------------------------------------------------------------------------
RaceOverDialog::RaceOverDialog(const float percentWidth,
const float percentHeight)
: ModalDialog(percentWidth, percentHeight)
{
m_auxiliary_timer = 0;
// Switch to barrier mode: server waits for ack from each client
network_manager->beginRaceResultBarrier();
//std::cout << "race_manager->getMajorMode()=" << race_manager->getMajorMode()
// << ", RaceManager::MAJOR_MODE_GRAND_PRIX=" << RaceManager::MAJOR_MODE_GRAND_PRIX
// << ", RaceManager::MAJOR_MODE_SINGLE=" << RaceManager::MAJOR_MODE_SINGLE << "\n";
const bool show_highscores = (race_manager->getMajorMode() != RaceManager::MAJOR_MODE_GRAND_PRIX) &&
World::getWorld()->useHighScores();
const int text_height = GUIEngine::getFontHeight();
const int button_h = text_height + 6;
const int margin_between_buttons = 12;
m_buttons_y_from = m_area.getHeight() - 3*(button_h + margin_between_buttons);
// ---- Ranking
core::rect< s32 > area(0, 0, (show_highscores ? m_area.getWidth()*2/3 : m_area.getWidth()), text_height);
IGUIStaticText* caption = GUIEngine::getGUIEnv()->addStaticText( _("Race Results"),
area, false, false, // border, word warp
m_irrlicht_window);
caption->setTabStop(false);
caption->setTextAlignment(EGUIA_CENTER, EGUIA_CENTER);
WorldWithRank *world = (WorldWithRank*)World::getWorld();
const unsigned int num_karts = world->getNumKarts();
const bool display_time = (world->getClockMode() == WorldStatus::CLOCK_CHRONO);
int line_h = text_height + 15;
const int lines_from_y = text_height + 15;
// make things more compact if we're missing space
while (lines_from_y + (int)num_karts*line_h > m_buttons_y_from) // cheap way to avoid calculating the
{ // required size with proper maths (FIXME)
line_h = (int)(line_h*0.9f);
}
m_rankings_y_bottom = -1;
int kart_id = 0; // 'i' below is not reliable because some karts (e.g. leader) will be skipped
for (unsigned int position = 1; position <= num_karts; position++)
{
const AbstractKart* current_kart = world->getKartAtPosition(position);
stringw kart_results_line;
const stringw& kart_name = current_kart->getName();
std::string time_string;
const float time = current_kart->getFinishTime();
if (display_time)
{
time_string = StringUtils::timeToString(time);
}
//This shows position + driver name + time + points earned + total points
if (race_manager->getMajorMode() == RaceManager::MAJOR_MODE_GRAND_PRIX)
{
const int prev_score = race_manager->getKartPrevScore(current_kart->getWorldKartId());
const int new_score = race_manager->getKartScore(current_kart->getWorldKartId());
if (display_time)
{
kart_results_line = StringUtils::insertValues( L"#%i. %s %s (%i + %i = %i)",
current_kart->getPosition(),
time_string.c_str(),
kart_name.c_str(), prev_score,
(new_score - prev_score), new_score);
}
else
{
kart_results_line = StringUtils::insertValues( L"#%i. %s (%i + %i = %i)",
current_kart->getPosition(), kart_name.c_str(),
prev_score, (new_score - prev_score), new_score);
}
}
else if (race_manager->getMinorMode() == RaceManager::MINOR_MODE_3_STRIKES)
{
//I18N: In results of battle mode; %i is where the rank is inserted;
//I18N: the first %s is where the kart name is inserted;
//I18N: the second %s is where the time is inserted
kart_results_line = _("%i. %s : survived for %s",
current_kart->getPosition(),
kart_name.c_str(),
time_string.c_str());
}
else
{
kart_results_line = StringUtils::insertValues( L"%i. %s %s",
current_kart->getPosition(),
kart_name.c_str(),
time_string.c_str());
}
const KartProperties* prop = current_kart->getKartProperties();
const std::string &icon_path = prop->getAbsoluteIconFile();
ITexture* kart_icon_texture = irr_driver->getTexture( icon_path );
const int entry_width = (show_highscores? m_area.getWidth()*2/3 : m_area.getWidth());
const int icon_size = text_height;
unsigned int i = current_kart->getWorldKartId();
core::rect< s32 > entry_area(10 + icon_size, lines_from_y + line_h*i,
entry_width , lines_from_y + line_h*(i+1));
core::rect< s32 > icon_area (5 , lines_from_y + line_h*i,
5+icon_size , lines_from_y + line_h*i + icon_size);
m_rankings_y_bottom = lines_from_y + line_h*(i+1);
GUIEngine::getGUIEnv()->addStaticText( kart_results_line.c_str(), entry_area,
false , true , // border, word warp
m_irrlicht_window);
IGUIImage* img = GUIEngine::getGUIEnv()->addImage( icon_area, m_irrlicht_window );
img->setImage(kart_icon_texture);
img->setScaleImage(true);
img->setTabStop(false);
img->setUseAlphaChannel(true);
kart_id++;
}
// ---- Highscores
if (show_highscores)
{
const Highscores *hs = World::getWorld()->getHighscores();
if (hs != NULL)
{
core::rect< s32 > hsarea(m_area.getWidth()*2/3, 0, m_area.getWidth(), text_height);
IGUIStaticText* highscores = GUIEngine::getGUIEnv()->addStaticText( _("Highscores"),
hsarea, false, false, // border, word warp
m_irrlicht_window);
highscores->setTabStop(false);
highscores->setTextAlignment(EGUIA_CENTER, EGUIA_CENTER);
unsigned int num_scores = hs->getNumberEntries();
std::string timebuffer;
for (unsigned int i=0; i<num_scores; i++)
{
std::string kart_name;
core::stringw playerName;
float T;
hs->getEntry(i, kart_name, playerName, &T);
timebuffer = StringUtils::timeToString(T);
const int line_from = lines_from_y + text_height*(i*3);
core::rect< s32 > linearea(m_area.getWidth()*2/3, line_from,
m_area.getWidth(), line_from + text_height);
GUIEngine::getGUIEnv()->addStaticText( playerName.c_str(),
linearea, false, false, // border, word warp
m_irrlicht_window);
core::rect< s32 > linearea2(m_area.getWidth()*2/3, line_from + text_height,
m_area.getWidth(), line_from + text_height*2);
GUIEngine::getGUIEnv()->addStaticText( stringw(timebuffer.c_str()).c_str(),
linearea2, false, false, // border, word warp
m_irrlicht_window);
} // next score
} // end if hs != NULL
} // end if not GP
// ---- GP ranks
if (race_manager->getMajorMode() == RaceManager::MAJOR_MODE_GRAND_PRIX)
{
const int gp_rank_y = m_area.getHeight() - (button_h + margin_between_buttons)*3;
//I18N: warning, this string needs to be SHORT!
stringw header = _("GP scores :");
const int headerWidth = GUIEngine::getFont()->getDimension(header.c_str()).Width + 5;
const int remainingWidth = m_area.getWidth() - headerWidth;
core::rect< s32 > hsarea(5, gp_rank_y, m_area.getWidth(), gp_rank_y + line_h);
IGUIStaticText* highscores = GUIEngine::getGUIEnv()->addStaticText( header.c_str(),
hsarea, false, false, // border, word warp
m_irrlicht_window);
highscores->setTabStop(false);
highscores->setTextAlignment(EGUIA_UPPERLEFT, EGUIA_CENTER);
// I assume it's harmless to call it here?
race_manager->computeGPRanks();
//FIXME: handle when there are too many karts to fit...
const int entry_width = std::min(int(remainingWidth/num_karts), line_h*2);
for (unsigned int i = 0; i < num_karts; ++i)
{
//if (order[i] == -1) continue;
const int gp_rank = race_manager->getKartGPRank(i);
const AbstractKart *current_kart = world->getKart(i);
const KartProperties* prop = current_kart->getKartProperties();
const std::string &icon_path = prop->getAbsoluteIconFile();
ITexture* kart_icon_texture = irr_driver->getTexture( icon_path );
std::ostringstream gp_score_str;
gp_score_str << race_manager->getKartScore(i);
const int x_from = headerWidth + gp_rank*entry_width;
core::rect< s32 > entry_area(x_from + line_h + 5 , gp_rank_y,
x_from + entry_width + line_h + 5, gp_rank_y + line_h);
core::rect< s32 > icon_area (x_from , gp_rank_y,
x_from + line_h , gp_rank_y + line_h);
gui::IGUIStaticText* label =
GUIEngine::getGUIEnv()->addStaticText( stringw(gp_score_str.str().c_str()).c_str(), entry_area,
false , true , // border, word warp
m_irrlicht_window);
label->setTabStop(false);
label->setTextAlignment(EGUIA_UPPERLEFT, EGUIA_CENTER);
IGUIImage* img = GUIEngine::getGUIEnv()->addImage( icon_area, m_irrlicht_window );
img->setImage(kart_icon_texture);
img->setScaleImage(true);
img->setTabStop(false);
img->setUseAlphaChannel(true);
}
}
// ---- Buttons at the bottom
if (unlock_manager->getCurrentSlot()->getRecentlyCompletedChallenges().size() > 0)
{
const int label_y = m_area.getHeight() - (button_h + margin_between_buttons)*2;
// button_h is used in the x coordinates not by mistake, but because the icon is square and
// scaled according to the available height.
core::rect< s32 > iconarea(20, label_y,
20 + button_h, label_y + button_h);
IGUIImage* img = GUIEngine::getGUIEnv()->addImage( iconarea, m_irrlicht_window );
img->setImage( irr_driver->getTexture( file_manager->getTextureFile("cup_gold.png") ) );
img->setScaleImage(true);
img->setTabStop(false);
img->setUseAlphaChannel(true);
core::rect< s32 > icon2area(m_area.getWidth() - button_h - 20, label_y,
m_area.getWidth() - 20, label_y + button_h);
img = GUIEngine::getGUIEnv()->addImage( icon2area, m_irrlicht_window );
img->setImage( irr_driver->getTexture( file_manager->getTextureFile("cup_gold.png") ) );
img->setScaleImage(true);
img->setTabStop(false);
img->setUseAlphaChannel(true);
LabelWidget* unlocked_label = new LabelWidget();
unlocked_label->m_properties[PROP_ID] = "label";
unlocked_label->m_properties[PROP_TEXT_ALIGN] = "center";
unlocked_label->m_x = button_h + 30;
unlocked_label->m_y = label_y;
unlocked_label->m_w = m_area.getWidth() - button_h*2 - 60;
unlocked_label->m_h = button_h;
unlocked_label->setText( _("You unlocked a new feature!"), false );
unlocked_label->setParent(m_irrlicht_window);
m_widgets.push_back(unlocked_label);
unlocked_label->add();
ButtonWidget* whats_next_btn = new ButtonWidget();
whats_next_btn->m_x = 15;
whats_next_btn->m_y = m_area.getHeight() - (button_h + margin_between_buttons);
whats_next_btn->m_w = m_area.getWidth() - 30;
whats_next_btn->m_h = button_h;
whats_next_btn->setParent(m_irrlicht_window);
whats_next_btn->setText( _("You completed a challenge!") );
whats_next_btn->m_properties[PROP_ID] = "seeunlocked";
m_widgets.push_back(whats_next_btn);
whats_next_btn->add();
whats_next_btn->setFocusForPlayer( PLAYER_ID_GAME_MASTER );
}
else if (race_manager->getMajorMode() == RaceManager::MAJOR_MODE_SINGLE)
{
ButtonWidget* new_race_btn = new ButtonWidget();
new_race_btn->m_properties[PROP_ID] = "newracebtn";
new_race_btn->m_x = 15;
new_race_btn->m_y = m_area.getHeight() - (button_h + margin_between_buttons)*3;
new_race_btn->m_w = m_area.getWidth() - 30;
new_race_btn->m_h = button_h;
new_race_btn->setText( _("Setup New Race") );
new_race_btn->setParent(m_irrlicht_window);
m_widgets.push_back(new_race_btn);
new_race_btn->add();
ButtonWidget* race_again_btn = new ButtonWidget();
race_again_btn->m_properties[PROP_ID] = "raceagainbtn";
race_again_btn->m_x = 15;
race_again_btn->m_y = m_area.getHeight() - (button_h + margin_between_buttons)*2;
race_again_btn->m_w = m_area.getWidth() - 30;
race_again_btn->m_h = button_h;
race_again_btn->setText( _("Race in this track again") );
race_again_btn->setParent(m_irrlicht_window);
m_widgets.push_back(race_again_btn);
race_again_btn->add();
ButtonWidget* whats_next_btn = new ButtonWidget();
whats_next_btn->m_x = 15;
whats_next_btn->m_y = m_area.getHeight() - (button_h + margin_between_buttons);
whats_next_btn->m_w = m_area.getWidth() - 30;
whats_next_btn->m_h = button_h;
whats_next_btn->setParent(m_irrlicht_window);
if (race_manager->raceWasStartedFromOverworld())
{
whats_next_btn->setText( _("Back to track selection") );
}
else
{
whats_next_btn->setText( _("Back to the main menu") );
}
whats_next_btn->m_properties[PROP_ID] = "backtomenu";
m_widgets.push_back(whats_next_btn);
whats_next_btn->add();
whats_next_btn->setFocusForPlayer( PLAYER_ID_GAME_MASTER );
}
else if (race_manager->getMajorMode() == RaceManager::MAJOR_MODE_GRAND_PRIX)
{
ButtonWidget* whats_next_btn = new ButtonWidget();
whats_next_btn->m_x = 15;
whats_next_btn->m_y = m_area.getHeight() - (button_h + margin_between_buttons)*2;
whats_next_btn->m_w = m_area.getWidth() - 30;
whats_next_btn->m_h = button_h;
whats_next_btn->setParent(m_irrlicht_window);
whats_next_btn->setText( _("Continue Grand Prix") );
whats_next_btn->m_properties[PROP_ID] = "continuegp";
m_widgets.push_back(whats_next_btn);
whats_next_btn->add();
whats_next_btn->setFocusForPlayer( PLAYER_ID_GAME_MASTER );
ButtonWidget* abort_gp = new ButtonWidget();
abort_gp->m_properties[PROP_ID] = "backtomenu";
abort_gp->m_x = 15;
abort_gp->m_y = m_area.getHeight() - (button_h + margin_between_buttons);
abort_gp->m_w = m_area.getWidth() - 30;
abort_gp->m_h = button_h;
abort_gp->setText( _("Abort Grand Prix") );
abort_gp->setParent(m_irrlicht_window);
m_widgets.push_back(abort_gp);
abort_gp->add();
}
else
{
assert(false);
}
} // RaceOverDialog
// ------------------------------------------------------------------------------------------------------
void RaceOverDialog::onEnterPressedInternal()
{
} // onEnterPressedInternal
// ------------------------------------------------------------------------------------------------------
GUIEngine::EventPropagation RaceOverDialog::processEvent(const std::string& eventSource)
{
if (eventSource == "raceagainbtn")
{
ModalDialog::dismiss();
network_manager->setState(NetworkManager::NS_MAIN_MENU);
World::getWorld()->unpause();
race_manager->rerunRace();
return GUIEngine::EVENT_BLOCK;
}
else if (eventSource == "newracebtn")
{
ModalDialog::dismiss();
World::getWorld()->unpause();
race_manager->exitRace();
Screen* newStack[] = {MainMenuScreen::getInstance(), RaceSetupScreen::getInstance(), NULL};
StateManager::get()->resetAndSetStack( newStack );
return GUIEngine::EVENT_BLOCK;
}
else if (eventSource == "backtomenu")
{
ModalDialog::dismiss();
World::getWorld()->unpause();
race_manager->exitRace();
StateManager::get()->resetAndGoToScreen(MainMenuScreen::getInstance());
if (race_manager->raceWasStartedFromOverworld())
{
OverWorld::enterOverWorld();
}
return GUIEngine::EVENT_BLOCK;
}
else if (eventSource == "continuegp")
{
ModalDialog::dismiss();
World::getWorld()->unpause();
race_manager->next();
return GUIEngine::EVENT_BLOCK;
}
else if (eventSource == "seeunlocked")
{
std::vector<const ChallengeData*> unlocked =
unlock_manager->getCurrentSlot()->getRecentlyCompletedChallenges();
unlock_manager->getCurrentSlot()->clearUnlocked();
FeatureUnlockedCutScene* scene =
FeatureUnlockedCutScene::getInstance();
assert(unlocked.size() > 0);
scene->addTrophy(race_manager->getDifficulty());
scene->findWhatWasUnlocked(race_manager->getDifficulty());
ModalDialog::dismiss();
// clear the race
World::deleteWorld();
StateManager::get()->pushScreen(scene);
return GUIEngine::EVENT_BLOCK;
}
return GUIEngine::EVENT_LET;
} // processEvent
//-----------------------------------------------------------------------------
void RaceOverDialog::escapePressed()
{
if (unlock_manager->getCurrentSlot()->getRecentlyCompletedChallenges().size() > 0)
{
std::string what = "seeunlocked";
processEvent(what);
}
else if (race_manager->getMajorMode() == RaceManager::MAJOR_MODE_GRAND_PRIX)
{
std::string what = "continuegp";
processEvent(what);
}
else if (race_manager->getMajorMode() == RaceManager::MAJOR_MODE_SINGLE)
{
std::string what = "backtomenu";
processEvent(what);
}
else
{
assert(false);
}
} // escapePressed
//-----------------------------------------------------------------------------
void RaceOverDialog::onUpdate(float dt)
{
m_auxiliary_timer +=dt;
// Draw battle report (if relevant)
if (race_manager->getMinorMode() == RaceManager::MINOR_MODE_3_STRIKES)
{
// only draw if we have enough space (FIXME: find better way?)
if (m_buttons_y_from - m_rankings_y_bottom >= 100)
{
renderThreeStrikesGraph(m_area.UpperLeftCorner.X + 15, m_rankings_y_bottom + 30,
m_area.getWidth() - 30,
m_buttons_y_from - m_rankings_y_bottom - 45);
}
}
}
//-----------------------------------------------------------------------------
void RaceOverDialog::renderThreeStrikesGraph(const int x, const int y, const int w, const int h)
{
assert(h > 0);
assert(w > 0);
assert(x >= 0);
assert(y >= 0);
//FIXME: don't render everything from scratch everytime, but use RTT?
ThreeStrikesBattle* world = dynamic_cast<ThreeStrikesBattle*>(World::getWorld());
assert(world != NULL);
const unsigned int evt_count = world->m_battle_events.size();
if (evt_count < 2) return;
SColor black(255,0,0,0);
irr_driver->getVideoDriver()->draw2DLine( core::position2d<s32>(x, y),
core::position2d<s32>(x, y + h), black);
irr_driver->getVideoDriver()->draw2DLine( core::position2d<s32>(x, y),
core::position2d<s32>(x - 7, y + 13), black);
irr_driver->getVideoDriver()->draw2DLine( core::position2d<s32>(x, y),
core::position2d<s32>(x + 7, y + 13), black);
irr_driver->getVideoDriver()->draw2DLine( core::position2d<s32>(x, y + h),
core::position2d<s32>(x + w, y + h), black);
irr_driver->getVideoDriver()->draw2DLine( core::position2d<s32>(x + w, y + h),
core::position2d<s32>(x + w - 13, y + h + 7), black);
irr_driver->getVideoDriver()->draw2DLine( core::position2d<s32>(x + w, y + h),
core::position2d<s32>(x + w - 13, y + h - 7), black);
float lastEventTime = 0.0f;
int max_life_count = 0;
const unsigned int kart_count = world->m_battle_events[0].m_kart_info.size();
// find max values
for (unsigned int n=0; n<evt_count; ++n)
{
const float time = world->m_battle_events[n].m_time;
if (time > lastEventTime) lastEventTime = time;
assert(world->m_battle_events[n].m_kart_info.size() == kart_count);
for (unsigned int k=0; k<kart_count; k++)
{
if (world->m_battle_events[n].m_kart_info[k].m_lives > max_life_count)
{
max_life_count = world->m_battle_events[n].m_kart_info[k].m_lives;
}
}
}
assert(lastEventTime > 0.0f);
assert(max_life_count > 0);
std::vector<int> kart_y_at_mid_time(kart_count);
const float mid_time = lastEventTime/2.0f;
// render graph
for (unsigned int n=1; n<evt_count; ++n)
{
const float previous_time = world->m_battle_events[n-1].m_time;
const float time = world->m_battle_events[n].m_time;
//printf("At time %f :\n", time);
const int previous_event_x = (int)(x + w*previous_time/lastEventTime);
const int event_x = (int)(x + w*time/lastEventTime);
assert(world->m_battle_events[n].m_kart_info.size() == kart_count);
const bool midTime = (previous_time < mid_time && time >= mid_time);
for (unsigned int k=0; k<kart_count; k++)
{
const int kart_lives = world->m_battle_events[n].m_kart_info[k].m_lives;
const int kart_previous_lives = world->m_battle_events[n-1].m_kart_info[k].m_lives;
//printf(" kart %s had %i lives\n", world->getKart(k)->getIdent().c_str(),
// world->m_battle_events[n].m_kart_info[k].m_lives);
const int event_y = y + h - (int)(h * (float)kart_lives / (float)max_life_count);
const int previous_event_y = y + h - (int)(h * (float)kart_previous_lives / (float)max_life_count);
if (midTime)
{
kart_y_at_mid_time[k] = previous_event_y;
}
const video::SColor& color = world->getKart(k)->getKartProperties()->getColor();
irr_driver->getVideoDriver()->draw2DLine( core::position2d<s32>(previous_event_x, previous_event_y),
core::position2d<s32>(event_x, previous_event_y), color);
irr_driver->getVideoDriver()->draw2DLine( core::position2d<s32>(event_x, previous_event_y),
core::position2d<s32>(event_x, event_y), color);
}
}
// draw kart icons
const int middleX = x + w/2;
const int iconSize = h/10;
for (unsigned int k=0; k<kart_count; k++)
{
const AbstractKart* current_kart = world->getKart(k);
const KartProperties* prop = current_kart->getKartProperties();
const std::string& icon_path = prop->getAbsoluteIconFile();
ITexture* kart_icon_texture = irr_driver->getTexture( icon_path );
/*
draw2DImage (const video::ITexture *texture, const core::rect< s32 > &destRect,
const core::rect< s32 > &sourceRect, const core::rect< s32 > *clipRect=0,
const video::SColor *const colors=0, bool useAlphaChannelOfTexture=false)=0
*/
core::rect< s32 > dest(middleX, kart_y_at_mid_time[k] - iconSize/2,
middleX + iconSize, kart_y_at_mid_time[k] + iconSize/2);
core::rect< s32 > src(core::position2d<s32>(0, 0),
kart_icon_texture->getSize() );
irr_driver->getVideoDriver()->draw2DImage(kart_icon_texture, dest, src,
NULL /* clip */, NULL /* colors */, true /* alpha */ );
}
// draw axes names
{
core::rect<s32> pos(x, y + h, x + w, y + y + h + 100);
GUIEngine::getSmallFont()->draw( _("Time"), pos, video::SColor(255,0,0,0),
true /* hcenter */, false /* vcenter */ );
}
{
core::rect<s32> pos(x, y, x + w, y + h);
GUIEngine::getSmallFont()->draw( _("Energy"), pos, video::SColor(255,0,0,0),
false /* hcenter */, true /* vcenter */ );
}
} // renderThreeStrikesGraph
// ----------------------------------------------------------------------------
/** Called by WorldStatus to see when the race results have been completely
* displayed, which means that the next phase can start.
*/
bool RaceOverDialog::menuIsFinished()
{
return m_auxiliary_timer>stk_config->m_delay_finish_time;
} // menuIsFinished

View File

@ -1,54 +0,0 @@
// SuperTuxKart - a fun racing game with go-kart
// Copyright (C) 2009 Marianne Gagnon
//
// 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.
#ifndef HEADER_RACEOVER_DIALOG_HPP
#define HEADER_RACEOVER_DIALOG_HPP
#include "guiengine/modaldialog.hpp"
namespace irr { namespace video { class ITexture; } }
/**
* \ingroup states_screens
*/
class RaceOverDialog : public GUIEngine::ModalDialog
{
void renderThreeStrikesGraph(const int x, const int y, const int w, const int h);
int m_buttons_y_from;
int m_rankings_y_bottom;
/** A timer to make this display shown for a certain amount of time. */
float m_auxiliary_timer;
public:
/**
* Creates a modal dialog with given percentage of screen width and height
*/
RaceOverDialog(const float percentWidth, const float percentHeight);
void onEnterPressedInternal();
GUIEngine::EventPropagation processEvent(const std::string& eventSource);
virtual void escapePressed();
virtual void onUpdate(float dt);
bool menuIsFinished();
};
#endif