2 // object.cpp: Base class for all CAD objects
4 // Part of the Architektonas Project
5 // (C) 2011 Underground Software
6 // See the README and GPLv3 files for licensing and warranty information
8 // JLH = James Hammons <jlhamm@acm.org>
11 // --- ---------- ------------------------------------------------------------
12 // JLH 03/22/2011 Created this file
13 // JLH 04/01/2011 Added constructor to allow derived objects to have empty
14 // constructor bodies, added state querying
15 // JLH 04/02/2001 Added static methods for global states (fixed angle, etc)
21 // Initialize static variables
22 bool Object::fixedAngle = false;
23 bool Object::fixedLength = false;
24 QFont * Object::font = 0;
25 int Object::viewportHeight = 0;
26 bool Object::deleteActive = false;
27 bool Object::dimensionActive = false;
28 bool Object::snapToGrid = true;
29 //snapToPoints all well here?
30 bool Object::ignoreClicks = false;
31 bool Object::dontMove = false;
34 Object::Object(): position(Vector(0, 0)), parent(0), type(OTObject),
35 state(OSInactive), oldState(OSInactive), needUpdate(false)
36 //, attachedDimension(0)
41 Object::Object(Vector v, Object * passedInParent/*= 0*/): position(v), parent(passedInParent),
42 state(OSInactive), oldState(OSInactive), needUpdate(false)//, attachedDimension(0)
49 printf("Object: Destroyed!\n");
50 for(uint i=0; i<connected.size(); i++)
51 connected[i].object->DisconnectAll(this);
55 /*virtual*/ void Object::Draw(Painter *)
60 /*virtual*/ Vector Object::Center(void)
66 /*virtual*/ bool Object::Collided(Vector)
72 /*virtual*/ void Object::PointerMoved(Vector)
77 /*virtual*/ void Object::PointerReleased(void)
82 /*virtual*/ bool Object::NeedsUpdate(void)
88 // This is intended to be overridden by the Container class, for object morphing
89 /*virtual*/ void Object::Transmute(Object *, Object *)
94 /*virtual*/ Object * Object::GetParent(void)
100 /*virtual*/ void Object::Add(Object *)
105 // This returns a pointer to the point passed in, if it coincides. Otherwise returns NULL.
106 /*virtual*/ Vector * Object::GetPointAt(Vector)
112 // This is meant for writing object data to a file.
113 /*virtual*/ void Object::Enumerate(FILE *)
118 /*virtual*/ Object * Object::Copy(void)
120 return new Object(position, parent);
124 // This returns a point on the object at 'parameter', which is between 0 and 1.
125 // Default is to return the object's position.
126 /*virtual*/ Vector Object::GetPointAtParameter(double)
132 // Since these functions are pretty much non-object specific, we can implement
134 /*virtual*/ void Object::Connect(Object * obj, double parameter)
136 connected.push_back(Connection(obj, parameter));
140 /*virtual*/ void Object::Disconnect(Object * obj, double parameter)
142 for(uint i=0; i<connected.size(); i++)
144 if (connected[i].object == obj && connected[i].t == parameter)
146 connected.erase(connected.begin() + i);
153 /*virtual*/ void Object::DisconnectAll(Object * obj)
155 // According the std::vector docs, only items at position i and beyond are
156 // invalidated, everything before i is still valid. So we use that here.
157 for(uint i=0; i<connected.size();)
159 // If we found our object, erase it from the vector but don't advance
160 // the iterator. Otherwise, advance the iterator. :-)
161 if (connected[i].object == obj)
162 connected.erase(connected.begin() + i);
169 /*virtual*/ QRectF Object::Extents(void)
171 // Generic object returns an empty rect...
177 /*virtual*/ ObjectType Object::Type(void)
184 ObjectState Object::GetState(void)
190 void Object::Reparent(Object * newParent)
196 /*Dimension * Object::GetAttachedDimension(void)
198 return attachedDimension;
204 void Object::SetFixedAngle(bool state/*= true*/)
210 void Object::SetFixedLength(bool state/*= true*/)
216 void Object::SetFont(QFont * f)
222 void Object::SetViewportHeight(int height)
224 viewportHeight = height;
228 void Object::SetDeleteActive(bool state/*= true*/)
230 deleteActive = state;
234 void Object::SetDimensionActive(bool state/*= true*/)
236 dimensionActive = state;
240 void Object::SetSnapMode(bool state/*= true*/)