X-Git-Url: http://git.tdb.fi/?a=blobdiff_plain;f=source%2Flibr2c2%2Ftrack.h;h=883fb5eda506ab04a0614bbbebf1333560bbe41f;hb=f950f5a77714a155e57c868101911e181a617818;hp=82365a5ab02127ed5a0742e567bae153bf546cbd;hpb=949b13aae247fa53579ec1cda9142ccc8755acde;p=r2c2.git diff --git a/source/libr2c2/track.h b/source/libr2c2/track.h index 82365a5..883fb5e 100644 --- a/source/libr2c2/track.h +++ b/source/libr2c2/track.h @@ -1,34 +1,29 @@ -/* $Id$ - -This file is part of R²C² -Copyright © 2006-2010 Mikkosoft Productions, Mikko Rasa -Distributed under the GPL -*/ - #ifndef LIBR2C2_TRACK_H_ #define LIBR2C2_TRACK_H_ #include #include #include -#include +#include #include "geometry.h" +#include "object.h" +#include "tracktype.h" namespace R2C2 { class Block; class Layout; -class TrackType; -class Track: public sigc::trackable +class Track: public Object, public sigc::trackable { public: - class Loader: public Msp::DataFile::BasicLoader + class Loader: public Msp::DataFile::ObjectLoader { public: Loader(Track &); private: void position(float, float, float); + void rotation(float); void sensor_id(unsigned); void turnout_id(unsigned); }; @@ -37,17 +32,15 @@ public: sigc::signal signal_path_changed; private: - Layout &layout; const TrackType &type; Block *block; - Point pos; - float rot; float slope; bool flex; unsigned turnout_id; unsigned sensor_id; std::vector links; unsigned active_path; + bool path_changing; Track(const Track &); Track &operator=(const Track &); @@ -55,17 +48,15 @@ public: Track(Layout &, const TrackType &); ~Track(); - Layout &get_layout() const { return layout; } - const TrackType &get_type() const { return type; } + virtual Track *clone(Layout * = 0) const; + virtual const TrackType &get_type() const { return type; } void set_block(Block *); Block &get_block() const; - void set_position(const Point &); - void set_rotation(float); + virtual void set_position(const Vector &); + virtual void set_rotation(float); void set_slope(float); void set_flex(bool); - const Point &get_position() const { return pos; } - float get_rotation() const { return rot; } float get_slope() const { return slope; } bool get_flex() const { return flex; } void check_slope(); @@ -76,18 +67,22 @@ public: unsigned get_sensor_id() const { return sensor_id; } void set_active_path(unsigned); unsigned get_active_path() const { return active_path; } + bool is_path_changing() const { return path_changing; } int get_endpoint_by_link(Track &) const; - Point get_endpoint_position(unsigned) const; + Vector get_endpoint_position(unsigned) const; float get_endpoint_direction(unsigned) const; bool snap_to(Track &, bool, float = 0); - bool snap(Point &, float &) const; + bool snap(Vector &, float &) const; void break_link(Track &); void break_links(); const std::vector &get_links() const { return links; } Track *get_link(unsigned) const; TrackPoint get_point(unsigned, unsigned, float) const; TrackPoint get_point(unsigned, float) const; + TrackPoint get_nearest_point(const Vector &) const; + + virtual bool collide_ray(const Vector &, const Vector &) const; void save(std::list &) const; private: