X-Git-Url: http://git.tdb.fi/?a=blobdiff_plain;f=source%2Flibr2c2%2Fsignal.h;h=b6049516c45b6ffa18db0c664cdfccbfdf984a6b;hb=b88d3630a0e3fdd763db018bbe5dbfe3180a95f2;hp=dcaa17a3cd997dba36a5cdedc03badae601cc8df;hpb=176634834df3ac62646d1aec78e35f9364750d7d;p=r2c2.git diff --git a/source/libr2c2/signal.h b/source/libr2c2/signal.h index dcaa17a..b604951 100644 --- a/source/libr2c2/signal.h +++ b/source/libr2c2/signal.h @@ -4,16 +4,17 @@ #include #include #include "geometry.h" +#include "object.h" +#include "signaltype.h" +#include "track.h" namespace R2C2 { class Block; class Layout; -class SignalType; -class Track; class Train; -class Signal +class Signal: public Object { public: class Loader: public Msp::DataFile::ObjectLoader @@ -23,16 +24,13 @@ public: private: void address(unsigned); - void direction(float); void position(float, float, float); + void rotation(float); }; private: - Layout &layout; const SignalType &type; unsigned address; - Vector position; - float direction; Track *track; Block *block; unsigned entry; @@ -45,16 +43,24 @@ public: Signal(Layout &, const SignalType &); ~Signal(); - const SignalType &get_type() const { return type; } + virtual Signal *clone(Layout * = 0) const; + virtual const SignalType &get_type() const { return type; } void set_address(unsigned); - void set_position(const Vector &); - void set_direction(float); + virtual void set_position(const Vector &); + virtual void set_rotation(float); private: void normalize_location(); public: - const Vector &get_position() const { return position; } - float get_direction() const { return direction; } + virtual Track *get_parent() const { return track; } + + virtual unsigned get_n_snap_nodes() const; + virtual Snap get_snap_node(unsigned) const; +private: + virtual SnapType get_default_snap_type_to(const Object &) const; + +public: + virtual bool collide_ray(const Vector &, const Vector &) const; void tick(const Msp::Time::TimeDelta &);