X-Git-Url: http://git.tdb.fi/?a=blobdiff_plain;ds=sidebyside;f=source%2Fdesigner%2Fdesigner.cpp;h=1cad9eb251cc686743bc1383c92a1489b54352ac;hb=2ce3226c21dd0ab65a7abaf1cdcec36cc4c09dcc;hp=a59b3a12dd127839616a13190ceb51b7ee345b4f;hpb=b6af6301c76d3664d969a72d8d889020093ac848;p=r2c2.git diff --git a/source/designer/designer.cpp b/source/designer/designer.cpp index a59b3a1..1cad9eb 100644 --- a/source/designer/designer.cpp +++ b/source/designer/designer.cpp @@ -17,6 +17,7 @@ #include #include #include "libr2c2/route.h" +#include "libr2c2/terrain.h" #include "libr2c2/tracktype.h" #include "libr2c2/zone.h" #include "3d/path.h" @@ -35,6 +36,7 @@ #include "selection.h" #include "slopetool.h" #include "svgexporter.h" +#include "terraintool.h" #include "trackbar.h" #include "zonebar.h" #include "zoneproperties.h" @@ -61,6 +63,7 @@ Designer::Designer(int argc, char **argv): // Setup catalogue and layout DataFile::load(catalogue, "tracks.dat"); + DataFile::load(catalogue, "terrain.dat"); cat_layout_3d = new Layout3D(catalogue.get_layout()); @@ -148,9 +151,9 @@ Designer::Designer(int argc, char **argv): cat_view->view_all(true); main_view->view_all(); - const set &tracks = layout->get_all(); - for(set::const_iterator i=tracks.begin(); i!=tracks.end(); ++i) - update_track_icon(layout_3d->get_3d(**i)); + const set &objects = layout->get_all(); + for(set::const_iterator i=objects.begin(); i!=objects.end(); ++i) + update_object_icon(**i); } Designer::~Designer() @@ -406,7 +409,7 @@ void Designer::key_press(unsigned key) if(*j!=*i) (*i)->snap_to(**j, true); - update_track_icon(layout_3d->get_3d(**i)); + update_object_icon(**i); } } else if(key==Msp::Input::KEY_F) @@ -428,6 +431,12 @@ void Designer::key_press(unsigned key) svg_export(); else if(key==Msp::Input::KEY_P) object_properties(); + else if(key==Msp::Input::KEY_TAB) + { + Object *obj = selection.get_object(); + if(Terrain *terrain = dynamic_cast(obj)) + use_tool(new TerrainTool(*this, keyboard, mouse, *terrain)); + } } template @@ -509,25 +518,39 @@ Object *Designer::pick_object(const Vector &pointer) return view.get_layout().get_layout().pick(Ray(cpos, Vector(cray))); } -void Designer::update_track_icon(Track3D &track) +void Designer::update_object_icon(Object &obj) { - overlay->clear(track); + Object3D &obj3d = layout_3d->get_3d(obj); + overlay->clear(obj3d); - if(track.get_track().get_flex()) - overlay->add_graphic(track, "flex"); + if(Track *track = dynamic_cast(&obj)) + { + if(track->get_flex()) + overlay->add_graphic(obj3d, "flex"); - if(unsigned saddr = track.get_track().get_sensor_address()) + if(unsigned saddr = track->get_sensor_address()) + { + overlay->add_graphic(obj3d, "trackcircuit"); + overlay->set_label(obj3d, lexical_cast(saddr)); + } + else if(unsigned taddr = track->get_turnout_address()) + { + if(taddr<0x800) + { + overlay->add_graphic(obj3d, "turnout"); + overlay->set_label(obj3d, lexical_cast(taddr)); + } + } + } + else if(Signal *signal = dynamic_cast(&obj)) { - overlay->add_graphic(track, "sensor"); - overlay->set_label(track, lexical_cast(saddr)); + overlay->add_graphic(obj3d, "signal"); + overlay->set_label(obj3d, lexical_cast(signal->get_address())); } - else if(unsigned taddr = track.get_track().get_turnout_address()) + else if(BeamGate *gate = dynamic_cast(&obj)) { - if(taddr<0x800) - { - overlay->add_graphic(track, "turnout"); - overlay->set_label(track, lexical_cast(taddr)); - } + overlay->add_graphic(obj3d, "beamgate"); + overlay->set_label(obj3d, lexical_cast(gate->get_address())); } } @@ -538,9 +561,9 @@ void Designer::tool_status(const string &status) void Designer::object_properties_response(int) { - const set &tracks = selection.get_objects(); - for(set::const_iterator i=tracks.begin(); i!=tracks.end(); ++i) - update_track_icon(layout_3d->get_3d(**i)); + const set &objects = selection.get_objects(); + for(set::const_iterator i=objects.begin(); i!=objects.end(); ++i) + update_object_icon(**i); } void Designer::route_name_accept(const string &text) @@ -596,6 +619,7 @@ void Designer::show_route(const Route &route) path->set_color(GL::Color(0.5, 0.8, 1.0)); if(unsigned taddr = (*i)->get_turnout_address()) path->set_path(route.get_turnout(taddr)); + highlight_paths.push_back(path); } } @@ -609,5 +633,6 @@ void Designer::show_zone(const Zone &zone) Track3D &t3d = layout_3d->get_3d(**i); Path3D *path = new Path3D(t3d); path->set_color(GL::Color(0.8, 1.0, 0.5)); + highlight_paths.push_back(path); } }