X-Git-Url: http://git.tdb.fi/?a=blobdiff_plain;f=source%2Flibmarklin%2Ftracktype.h;h=902a2f6ddd561df38ecb1c84dbdfbb0fb3d2c79b;hb=45ec6f645ff2c303700711e96421c75acf33db1a;hp=ba1b95ff6aee5148d5335f47648e9c2e5de84b00;hpb=3df8cb5c78fbb0b919bcb79677c6c788b8028482;p=r2c2.git diff --git a/source/libmarklin/tracktype.h b/source/libmarklin/tracktype.h index ba1b95f..902a2f6 100644 --- a/source/libmarklin/tracktype.h +++ b/source/libmarklin/tracktype.h @@ -1,7 +1,7 @@ /* $Id$ This file is part of the MSP Märklin suite -Copyright © 2006-2009 Mikkosoft Productions, Mikko Rasa +Copyright © 2006-2010 Mikkosoft Productions, Mikko Rasa Distributed under the GPL */ @@ -9,7 +9,7 @@ Distributed under the GPL #define LIBMARKLIN_TRACKTYPE_H_ #include -#include "endpoint.h" +#include "geometry.h" #include "trackpart.h" namespace Marklin { @@ -17,6 +17,15 @@ namespace Marklin { class TrackType { public: + struct Endpoint + { + Point pos; + float dir; // Direction outwards from the endpoint + unsigned paths; + + Endpoint(float, float, float, unsigned); + }; + class Loader: public Msp::DataFile::BasicLoader { public: @@ -28,10 +37,11 @@ public: }; private: - unsigned art_nr; - std::string description; + unsigned art_nr; + std::string description; std::vector parts; std::vector endpoints; + bool double_address; public: TrackType(unsigned); @@ -39,13 +49,18 @@ public: unsigned get_article_number() const { return art_nr; } const std::string &get_description() const { return description; } float get_total_length() const; - float get_route_length(int) const; - unsigned get_n_routes() const; + float get_path_length(int) const; + unsigned get_paths() const; + unsigned get_n_paths() const; + bool is_turnout() const; + bool is_dead_end() const; + bool is_double_address() const { return double_address; } const std::vector &get_parts() const { return parts; } - const std::vector &get_endpoints() const { return endpoints; } + const std::vector &get_endpoints() const { return endpoints; } + TrackPoint get_point(unsigned, unsigned, float) const; private: - void collect_endpoints(); + void collect_endpoints(); }; } // namespace Marklin