X-Git-Url: http://shamusworld.gotdns.org/cgi-bin/gitweb.cgi?a=blobdiff_plain;f=src%2Fobject.h;h=ff29e1f7618328b5fa7689efc95c4ec6a6221b51;hb=7f3a6b11585376eecd80979ec3da2346c5314d88;hp=0a72328cc6d8446b0804d1792c38240407a1b5af;hpb=642cf72c11b49a9e00128ab6258a2438c785a5ab;p=architektonas diff --git a/src/object.h b/src/object.h index 0a72328..ff29e1f 100644 --- a/src/object.h +++ b/src/object.h @@ -13,10 +13,12 @@ class Dimension; //class FILE; enum ObjectState { OSInactive, OSSelected }; -enum ObjectType { OTNone, OTObject, OTLine, OTCircle, OTArc, OTDimension, OTEllipse, OTContainer }; +enum ObjectType { OTNone, OTObject, OTLine, OTCircle, OTArc, OTDimension, OTEllipse, OTContainer, OTSpline }; class Object { + friend class Geometry; + public: Object(); Object(Vector, Object * passedInParent = 0); @@ -25,7 +27,7 @@ class Object virtual void Draw(Painter *); virtual Vector Center(void); virtual bool Collided(Vector); - virtual void PointerMoved(Vector); + virtual bool PointerMoved(Vector); virtual void PointerReleased(void); virtual bool NeedsUpdate(void); virtual bool HitTest(Point); @@ -36,18 +38,19 @@ class Object virtual void Enumerate(FILE *); virtual Object * Copy(void); virtual Vector GetPointAtParameter(double parameter); +//Not yet, soon though virtual void MovePointAtParameter(double parameter, Vector); virtual void Connect(Object *, double); virtual void Disconnect(Object *, double); virtual void DisconnectAll(Object *); virtual QRectF Extents(void); -// virtual ObjectType Type(void);// = 0; // Pure virtual, must be implemented virtual void Translate(Vector); - virtual void Rotate(Vector, double); - virtual void Scale(Vector, double); + virtual void Rotate(Point, double); + virtual void Scale(Point, double); + virtual void Mirror(Point, Point); + virtual void Save(void); + virtual void Restore(void); ObjectState GetState(void); void Reparent(Object *); -// Dimension * GetAttachedDimension(void); -//Hm. Object * Connect(Object *); // Class methods static void SetFixedAngle(bool state = true); @@ -59,11 +62,14 @@ class Object static void SetSnapMode(bool state = true); static Vector SnapPointToGrid(Vector); - protected: + public: Vector position; // All objects have a position (doubles as reference point) + protected: Object * parent; +//this needs to be added eventually // Pen pen; // Fill fill; + Point oldPosition; public: ObjectType type; ObjectState state; @@ -71,7 +77,6 @@ class Object protected: ObjectState oldState; bool needUpdate; -// Dimension * attachedDimension; std::vector connected; // Class variables @@ -92,6 +97,8 @@ class Object static QRectF selection; static double gridSpacing; // Grid spacing in base units static int currentLayer; + static Point snapPoint; + static bool snapPointIsValid; }; #endif // __OBJECT_H__