2 // SuperTux - A Jump'n Run
3 // Copyright (C) 2004 Ricardo Cruz <rick2@aeiou.pt>
5 // This program is free software; you can redistribute it and/or
6 // modify it under the terms of the GNU General Public License
7 // as published by the Free Software Foundation; either version 2
8 // of the License, or (at your option) any later version.
10 // This program is distributed in the hope that it will be useful,
11 // but WITHOUT ANY WARRANTY; without even the implied warranty of
12 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
13 // GNU General Public License for more details.
15 // You should have received a copy of the GNU General Public License
16 // along with this program; if not, write to the Free Software
17 // Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA
20 #include "utils/lispreader.h"
21 #include "utils/lispwriter.h"
22 #include "statistics.h"
23 #include "video/drawing_context.h"
24 #include "app/gettext.h"
25 #include "app/globals.h"
26 #include "resources.h"
28 Statistics global_stats;
31 stat_name_to_string(int stat_enum)
37 case BADGUYS_SQUISHED_STAT:
38 return "badguys-squished";
41 case TIME_NEEDED_STAT:
55 return std::min(a, b);
58 Statistics::Statistics()
63 for(int i = 0; i < NUM_STATS; i++)
67 Statistics::~Statistics()
72 Statistics::parse(LispReader& reader)
74 for(int i = 0; i < NUM_STATS; i++)
75 reader.read_int(stat_name_to_string(i).c_str(), stats[i]);
79 Statistics::write(LispWriter& writer)
81 for(int i = 0; i < NUM_STATS; i++)
82 writer.write_int(stat_name_to_string(i), stats[i]);
85 #define TOTAL_DISPLAY_TIME 3400
86 #define FADING_TIME 600
89 Statistics::draw_worldmap_info(DrawingContext& context)
91 if(stats[SCORE_STAT] == -1) // not initialized yet
96 timer.start(TOTAL_DISPLAY_TIME);
98 if(display_stat >= NUM_STATS)
103 if(timer.get_gone() < FADING_TIME)
104 alpha = timer.get_gone() * 255 / FADING_TIME;
105 else if(timer.get_left() < FADING_TIME)
106 alpha = timer.get_left() * 255 / FADING_TIME;
112 context.draw_text(white_small_text, _("Level Statistics"), Vector(550, 490), LEFT_ALLIGN, LAYER_GUI);
114 sprintf(str, _("Max score: %d"), stats[SCORE_STAT]);
115 context.draw_text(white_small_text, str, Vector(560, 506), LEFT_ALLIGN, LAYER_GUI);
117 if(display_stat == BADGUYS_SQUISHED_STAT)
118 sprintf(str, _("Max fragging: %d"), stats[BADGUYS_SQUISHED_STAT]);
119 else if(display_stat == SHOTS_STAT)
120 sprintf(str, _("Min shots: %d"), stats[SHOTS_STAT]);
121 else if(display_stat == TIME_NEEDED_STAT)
122 sprintf(str, _("Min time needed: %d"), stats[TIME_NEEDED_STAT]);
123 else// if(display_stat == JUMPS_STAT)
124 sprintf(str, _("Min jumps: %d"), stats[JUMPS_STAT]);
126 context.draw_text(white_small_text, str, Vector(560, 522), LAYER_GUI, LEFT_ALLIGN, NONE_EFFECT, alpha);
130 Statistics::draw_message_info(DrawingContext& context, std::string title)
132 if(stats[SCORE_STAT] == -1) // not initialized yet
135 context.draw_text(gold_text, title, Vector(screen->w/2, 400), CENTER_ALLIGN, LAYER_GUI);
138 for(int i = 0; i < NUM_STATS; i++)
141 sprintf(str, _("Max score: %d"), stats[SCORE_STAT]);
142 else if(i == BADGUYS_SQUISHED_STAT)
143 sprintf(str, _("Max fragging: %d"), stats[BADGUYS_SQUISHED_STAT]);
144 else if(i == SHOTS_STAT)
145 sprintf(str, _("Min shots: %d"), stats[SHOTS_STAT]);
146 else if(i == TIME_NEEDED_STAT)
147 sprintf(str, _("Min time needed: %d"), stats[TIME_NEEDED_STAT]);
148 else// if(i == JUMPS_STAT)
149 sprintf(str, _("Min jumps: %d"), stats[JUMPS_STAT]);
151 context.draw_text(white_text, str, Vector(screen->w/2, 430 + i*22), CENTER_ALLIGN, LAYER_GUI);
156 Statistics::add_points(int stat, int points)
158 stats[stat] += points;
162 Statistics::get_points(int stat)
168 Statistics::set_points(int stat, int points)
170 stats[stat] = points;
176 for(int i = 0; i < NUM_STATS; i++)
181 Statistics::merge(Statistics& stats_)
183 stats[SCORE_STAT] = std::max(stats[SCORE_STAT], stats_.stats[SCORE_STAT]);
184 if(stats[JUMPS_STAT] != -1)
185 stats[JUMPS_STAT] = my_min(stats[JUMPS_STAT], stats_.stats[JUMPS_STAT]);
186 stats[BADGUYS_SQUISHED_STAT] =
187 std::max(stats[BADGUYS_SQUISHED_STAT], stats_.stats[BADGUYS_SQUISHED_STAT]);
188 stats[SHOTS_STAT] = my_min(stats[SHOTS_STAT], stats_.stats[SHOTS_STAT]);
189 stats[TIME_NEEDED_STAT] =
190 my_min(stats[TIME_NEEDED_STAT], stats_.stats[TIME_NEEDED_STAT]);
194 Statistics::operator+=(const Statistics& stats_)
196 for(int i = 0; i < NUM_STATS; i++)
197 stats[i] += stats_.stats[i];