2 // Copyright (C) 2006 Matthias Braun <matze@braunis.de>
4 // This program is free software: you can redistribute it and/or modify
5 // it under the terms of the GNU General Public License as published by
6 // the Free Software Foundation, either version 3 of the License, or
7 // (at your option) any later version.
9 // This program is distributed in the hope that it will be useful,
10 // but WITHOUT ANY WARRANTY; without even the implied warranty of
11 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
12 // GNU General Public License for more details.
14 // You should have received a copy of the GNU General Public License
15 // along with this program. If not, see <http://www.gnu.org/licenses/>.
17 #include "audio/sound_manager.hpp"
18 #include "object/rock.hpp"
19 #include "supertux/object_factory.hpp"
20 #include "supertux/tile.hpp"
23 const std::string ROCK_SOUND = "sounds/brick.wav"; //TODO use own sound.
26 Rock::Rock(const Vector& pos, std::string spritename) :
27 MovingSprite(pos, spritename),
33 sound_manager->preload(ROCK_SOUND);
36 set_group(COLGROUP_MOVING_STATIC);
39 Rock::Rock(const Reader& reader) :
40 MovingSprite(reader, "images/objects/rock/rock.sprite"),
46 sound_manager->preload(ROCK_SOUND);
49 set_group(COLGROUP_MOVING_STATIC);
52 Rock::Rock(const Reader& reader, std::string spritename)
53 : MovingSprite(reader, spritename)
55 sound_manager->preload(ROCK_SOUND);
58 set_group(COLGROUP_MOVING_STATIC);
62 Rock::update(float elapsed_time)
67 if (on_ground) physic.set_velocity_x(0);
69 movement = physic.get_movement(elapsed_time);
73 Rock::collision_solid(const CollisionHit& hit)
78 if(hit.top || hit.bottom)
79 physic.set_velocity_y(0);
80 if(hit.left || hit.right)
81 physic.set_velocity_x(0);
83 physic.set_velocity(0, 0);
85 if(hit.bottom && !on_ground && !grabbed) {
86 sound_manager->play(ROCK_SOUND, get_pos());
92 Rock::collision(GameObject& other, const CollisionHit& hit)
98 if(hit.bottom && physic.get_velocity_y() > 200) {
99 MovingObject* moving_object = dynamic_cast<MovingObject*> (&other);
101 //Getting a rock on the head hurts. A lot.
102 moving_object->collision_tile(Tile::HURTS);
112 Rock::grab(MovingObject& , const Vector& pos, Direction)
114 movement = pos - get_pos();
115 last_movement = movement;
116 set_group(COLGROUP_TOUCHABLE);
122 Rock::ungrab(MovingObject& , Direction dir)
124 set_group(COLGROUP_MOVING_STATIC);
127 physic.set_velocity(0, -500);
128 } else if (last_movement.norm() > 1) {
129 physic.set_velocity((dir == RIGHT) ? 200 : -200, -200);
131 physic.set_velocity(0, 0);
136 IMPLEMENT_FACTORY(Rock, "rock");