- if(mystate == STATE_BIG) {
- mystate = STATE_NORMAL;
- activate();
-
-
- sound_manager->play("sounds/mr_tree.ogg", get_pos());
- player.bounce(*this);
- } else {
-bbox.set_size(67.8, 99.8);
-sprite->set_action(dir == LEFT ? "squished-left" : "squished-right");
-sound_manager->play("sounds/mr_treehit.ogg", get_pos());
-player.bounce(*this);
-
+ // replace with Stumpy
+ Vector stumpy_pos = get_pos();
+ stumpy_pos.x += 20;
+ stumpy_pos.y += 25;
+ Stumpy* stumpy = new Stumpy(stumpy_pos, dir);
+ remove_me();
+ Sector::current()->add_object(stumpy);
+
+ // give Feedback
+ sound_manager->play("sounds/mr_tree.ogg", get_pos());
+ player.bounce(*this);
+
+ // spawn some particles
+ // TODO: provide convenience function in MovingSprite or MovingObject?
+ for (int px = (int)stumpy->get_bbox().p1.x; px < (int)stumpy->get_bbox().p2.x; px+=10) {
+ Vector ppos = Vector(px, stumpy->get_bbox().p1.y-5);
+ float angle = systemRandom.randf(-M_PI_2, M_PI_2);
+ float velocity = systemRandom.randf(45, 90);
+ float vx = sin(angle)*velocity;
+ float vy = -cos(angle)*velocity;
+ Vector pspeed = Vector(vx, vy);
+ Vector paccel = Vector(0, 100);
+ Sector::current()->add_object(new SpriteParticle("images/objects/particles/leaf.sprite", "default", ppos, ANCHOR_MIDDLE, pspeed, paccel, LAYER_OBJECTS-1));