X-Git-Url: http://git.tdb.fi/?a=blobdiff_plain;f=source%2Fdesigner%2Fmanipulator.h;h=55d2425ad8bfdb98596bd33877da65eaa25e18a8;hb=8e3009751ee81e0e5312cae53ee844bdd9e49628;hp=9177f971b66d2d63011d69601306287b4dca1c8e;hpb=449fb5de95ddb2ac9da4bd72a1c12150505d5549;p=r2c2.git diff --git a/source/designer/manipulator.h b/source/designer/manipulator.h index 9177f97..55d2425 100644 --- a/source/designer/manipulator.h +++ b/source/designer/manipulator.h @@ -9,7 +9,6 @@ Distributed under the GPL #define MANIPULATOR_H_ #include -#include "3d/track.h" class Designer; class Selection; @@ -22,7 +21,8 @@ private: NONE, MOVE, ROTATE, - ELEVATE + ELEVATE, + EXTEND }; struct MTrack @@ -42,28 +42,17 @@ private: TrackOrder(Marklin::Track *t, bool r): track(t), rev(r) { } }; - struct TrackWrap - { - Marklin::Point pos; - float rot; - float width; - float height; - }; - public: sigc::signal signal_status; sigc::signal signal_done; private: Designer &designer; - Selection *selection; + Msp::Graphics::EventSource &event_source; + Selection &selection; std::vector tracks; Marklin::Point center; - std::list wrap; - Marklin::Point wrap_pos; - float wrap_rot; - Marklin::Point gpointer; int pointer_y; Mode mode; @@ -72,27 +61,28 @@ private: float rot_origin; int elev_origin; std::set neighbors; - sigc::connection selection_changed_conn; + std::vector extend_tracks; public: - Manipulator(Designer &); + Manipulator(Designer &, Msp::Graphics::EventSource &, Selection &); - void set_selection(Selection *); 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); - void render(); private: + void button_press(int, int, unsigned, unsigned); + void pointer_motion(int, int); void selection_changed(); - void update_wrap(); + void update_tracks(); void update_neighbors(); void set_slope(TrackOrder &, float, float); + std::vector create_straight(const Marklin::Point &, float, float, float); }; #endif