projects
/
supertux.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
* Add Airship (regular above-ground theme) and Battle (castle/boss theme) music court...
[supertux.git]
/
src
/
badguy
/
stalactite.cpp
diff --git
a/src/badguy/stalactite.cpp
b/src/badguy/stalactite.cpp
index
f151b67
..
f810d7c
100644
(file)
--- a/
src/badguy/stalactite.cpp
+++ b/
src/badguy/stalactite.cpp
@@
-36,6
+36,7
@@
Stalactite::Stalactite(const lisp::Lisp& lisp)
: BadGuy(lisp, "images/creatures/stalactite/stalactite.sprite", LAYER_TILES - 1), state(STALACTITE_HANGING)
{
countMe = false;
: BadGuy(lisp, "images/creatures/stalactite/stalactite.sprite", LAYER_TILES - 1), state(STALACTITE_HANGING)
{
countMe = false;
+ set_colgroup_active(COLGROUP_TOUCHABLE);
}
void
}
void
@@
-65,6
+66,7
@@
Stalactite::active_update(float elapsed_time)
if(timer.check()) {
state = STALACTITE_FALLING;
physic.enable_gravity(true);
if(timer.check()) {
state = STALACTITE_FALLING;
physic.enable_gravity(true);
+ set_colgroup_active(COLGROUP_MOVING);
}
} else if(state == STALACTITE_FALLING || state == STALACTITE_SQUISHED) {
movement = physic.get_movement(elapsed_time);
}
} else if(state == STALACTITE_FALLING || state == STALACTITE_SQUISHED) {
movement = physic.get_movement(elapsed_time);
@@
-108,11
+110,12
@@
HitResponse
Stalactite::collision_badguy(BadGuy& other, const CollisionHit& hit)
{
if (state == STALACTITE_SQUISHED) return FORCE_MOVE;
Stalactite::collision_badguy(BadGuy& other, const CollisionHit& hit)
{
if (state == STALACTITE_SQUISHED) return FORCE_MOVE;
- if (state != STALACTITE_FALLING) return BadGuy::collision_badguy(other, hit);
// ignore other Stalactites
if (dynamic_cast<Stalactite*>(&other)) return FORCE_MOVE;
// ignore other Stalactites
if (dynamic_cast<Stalactite*>(&other)) return FORCE_MOVE;
+ if (state != STALACTITE_FALLING) return BadGuy::collision_badguy(other, hit);
+
if (other.is_freezable()) {
other.freeze();
} else {
if (other.is_freezable()) {
other.freeze();
} else {