-// SuperTux
-// Copyright (C) 2004 SuperTux Development Team, see AUTHORS for details
+//
+// SuperTux - A Jump'n Run
+// Copyright (C) 2004 Ricardo Cruz <rick2@aeiou.pt>
//
// This program is free software; you can redistribute it and/or
// modify it under the terms of the GNU General Public License
#include "utils/lispreader.h"
#include "utils/lispwriter.h"
#include "statistics.h"
+#include "video/drawing_context.h"
+#include "app/gettext.h"
+#include "app/globals.h"
+#include "resources.h"
Statistics global_stats;
+std::string
+stat_name_to_string(int stat_enum)
+{
+ switch(stat_enum)
+ {
+ case SCORE_STAT:
+ return "score";
+ case BADGUYS_SQUISHED_STAT:
+ return "badguys-squished";
+ case SHOTS_STAT:
+ return "shots";
+ case TIME_NEEDED_STAT:
+ return "time-needed";
+ case JUMPS_STAT:
+ return "jumps";
+ }
+}
+
+int
+my_min(int a, int b)
+{
+if(a == -1)
+ return b;
+if(b == -1)
+ return a;
+return std::min(a, b);
+}
+
Statistics::Statistics()
{
- reset();
+ timer.init(true);
+ display_stat = 1;
+
+ for(int i = 0; i < NUM_STATS; i++)
+ stats[i] = -1;
}
Statistics::~Statistics()
void
Statistics::parse(LispReader& reader)
{
- reader.read_int("score", stats[SCORE_STAT]);
+ for(int i = 0; i < NUM_STATS; i++)
+ reader.read_int(stat_name_to_string(i).c_str(), stats[i]);
}
void
Statistics::write(LispWriter& writer)
{
- writer.write_int("score", stats[SCORE_STAT]);
+ for(int i = 0; i < NUM_STATS; i++)
+ writer.write_int(stat_name_to_string(i), stats[i]);
+}
+
+#define TOTAL_DISPLAY_TIME 3400
+#define FADING_TIME 600
+
+#define WMAP_INFO_LEFT_X 555
+#define WMAP_INFO_RIGHT_X 705
+
+void
+Statistics::draw_worldmap_info(DrawingContext& context)
+{
+ if(stats[SCORE_STAT] == -1) // not initialized yet
+ return;
+
+ if(!timer.check())
+ {
+ timer.start(TOTAL_DISPLAY_TIME);
+ display_stat++;
+ if(display_stat >= NUM_STATS)
+ display_stat = 1;
+ }
+
+ int alpha;
+ if(timer.get_gone() < FADING_TIME)
+ alpha = timer.get_gone() * 255 / FADING_TIME;
+ else if(timer.get_left() < FADING_TIME)
+ alpha = timer.get_left() * 255 / FADING_TIME;
+ else
+ alpha = 255;
+
+ char str[128];
+
+ context.draw_text(white_small_text, _("Level Statistics"),
+ Vector((WMAP_INFO_LEFT_X + WMAP_INFO_RIGHT_X) / 2, 490),
+ CENTER_ALLIGN, LAYER_GUI);
+
+ sprintf(str, _("Max score:"));
+ context.draw_text(white_small_text, str, Vector(WMAP_INFO_LEFT_X, 506), LEFT_ALLIGN, LAYER_GUI);
+
+ sprintf(str, "%d", stats[SCORE_STAT]);
+ context.draw_text(white_small_text, str, Vector(WMAP_INFO_RIGHT_X, 506), RIGHT_ALLIGN, LAYER_GUI);
+
+ // draw other small info
+
+ if(display_stat == BADGUYS_SQUISHED_STAT)
+ sprintf(str, _("Max fragging:"));
+ else if(display_stat == SHOTS_STAT)
+ sprintf(str, _("Min shots:"));
+ else if(display_stat == TIME_NEEDED_STAT)
+ sprintf(str, _("Min time needed:"));
+ else// if(display_stat == JUMPS_STAT)
+ sprintf(str, _("Min jumps:"));
+
+ context.draw_text(white_small_text, str, Vector(WMAP_INFO_LEFT_X, 522), LEFT_ALLIGN, LAYER_GUI, NONE_EFFECT, alpha);
+
+ if(display_stat == BADGUYS_SQUISHED_STAT)
+ sprintf(str, "%d", stats[BADGUYS_SQUISHED_STAT]);
+ else if(display_stat == SHOTS_STAT)
+ sprintf(str, "%d", stats[SHOTS_STAT]);
+ else if(display_stat == TIME_NEEDED_STAT)
+ sprintf(str, "%d", stats[TIME_NEEDED_STAT]);
+ else// if(display_stat == JUMPS_STAT)
+ sprintf(str, "%d", stats[JUMPS_STAT]);
+
+ context.draw_text(white_small_text, str, Vector(WMAP_INFO_RIGHT_X, 522), RIGHT_ALLIGN, LAYER_GUI, NONE_EFFECT, alpha);
+}
+
+void
+Statistics::draw_message_info(DrawingContext& context, std::string title)
+{
+ if(stats[SCORE_STAT] == -1) // not initialized yet
+ return;
+
+ context.draw_text(gold_text, title, Vector(screen->w/2, 410), CENTER_ALLIGN, LAYER_GUI);
+
+ char str[128];
+
+ sprintf(str, _( "Max score: %d"), stats[SCORE_STAT]);
+ context.draw_text(white_text, str, Vector(screen->w/2, 450), CENTER_ALLIGN, LAYER_GUI);
+
+ for(int i = 1; i < NUM_STATS; i++)
+ {
+ if(i == BADGUYS_SQUISHED_STAT)
+ sprintf(str, _("Max fragging: %d"), stats[BADGUYS_SQUISHED_STAT]);
+ else if(i == SHOTS_STAT)
+ sprintf(str, _("Min shots: %d"), stats[SHOTS_STAT]);
+ else if(i == TIME_NEEDED_STAT)
+ sprintf(str, _("Min time needed: %d"), stats[TIME_NEEDED_STAT]);
+ else// if(i == JUMPS_STAT)
+ sprintf(str, _("Min jumps: %d"), stats[JUMPS_STAT]);
+
+ context.draw_text(white_small_text, str, Vector(screen->w/2, 462 + i*18), CENTER_ALLIGN, LAYER_GUI);
+ }
}
void
}
void
+Statistics::set_points(int stat, int points)
+{
+ stats[stat] = points;
+}
+
+void
Statistics::reset()
{
- for(int i = 0; i < MAX_STATS; i++)
+ for(int i = 0; i < NUM_STATS; i++)
stats[i] = 0;
}
Statistics::merge(Statistics& stats_)
{
stats[SCORE_STAT] = std::max(stats[SCORE_STAT], stats_.stats[SCORE_STAT]);
+ if(stats[JUMPS_STAT] != -1)
+ stats[JUMPS_STAT] = my_min(stats[JUMPS_STAT], stats_.stats[JUMPS_STAT]);
+ stats[BADGUYS_SQUISHED_STAT] =
+ std::max(stats[BADGUYS_SQUISHED_STAT], stats_.stats[BADGUYS_SQUISHED_STAT]);
+ stats[SHOTS_STAT] = my_min(stats[SHOTS_STAT], stats_.stats[SHOTS_STAT]);
+ stats[TIME_NEEDED_STAT] =
+ my_min(stats[TIME_NEEDED_STAT], stats_.stats[TIME_NEEDED_STAT]);
}
void
Statistics::operator+=(const Statistics& stats_)
{
- stats[SCORE_STAT] += stats_.stats[SCORE_STAT];
+ for(int i = 0; i < NUM_STATS; i++)
+ stats[i] += stats_.stats[i];
}