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
88 #define WMAP_INFO_LEFT_X 555
89 #define WMAP_INFO_RIGHT_X 705
92 Statistics::draw_worldmap_info(DrawingContext& context)
94 if(stats[SCORE_STAT] == -1) // not initialized yet
99 timer.start(TOTAL_DISPLAY_TIME);
101 if(display_stat >= NUM_STATS)
106 if(timer.get_gone() < FADING_TIME)
107 alpha = timer.get_gone() * 255 / FADING_TIME;
108 else if(timer.get_left() < FADING_TIME)
109 alpha = timer.get_left() * 255 / FADING_TIME;
115 context.draw_text(white_small_text, _("Level Statistics"),
116 Vector((WMAP_INFO_LEFT_X + WMAP_INFO_RIGHT_X) / 2, 490),
117 CENTER_ALLIGN, LAYER_GUI);
119 sprintf(str, _("Max score:"));
120 context.draw_text(white_small_text, str, Vector(WMAP_INFO_LEFT_X, 506), LEFT_ALLIGN, LAYER_GUI);
122 sprintf(str, "%d", stats[SCORE_STAT]);
123 context.draw_text(white_small_text, str, Vector(WMAP_INFO_RIGHT_X, 506), RIGHT_ALLIGN, LAYER_GUI);
125 // draw other small info
127 if(display_stat == BADGUYS_SQUISHED_STAT)
128 sprintf(str, _("Max fragging:"));
129 else if(display_stat == SHOTS_STAT)
130 sprintf(str, _("Min shots:"));
131 else if(display_stat == TIME_NEEDED_STAT)
132 sprintf(str, _("Min time needed:"));
133 else// if(display_stat == JUMPS_STAT)
134 sprintf(str, _("Min jumps:"));
136 context.draw_text(white_small_text, str, Vector(WMAP_INFO_LEFT_X, 522), LEFT_ALLIGN, LAYER_GUI, NONE_EFFECT, alpha);
138 if(display_stat == BADGUYS_SQUISHED_STAT)
139 sprintf(str, "%d", stats[BADGUYS_SQUISHED_STAT]);
140 else if(display_stat == SHOTS_STAT)
141 sprintf(str, "%d", stats[SHOTS_STAT]);
142 else if(display_stat == TIME_NEEDED_STAT)
143 sprintf(str, "%d", stats[TIME_NEEDED_STAT]);
144 else// if(display_stat == JUMPS_STAT)
145 sprintf(str, "%d", stats[JUMPS_STAT]);
147 context.draw_text(white_small_text, str, Vector(WMAP_INFO_RIGHT_X, 522), RIGHT_ALLIGN, LAYER_GUI, NONE_EFFECT, alpha);
151 Statistics::draw_message_info(DrawingContext& context, std::string title)
153 if(stats[SCORE_STAT] == -1) // not initialized yet
156 context.draw_text(gold_text, title, Vector(screen->w/2, 410), CENTER_ALLIGN, LAYER_GUI);
160 sprintf(str, _( "Max score: %d"), stats[SCORE_STAT]);
161 context.draw_text(white_text, str, Vector(screen->w/2, 450), CENTER_ALLIGN, LAYER_GUI);
163 for(int i = 1; i < NUM_STATS; i++)
165 if(i == BADGUYS_SQUISHED_STAT)
166 sprintf(str, _("Max fragging: %d"), stats[BADGUYS_SQUISHED_STAT]);
167 else if(i == SHOTS_STAT)
168 sprintf(str, _("Min shots: %d"), stats[SHOTS_STAT]);
169 else if(i == TIME_NEEDED_STAT)
170 sprintf(str, _("Min time needed: %d"), stats[TIME_NEEDED_STAT]);
171 else// if(i == JUMPS_STAT)
172 sprintf(str, _("Min jumps: %d"), stats[JUMPS_STAT]);
174 context.draw_text(white_small_text, str, Vector(screen->w/2, 462 + i*18), CENTER_ALLIGN, LAYER_GUI);
179 Statistics::add_points(int stat, int points)
181 stats[stat] += points;
185 Statistics::get_points(int stat)
191 Statistics::set_points(int stat, int points)
193 stats[stat] = points;
199 for(int i = 0; i < NUM_STATS; i++)
204 Statistics::merge(Statistics& stats_)
206 stats[SCORE_STAT] = std::max(stats[SCORE_STAT], stats_.stats[SCORE_STAT]);
207 if(stats[JUMPS_STAT] != -1)
208 stats[JUMPS_STAT] = my_min(stats[JUMPS_STAT], stats_.stats[JUMPS_STAT]);
209 stats[BADGUYS_SQUISHED_STAT] =
210 std::max(stats[BADGUYS_SQUISHED_STAT], stats_.stats[BADGUYS_SQUISHED_STAT]);
211 stats[SHOTS_STAT] = my_min(stats[SHOTS_STAT], stats_.stats[SHOTS_STAT]);
212 stats[TIME_NEEDED_STAT] =
213 my_min(stats[TIME_NEEDED_STAT], stats_.stats[TIME_NEEDED_STAT]);
217 Statistics::operator+=(const Statistics& stats_)
219 for(int i = 0; i < NUM_STATS; i++)
220 stats[i] += stats_.stats[i];