+ reader.read_int_vector("x", &pos_x);
+ reader.read_int_vector("y", &pos_y);
+
+ velocity = 2.0;
+ reader.read_float("velocity", &velocity);
+
+ base.x = pos_x[0];
+ base.y = pos_y[0];
+ base.width = 96;
+ base.height = 40;
+
+ point = 0;
+ move = false;
+
+ frame = 0;
+}
+
+void
+FlyingPlatform::write(LispWriter& writer)
+{
+ writer.start_list("flying-trampoline");
+
+ writer.write_int_vector("x", pos_x);
+ writer.write_int_vector("y", pos_y);
+ writer.write_float("velocity", velocity);
+
+ writer.end_list("flying-trampoline");
+}
+
+void
+FlyingPlatform::draw(Camera& viewport, int )
+{
+img_flying_platform->draw(viewport.world2screen(Vector(base.x, base.y)));
+}
+
+void
+FlyingPlatform::action(float frame_ratio)
+{
+ // TODO: Remove if we're too far off the screen
+
+if(!move)
+ return;
+
+if((unsigned)point+1 != pos_x.size())
+ {
+ if(((pos_x[point+1] > pos_x[point] && base.x >= pos_x[point+1]) ||
+ (pos_x[point+1] < pos_x[point] && base.x <= pos_x[point+1]) ||
+ pos_x[point] == pos_x[point+1]) &&
+ ((pos_y[point+1] > pos_y[point] && base.y >= pos_y[point+1]) ||
+ (pos_y[point+1] < pos_y[point] && base.y <= pos_y[point+1]) ||
+ pos_y[point] == pos_y[point+1]))
+ {
+ point++;
+ }
+ }
+else // last point
+ {
+ // point = 0;
+ // reverse vector
+ return;
+ }
+
+if(pos_x[point+1] > base.x)
+ base.x += velocity * frame_ratio;
+else if(pos_x[point+1] < base.x)
+ base.x -= velocity * frame_ratio;
+
+if(pos_y[point+1] > base.y)
+ base.y += velocity * frame_ratio;
+else if(pos_y[point+1] < base.y)
+ base.y -= velocity * frame_ratio;
+/*
+float x = pos_x[point+1] - pos_x[point];
+float y = pos_y[point+1] - pos_y[point];
+float vel_x = x*velocity / sqrt(x*x + y*y);
+float vel_y = velocity - vel_x;
+
+base.x += vel_x * frame_ratio;
+base.y += vel_y * frame_ratio;
+*/
+}
+
+void
+FlyingPlatform::collision(const MovingObject&, int)
+{
+ // comes later
+}
+
+void
+FlyingPlatform::collision(void *p_c_object, int c_object, CollisionType type)
+{
+(void) p_c_object;
+(void) type;
+
+// Player* pplayer_c = NULL;
+ switch (c_object)
+ {
+ case CO_PLAYER:
+// pplayer_c = (Player*) p_c_object;
+ move = true;
+
+ break;
+
+ default:
+ break;
+
+ }
+}
+
+void load_object_gfx()
+{
+ char sprite_name[16];
+
+ for (int i = 0; i < TRAMPOLINE_FRAMES; i++)
+ {
+ sprintf(sprite_name, "trampoline-%i", i+1);
+ img_trampoline[i] = sprite_manager->load(sprite_name);
+ }
+
+ img_flying_platform = sprite_manager->load("flying_platform");
+}