#include <Geometry.h>
Public Member Functions | |
virtual Geometry * | clone (void) const |
returns a cloned object | |
GeomLine (const Base::Vector3d &Pos, const Base::Vector3d &Dir) | |
GeomLine (const Handle_Geom_Line &) | |
GeomLine () | |
Base::Vector3d | getDir (void) const |
virtual unsigned int | getMemSize (void) const |
This method is used to get the size of objects It is not meant to have the exact size, it is more or less an estimation which runs fast! Is it two bytes or a GB? | |
Base::Vector3d | getPos (void) const |
virtual PyObject * | getPyObject (void) |
This method returns the Python wrapper for a C++ object. | |
virtual Base::Type | getTypeId (void) const |
const Handle_Geom_Geometry & | handle () const |
virtual void | Restore (Base::XMLReader &) |
This method is used to restore properties from an XML document. | |
virtual void | Save (Base::Writer &) const |
This method is used to save properties to an XML document. | |
void | setLine (const Base::Vector3d &Pos, const Base::Vector3d &Dir) |
virtual | ~GeomLine () |
Static Public Member Functions | |
static void * | create (void) |
static Base::Type | getClassTypeId (void) |
static void | init (void) |
Definition at line 298 of file Geometry.h.
GeomLine::GeomLine | ( | ) |
Definition at line 918 of file Geometry.cpp.
Referenced by clone().
GeomLine::GeomLine | ( | const Handle_Geom_Line & | l | ) |
Definition at line 924 of file Geometry.cpp.
GeomLine::GeomLine | ( | const Base::Vector3d & | Pos, | |
const Base::Vector3d & | Dir | |||
) |
Definition at line 929 of file Geometry.cpp.
References Base::Vector3< _Precision >::x, Base::Vector3< _Precision >::y, and Base::Vector3< _Precision >::z.
GeomLine::~GeomLine | ( | ) | [virtual] |
Definition at line 935 of file Geometry.cpp.
Geometry * GeomLine::clone | ( | void | ) | const [virtual] |
returns a cloned object
Implements Part::Geometry.
Definition at line 962 of file Geometry.cpp.
References Part::Geometry::Construction, and GeomLine().
void * Part::GeomLine::create | ( | void | ) | [static] |
Reimplemented from Part::GeomCurve.
Definition at line 916 of file Geometry.cpp.
Base::Type Part::GeomLine::getClassTypeId | ( | void | ) | [static] |
Reimplemented from Part::GeomCurve.
Definition at line 916 of file Geometry.cpp.
Base::Vector3d GeomLine::getDir | ( | void | ) | const |
Definition at line 951 of file Geometry.cpp.
Referenced by Save().
unsigned int GeomLine::getMemSize | ( | void | ) | const [virtual] |
This method is used to get the size of objects It is not meant to have the exact size, it is more or less an estimation which runs fast! Is it two bytes or a GB?
Reimplemented from Part::Geometry.
Definition at line 970 of file Geometry.cpp.
Base::Vector3d GeomLine::getPos | ( | void | ) | const |
Definition at line 945 of file Geometry.cpp.
Referenced by Save().
PyObject * GeomLine::getPyObject | ( | void | ) | [virtual] |
This method returns the Python wrapper for a C++ object.
It's in the responsibility of the programmer to do the correct reference counting. Basically there are two ways how to implement that: Either always return a new Python object then reference counting is not a matter or return always the same Python object then the reference counter must be incremented by one. However, it's absolutely forbidden to return always the same Python object without incrementing the reference counter.
The default implementation returns 'None'.
Reimplemented from Base::BaseClass.
Definition at line 1014 of file Geometry.cpp.
Base::Type Part::GeomLine::getTypeId | ( | void | ) | const [virtual] |
Reimplemented from Part::GeomCurve.
Definition at line 916 of file Geometry.cpp.
const Handle_Geom_Geometry & GeomLine::handle | ( | ) | const [virtual] |
Implements Part::Geometry.
Definition at line 957 of file Geometry.cpp.
void Part::GeomLine::init | ( | void | ) | [static] |
Reimplemented from Part::GeomCurve.
Definition at line 916 of file Geometry.cpp.
Referenced by initPart().
void GeomLine::Restore | ( | Base::XMLReader & | ) | [virtual] |
This method is used to restore properties from an XML document.
It uses the XMLReader class, which bases on SAX, to read the in Save() written information. Again the Vector as an example:
void PropertyVector::Restore(Base::XMLReader &reader) { // read my Element reader.readElement("PropertyVector"); // get the value of my Attribute _cVec.x = (float)reader.getAttributeAsFloat("valueX"); _cVec.y = (float)reader.getAttributeAsFloat("valueY"); _cVec.z = (float)reader.getAttributeAsFloat("valueZ"); }
Reimplemented from Part::Geometry.
Definition at line 994 of file Geometry.cpp.
References Base::XMLReader::getAttributeAsFloat(), Base::XMLReader::readElement(), and setLine().
void GeomLine::Save | ( | Base::Writer & | ) | const [virtual] |
This method is used to save properties to an XML document.
A good example you'll find in PropertyStandard.cpp, e.g. the vector:
void PropertyVector::Save (Writer &writer) const { writer << writer.ind() << "<PropertyVector valueX=\"" << _cVec.x << "\" valueY=\"" << _cVec.y << "\" valueZ=\"" << _cVec.z <<"\"/>" << endl; }
The writer.ind() expression writes the indention, just for pretty printing of the XML. As you see, the writing of the XML document is not done with a DOM implementation because of performance reasons. Therefore the programmer has to take care that a valid XML document is written. This means closing tags and writing UTF-8.
Reimplemented from Part::Geometry.
Definition at line 975 of file Geometry.cpp.
References getDir(), getPos(), Base::Writer::ind(), Base::Writer::Stream(), Base::Vector3< _Precision >::x, Base::Vector3< _Precision >::y, and Base::Vector3< _Precision >::z.
void GeomLine::setLine | ( | const Base::Vector3d & | Pos, | |
const Base::Vector3d & | Dir | |||
) |
Definition at line 939 of file Geometry.cpp.
References Base::Vector3< _Precision >::x, Base::Vector3< _Precision >::y, and Base::Vector3< _Precision >::z.
Referenced by Restore().