projects
/
supertux.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
qmax patch to fix bug #0000389 - colors in infoblocks
[supertux.git]
/
src
/
badguy
/
mrbomb.cpp
diff --git
a/src/badguy/mrbomb.cpp
b/src/badguy/mrbomb.cpp
index
74a0d7e
..
1ed8240
100644
(file)
--- a/
src/badguy/mrbomb.cpp
+++ b/
src/badguy/mrbomb.cpp
@@
-21,15
+21,20
@@
#include "mrbomb.hpp"
#include "bomb.hpp"
#include "mrbomb.hpp"
#include "bomb.hpp"
+#include "object/explosion.hpp"
#include "sprite/sprite_manager.hpp"
#include "sprite/sprite_manager.hpp"
+#include "audio/sound_manager.hpp"
MrBomb::MrBomb(const lisp::Lisp& reader)
MrBomb::MrBomb(const lisp::Lisp& reader)
-
: WalkingBadguy(reader, "images/creatures/mr_bomb/mr_bomb.sprite", "left", "right")
+ : WalkingBadguy(reader, "images/creatures/mr_bomb/mr_bomb.sprite", "left", "right")
{
walk_speed = 80;
max_drop_height = 16;
grabbed = false;
{
walk_speed = 80;
max_drop_height = 16;
grabbed = false;
+ //Prevent stutter when Tux jumps on Mr Bomb
+ sound_manager->preload("sounds/explosion.wav");
+
//Check if we need another sprite
if( !reader.get( "sprite", sprite_name ) ){
return;
//Check if we need another sprite
if( !reader.get( "sprite", sprite_name ) ){
return;
@@
-42,13
+47,14
@@
MrBomb::MrBomb(const lisp::Lisp& reader)
sprite = sprite_manager->create( sprite_name );
}
sprite = sprite_manager->create( sprite_name );
}
-/* MrBomb created by a d
espenc
er always gets default sprite atm.*/
+/* MrBomb created by a d
ispens
er always gets default sprite atm.*/
MrBomb::MrBomb(const Vector& pos, Direction d)
MrBomb::MrBomb(const Vector& pos, Direction d)
-
: WalkingBadguy(pos, d, "images/creatures/mr_bomb/mr_bomb.sprite", "left", "right")
+ : WalkingBadguy(pos, d, "images/creatures/mr_bomb/mr_bomb.sprite", "left", "right")
{
walk_speed = 80;
max_drop_height = 16;
grabbed = false;
{
walk_speed = 80;
max_drop_height = 16;
grabbed = false;
+ sound_manager->preload("sounds/explosion.wav");
}
void
}
void
@@
-96,9
+102,8
@@
void
MrBomb::kill_fall()
{
remove_me();
MrBomb::kill_fall()
{
remove_me();
- Bomb* bomb = new Bomb(get_pos(), dir, sprite_name );
- Sector::current()->add_object(bomb);
- bomb->explode();
+ Explosion* explosion = new Explosion(get_bbox().get_middle());
+ Sector::current()->add_object(explosion);
run_dead_script();
}
run_dead_script();
}
@@
-110,7
+115,7
@@
MrBomb::grab(MovingObject&, const Vector& pos, Direction dir)
movement = pos - get_pos();
this->dir = dir;
sprite->set_action(dir == LEFT ? "iced-left" : "iced-right");
movement = pos - get_pos();
this->dir = dir;
sprite->set_action(dir == LEFT ? "iced-left" : "iced-right");
- set_
group
(COLGROUP_DISABLED);
+ set_
colgroup_active
(COLGROUP_DISABLED);
grabbed = true;
}
grabbed = true;
}
@@
-118,7
+123,7
@@
void
MrBomb::ungrab(MovingObject& , Direction dir)
{
this->dir = dir;
MrBomb::ungrab(MovingObject& , Direction dir)
{
this->dir = dir;
- set_
group
(COLGROUP_MOVING);
+ set_
colgroup_active
(COLGROUP_MOVING);
grabbed = false;
}
grabbed = false;
}