-/* $Id$
-
-This file is part of the MSP Märklin suite
-Copyright © 2006-2008 Mikkosoft Productions, Mikko Rasa
-Distributed under the GPL
-*/
-
#ifndef MANIPULATOR_H_
#define MANIPULATOR_H_
-#include <sigc++/sigc++.h>
+#include <set>
+#include <vector>
+#include "libr2c2/object.h"
+#include "tool.h"
-class Designer;
class Selection;
-class Manipulator
+class Manipulator: public Tool
{
-private:
- enum Mode
- {
- NONE,
- MOVE,
- ROTATE,
- ELEVATE,
- EXTEND
- };
-
- struct MTrack
+protected:
+ struct MObject
{
- Marklin::Track *track;
- Marklin::Point pos;
- float rot;
+ R2C2::Object *object;
+ R2C2::Vector original_position;
+ R2C2::Angle original_rotation;
- MTrack(Marklin::Track *);
- };
-
- struct TrackOrder
- {
- Marklin::Track *track;
- bool rev;
-
- TrackOrder(Marklin::Track *t, bool r): track(t), rev(r) { }
+ MObject(R2C2::Object *);
};
public:
- sigc::signal<void, const std::string &> signal_status;
sigc::signal<void, bool> signal_done;
-private:
- Designer &designer;
- Selection &selection;
- std::vector<MTrack> tracks;
- Marklin::Point center;
+protected:
+ typedef std::vector<MObject> ObjectArray;
- Marklin::Point gpointer;
- int pointer_y;
- Mode mode;
- Marklin::Point move_origin;
- float angle;
- float rot_origin;
- int elev_origin;
- std::set<Marklin::Track *> neighbors;
- std::vector<Marklin::Track *> extend_tracks;
+ ObjectArray objects;
+ R2C2::Vector center;
public:
- Manipulator(Designer &, Selection &);
+ Manipulator(Designer &, Msp::Input::Keyboard &, Msp::Input::Mouse &, const std::set<R2C2::Object *> &);
+ virtual ~Manipulator();
- void start_move();
- void start_rotate();
- void start_elevate();
- void start_extend();
- void duplicate();
- void flatten();
- void even_slope(bool =false);
- void connect();
- void cancel();
- void button_press(int, int, float, float, unsigned);
- void pointer_motion(int, int, float, float);
private:
- void selection_changed();
- void update_tracks();
- void update_neighbors();
- void set_slope(TrackOrder &, float, float);
- std::vector<Marklin::Track *> create_straight(const Marklin::Point &, float, float, float);
+ virtual void finish();
};
#endif