X-Git-Url: http://git.tdb.fi/?a=blobdiff_plain;f=source%2Flibr2c2%2Ftracktype.h;h=2a116134d850b0353a0ba1f2586bea15caa52a2d;hb=81ee4fbd16b472892b67b35ea85956423a2247ed;hp=1b1c78ce998de86b736d252774643bce2346bfba;hpb=64340dad429ba4040538fc06b6882aabdb489925;p=r2c2.git diff --git a/source/libr2c2/tracktype.h b/source/libr2c2/tracktype.h index 1b1c78c..2a11613 100644 --- a/source/libr2c2/tracktype.h +++ b/source/libr2c2/tracktype.h @@ -4,23 +4,29 @@ #include #include "articlenumber.h" #include "geometry.h" +#include "objecttype.h" #include "trackpart.h" namespace R2C2 { -class TrackType +class TrackAppearance; + +class TrackType: public ObjectType { public: struct Endpoint { Vector pos; - float dir; // Direction outwards from the endpoint + Angle dir; // Direction outwards from the endpoint unsigned paths; - Endpoint(float, float, float, unsigned); + Endpoint(float, float, const Angle &, unsigned); + + bool has_path(unsigned p) const { return paths&(1< + class Loader: public Msp::DataFile::DerivedObjectLoader { private: bool state_bits_set; @@ -35,8 +41,7 @@ public: }; private: - ArticleNumber art_nr; - std::string description; + const TrackAppearance *appearance; std::vector parts; std::vector endpoints; unsigned state_bits; @@ -44,14 +49,15 @@ private: std::string object; public: - TrackType(const ArticleNumber &); + TrackType(const ArticleNumber & = ArticleNumber(), const TrackAppearance * = 0); - const ArticleNumber &get_article_number() const { return art_nr; } - const std::string &get_description() const { return description; } + const TrackAppearance &get_appearance() const; + float get_gauge() const; float get_total_length() const; float get_path_length(int) const; unsigned get_paths() const; unsigned get_n_paths() const; + unsigned coerce_path(unsigned, unsigned) const; unsigned get_state_bits() const { return state_bits; } bool is_turnout() const; bool is_dead_end() const; @@ -60,8 +66,8 @@ public: const std::vector &get_parts() const { return parts; } const std::vector &get_endpoints() const { return endpoints; } const Endpoint &get_endpoint(unsigned) const; - TrackPoint get_point(unsigned, unsigned, float) const; - bool collide_ray(const Vector &, const Vector &, float) const; + OrientedPoint get_point(unsigned, unsigned, float) const; + OrientedPoint get_nearest_point(const Vector &) const; private: void collect_endpoints();