projects
/
supertux.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
- fixed level editor crash (a hack)
[supertux.git]
/
src
/
player.h
diff --git
a/src/player.h
b/src/player.h
index
362fbc6
..
21a00a2
100644
(file)
--- a/
src/player.h
+++ b/
src/player.h
@@
-83,6
+83,8
@@
extern Surface* tux_life;
extern Sprite* smalltux_gameover;
extern Sprite* smalltux_star;
extern Sprite* largetux_star;
extern Sprite* smalltux_gameover;
extern Sprite* smalltux_star;
extern Sprite* largetux_star;
+extern Sprite* growingtux_left;
+extern Sprite* growingtux_right;
struct PlayerSprite
{
struct PlayerSprite
{
@@
-112,17
+114,22
@@
class Player : public MovingObject, public Drawable
public:
enum HurtMode { KILL, SHRINK };
enum Power { NONE_POWER, FIRE_POWER, ICE_POWER };
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;
int got_power;
int size;
bool duck;
bool holding_something;
player_input_type input;
int got_power;
int size;
bool duck;
bool holding_something;
+ bool dead;
DyingType dying;
Direction dir;
Direction old_dir;
DyingType dying;
Direction dir;
Direction old_dir;
+ float last_ground_y;
+ FallMode fall_mode;
+
bool jumping;
bool can_jump;
bool butt_jump;
bool jumping;
bool can_jump;
bool butt_jump;
@@
-135,6
+142,9
@@
public:
Timer safe_timer;
Timer frame_timer;
Timer kick_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;
+ Timer growing_timer;
Physic physic;
public:
Physic physic;
public:
@@
-147,21
+157,21
@@
public:
void grabdistros();
virtual void action(float elapsed_time);
void grabdistros();
virtual void action(float elapsed_time);
- virtual void draw(
ViewPort
& viewport, int layer);
+ virtual void draw(
Camera
& viewport, int layer);
virtual void collision(const MovingObject& other_object,
int collision_type);
virtual void collision(const MovingObject& other_object,
int collision_type);
- virtual std::string type() const
- { return "Player"; }
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 check_bounds(
ViewPort& viewport, bool back_scrolling, bool hor_autoscroll
);
+ void check_bounds(
Camera& viewport
);
bool on_ground();
bool under_solid();
bool on_ground();
bool under_solid();
- void grow();
+ bool tiles_on_air(int tiles);
+ void grow(bool animate);
+ void move(const Vector& vector);
+ bool is_dead() const
+ { return dead; }
private:
void init();
private:
void init();