X-Git-Url: http://git.tdb.fi/?a=blobdiff_plain;f=source%2F3d%2Ftrack.h;h=9b70b630a5fd1f0a7e88bf418b21a66629901b1e;hb=2fb2e58685c521ea76aab9f6d7cffe1186c9814a;hp=a9154b7c6bbb628fb486d7d934601224a03a37ce;hpb=52cbe8d99669f843f8f75c51128e2748584dd03a;p=r2c2.git diff --git a/source/3d/track.h b/source/3d/track.h index a9154b7..9b70b63 100644 --- a/source/3d/track.h +++ b/source/3d/track.h @@ -1,42 +1,43 @@ -#ifndef MARKLIN3D_TRACK_H_ -#define MARKLIN3D_TRACK_H_ +#ifndef R2C2_3D_TRACK_H_ +#define R2C2_3D_TRACK_H_ #include -#include -#include -#include "libmarklin/track.h" -#include "libmarklin/trackpart.h" -#include "misc.h" +#include +#include +#include +#include "libr2c2/track.h" +#include "libr2c2/trackpart.h" +#include "object.h" -namespace Marklin { +namespace R2C2 { -class Track3D +class Endpoint3D; +class Path3D; +class TrackType3D; + +class Track3D: public Object3D, public Msp::GL::ObjectInstance { +private: + Track &track; + const TrackType3D &type; + std::vector endpoints; + public: - Track3D(Track &, unsigned); - void set_color(const Color &c) { color=c; } - void set_quality(unsigned); - void get_bounds(float, Point &, Point &) const; + Track3D(Layout3D &, Track &); + ~Track3D(); + + Layout3D &get_layout() const { return layout; } Track &get_track() const { return track; } - void render(); - void render_endpoints(); - void render_route(int); + const TrackType3D &get_type() const { return type; } + + virtual Vector get_node() const; + virtual bool is_visible() const { return true; } + + virtual void setup_render(Msp::GL::Renderer &, const Msp::GL::Tag &) const; private: - Track &track; - Color color; - std::vector border; - Msp::GL::VertexArray varray; - std::vector base_seq; - std::vector rail_seq; - std::vector > route_seq; - unsigned quality; - - void prepare_render(); - void build_object(); - void build_part(const TrackPart &, Msp::GL::VertexArrayBuilder &, unsigned &); + void link_changed(unsigned, Track *); }; -typedef std::list Track3DSeq; -} // namespace Marklin +} // namespace R2C2 #endif