projects
/
supertux.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
disable collision detection when tux is falling down because he is dead
[supertux.git]
/
src
/
statistics.h
diff --git
a/src/statistics.h
b/src/statistics.h
index
d22c773
..
9f15332
100644
(file)
--- a/
src/statistics.h
+++ b/
src/statistics.h
@@
-1,5
+1,6
@@
-// 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
//
// This program is free software; you can redistribute it and/or
// modify it under the terms of the GNU General Public License
@@
-19,16
+20,25
@@
#ifndef SUPERTUX_STATISTICS_H
#define SUPERTUX_STATISTICS_H
#ifndef SUPERTUX_STATISTICS_H
#define SUPERTUX_STATISTICS_H
+#include "timer.h"
+
using namespace SuperTux;
namespace SuperTux {
class LispReader;
class LispWriter;
using namespace SuperTux;
namespace SuperTux {
class LispReader;
class LispWriter;
+class DrawingContext;
}
}
+#define SPLAYER 0
+#define STOTAL 1
+
enum {
SCORE_STAT,
enum {
SCORE_STAT,
- MAX_STATS
+ COINS_COLLECTED_STAT,
+ BADGUYS_KILLED_STAT,
+ TIME_NEEDED_STAT,
+ NUM_STATS
};
/** This class is a layer between level and worldmap to keep
};
/** This class is a layer between level and worldmap to keep
@@
-38,6
+48,7
@@
enum {
class Statistics
{
public:
class Statistics
{
public:
+ // don't forget to call reset() to init stat
Statistics();
~Statistics();
Statistics();
~Statistics();
@@
-46,11
+57,19
@@
public:
/// write statistics to lisp file
void write(LispWriter& writer);
/// write statistics to lisp file
void write(LispWriter& writer);
- // TODO: add drawing functions to draw stats on WorldMap
+ /* Draw to the worldmap or a game message */
+ // TODO: make this functions working
+ void draw_worldmap_info(DrawingContext& context);
+ void draw_message_info(DrawingContext& context, std::string title);
+ /* Add / Set / Get points to/from one of the stats this can keep track of */
void add_points(int stat, int points);
void add_points(int stat, int points);
+ void set_points(int stat, int points);
int get_points(int stat);
int get_points(int stat);
+ void set_total_points(int stat, int points);
+
+ /* Reset statistics */
void reset();
/* Give another Statistics object, find the best of each one */
void reset();
/* Give another Statistics object, find the best of each one */
@@
-60,7
+79,10
@@
public:
void operator+=(const Statistics& o);
private:
void operator+=(const Statistics& o);
private:
- int stats[MAX_STATS];
+ int stats[NUM_STATS][2];
+
+ Timer2 timer;
+ int display_stat;
};
extern Statistics global_stats;
};
extern Statistics global_stats;