X-Git-Url: http://git.tdb.fi/?a=blobdiff_plain;f=source%2Fdesigner%2Fdesigner.h;h=e103a749a4f41a2d4c0bd286f1975dee00c9b7bb;hb=010d8321e982d1684fcbff5bf6fc2bdec7cb7bae;hp=553b25c3e4faf91d35f554c68128fe53a2c832f4;hpb=52cbe8d99669f843f8f75c51128e2748584dd03a;p=r2c2.git diff --git a/source/designer/designer.h b/source/designer/designer.h index 553b25c..e103a74 100644 --- a/source/designer/designer.h +++ b/source/designer/designer.h @@ -1,9 +1,23 @@ +/* $Id$ + +This file is part of the MSP Märklin suite +Copyright © 2006-2008 Mikkosoft Productions, Mikko Rasa +Distributed under the GPL +*/ + #ifndef DESIGNER_H_ #define DESIGNER_H_ #include #include +#include +#include +#include #include +#include +#include +#include +#include #include #include "libmarklin/catalogue.h" #include "libmarklin/layout.h" @@ -14,17 +28,10 @@ class Input; class Manipulator; class Measure; class Selection; +class Toolbar; class Designer: public Msp::Application { -public: - Designer(int, char **); - Marklin::Layout *get_layout() { return layout; } - Marklin::Layout3D *get_layout_3d() { return layout_3d; } - Msp::GL::Font &get_font() { return *font; } - int main(); - void map_pointer_coords(int, int, float &, float &); - ~Designer(); private: enum Mode { @@ -35,56 +42,88 @@ private: INPUT }; - unsigned screen_w; - unsigned screen_h; - Msp::GL::Font *font; + Msp::Graphics::Display *dpy; + Msp::Graphics::Window *wnd; + Msp::Graphics::GLContext *glc; + unsigned screen_w; + unsigned screen_h; + Msp::GLtk::Resources ui_res; + Msp::GLtk::Root *root; + + Toolbar *toolbar; + Msp::GLtk::Label *lbl_tooltip; + Msp::Time::TimeStamp tooltip_timeout; + Marklin::Catalogue catalogue; - Marklin::Layout *layout; - Marklin::Layout3D *layout_3d; - Marklin::Layout *cat_layout; - Marklin::Layout3D *cat_layout_3d; - Selection *selection; - Manipulator *manipulator; - Measure *measure; - Input *input; - Mode mode; - float cam_yaw; - float cam_pitch; + Marklin::Layout *cat_layout; + Marklin::Layout3D *cat_layout_3d; + std::string filename; + Marklin::Layout *layout; + Marklin::Layout3D *layout_3d; + Msp::GL::Mesh *base_mesh; + Marklin::Route *cur_route; + + Mode mode; + Selection *selection; + Manipulator *manipulator; + Measure *measure; + Input *input; + + float cam_yaw; + float cam_pitch; Marklin::Point cam_pos; - bool shift; - int move_x; - int move_y; - int zoom; - int rotate; - int pitch; - int pointer_x; - int pointer_y; - int tooltip_x; - int tooltip_y; - std::string tooltip; - Msp::Time::TimeStamp tooltip_timeout; + + bool shift; + int move_x; + int move_y; + int zoom; + int rotate; + int pitch; + int pointer_x; + int pointer_y; + Msp::Time::TimeStamp last_tick; + static Msp::Application::RegApp reg; + +public: + Designer(int, char **); + ~Designer(); + + int main(); + void save(); + void quit(); + + Marklin::Layout *get_layout() { return layout; } + Marklin::Layout3D *get_layout_3d() { return layout_3d; } + const Msp::GLtk::Resources &get_ui_resources() const { return ui_res; } + Msp::GLtk::Root &get_root() const { return *root; } + void edit_route(Marklin::Route &); + Marklin::Route *get_current_route() const { return cur_route; } + void add_selection_to_route(); + + void map_pointer_coords(int, int, float &, float &); +private: void tick(); void key_press(unsigned, unsigned, wchar_t); void key_release(unsigned, unsigned); - void button_press(int, int, float, float, unsigned); - void pointer_motion(int, int, float, float); + void button_press(int, int, unsigned, unsigned); + void pointer_motion(int, int); void project_3d(); void apply_camera(); void render(); Marklin::Track3D *pick_track(int, int); + void update_track_color(Marklin::Track3D &); void manipulation_status(const std::string &); void manipulation_done(bool); void measure_changed(); void measure_done(); - void move_tooltip(int, int); + void set_tooltip(int, int, const std::string &); + void clear_tooltip(); void save_accept(); void turnout_id_accept(); void sensor_id_accept(); void input_dismiss(); - - static Msp::Application::RegApp reg; }; #endif