projects
/
supertux.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
- beginnings of a wingling
[supertux.git]
/
src
/
player.h
diff --git
a/src/player.h
b/src/player.h
index
708d2ae
..
6852ebc
100644
(file)
--- a/
src/player.h
+++ b/
src/player.h
@@
-27,12
+27,15
@@
#include "texture.h"
#include "collision.h"
#include "sound.h"
#include "texture.h"
#include "collision.h"
#include "sound.h"
+#include "moving_object.h"
+#include "drawable.h"
#include "physic.h"
/* Times: */
#include "physic.h"
/* Times: */
-#define TUX_SAFE_TIME
7
50
+#define TUX_SAFE_TIME
12
50
#define TUX_INVINCIBLE_TIME 10000
#define TUX_INVINCIBLE_TIME 10000
+#define TUX_INVINCIBLE_TIME_WARNING 2000
#define TIME_WARNING 20000 /* When to alert player they're low on time! */
/* One-ups... */
#define TIME_WARNING 20000 /* When to alert player they're low on time! */
/* One-ups... */
@@
-65,6
+68,7
@@
struct player_input_type
int right;
int left;
int up;
int right;
int left;
int up;
+ int old_up;
int down;
int fire;
int old_fire;
int down;
int fire;
int old_fire;
@@
-101,53
+105,74
@@
struct PlayerSprite
extern PlayerSprite smalltux;
extern PlayerSprite largetux;
extern PlayerSprite firetux;
extern PlayerSprite smalltux;
extern PlayerSprite largetux;
extern PlayerSprite firetux;
+extern PlayerSprite icetux;
-class Player
+class Player
: public MovingObject, public Drawable
{
public:
enum HurtMode { KILL, SHRINK };
{
public:
enum HurtMode { KILL, SHRINK };
+ enum Power { NONE_POWER, FIRE_POWER, ICE_POWER };
+ enum FallMode { ON_GROUND, JUMPING, TRAMPOLINE_JUMP, FALLING };
player_input_type input;
player_input_type input;
-
bool got_coffee
;
+
int got_power
;
int size;
bool duck;
bool holding_something;
int size;
bool duck;
bool holding_something;
+ bool dead;
DyingType dying;
Direction dir;
DyingType dying;
Direction dir;
+ Direction old_dir;
+
+ float last_ground_y;
+ FallMode fall_mode;
bool jumping;
bool jumping;
+ bool can_jump;
+ bool butt_jump;
int frame_;
int frame_main;
int frame_;
int frame_main;
- base_type base;
- base_type old_base;
base_type previous_base;
Timer invincible_timer;
Timer skidding_timer;
Timer safe_timer;
Timer frame_timer;
Timer kick_timer;
base_type previous_base;
Timer invincible_timer;
Timer skidding_timer;
Timer safe_timer;
Timer frame_timer;
Timer kick_timer;
+ Timer shooting_timer; // used to show the arm when Tux is shooting
+ Timer dying_timer;
Physic physic;
public:
Physic physic;
public:
- void init();
+ Player(DisplayManager& display_manager);
+ virtual ~Player();
+
int key_event(SDLKey key, int state);
void level_begin();
int key_event(SDLKey key, int state);
void level_begin();
- void action(double frame_ratio);
void handle_input();
void grabdistros();
void handle_input();
void grabdistros();
- void draw();
+
+ virtual void action(float elapsed_time);
+ virtual void draw(Camera& viewport, int layer);
+ virtual void collision(const MovingObject& other_object,
+ int collision_type);
+
void collision(void* p_c_object, int c_object);
void kill(HurtMode mode);
void collision(void* p_c_object, int c_object);
void kill(HurtMode mode);
- void is_dying();
- bool is_dead();
void player_remove_powerups();
void player_remove_powerups();
- void
keep_in_bounds(
);
+ void
check_bounds(Camera& viewport, bool back_scrolling, bool hor_autoscroll
);
bool on_ground();
bool under_solid();
bool on_ground();
bool under_solid();
+ bool tiles_on_air(int tiles);
+ void grow();
+ void move(const Vector& vector);
+ bool is_dead() const
+ { return dead; }
private:
private:
+ void init();
+
void handle_horizontal_input();
void handle_vertical_input();
void remove_powerups();
void handle_horizontal_input();
void handle_vertical_input();
void remove_powerups();