1 #ifndef HYDROData_Polyline_HeaderFile
2 #define HYDROData_Polyline_HeaderFile
4 #include <HYDROData_Object.h>
6 #include <TCollection_ExtendedString.hxx>
9 #include <QPainterPath>
14 DEFINE_STANDARD_HANDLE(HYDROData_Polyline, HYDROData_Object)
16 struct PolylineSection
19 enum SectionType{ SECTION_POLYLINE=0, SECTION_SPLINE=1 };
21 PolylineSection(){ myIsClosed=true; myType=SECTION_POLYLINE; mySectionName="Section";}
22 TCollection_ExtendedString mySectionName;
25 QList<double> myCoords;
28 /**\class HYDROData_Polyline
29 * \brief Class that stores/retreives information about the painter path.
31 * Keeps path as binary array of element type and coordinates
32 * of image with correspondent API for forkind wit hthese properties.
34 class HYDROData_Polyline : public HYDROData_Object
38 typedef QList<PolylineSection> PolylineData;
42 * Enumeration of tags corresponding to the persistent object parameters.
46 DataTag_First = HYDROData_Object::DataTag_First + 100, ///< first tag, to reserve
48 DataTag_SectionsClosed,
55 DEFINE_STANDARD_RTTI(HYDROData_Polyline);
58 * Returns the kind of this object. Must be redefined in all objects of known type.
60 HYDRODATA_EXPORT virtual const ObjectKind GetKind() const {return KIND_POLYLINE;}
63 * Dump object to Python script representation.
65 HYDRODATA_EXPORT virtual QStringList DumpToPython( MapOfTreatedObjects& theTreatedObjects ) const;
68 * Returns data of object wrapped to QVariant.
69 * Reimplemented to wrap and return saved path.
71 HYDRODATA_EXPORT virtual QVariant GetDataVariant();
74 * Replace current polyline data by new sections list
75 * \param theSections the sections list
77 HYDRODATA_EXPORT void setPolylineData( const PolylineData& theSections );
80 * Return polyline data
81 * \return polyline section list
83 HYDRODATA_EXPORT PolylineData getPolylineData() const;
86 * Returns true if polyline is closed
88 HYDRODATA_EXPORT bool isClosed() const;
91 * Return polyline dimension
92 * \return polyline dimension (2 or 3)
94 HYDRODATA_EXPORT int getDimension() const;
97 * Set polyline dimension (2 or 3)
98 * \param theDimension the polyline dimension
100 HYDRODATA_EXPORT void setDimension( int theDimension );
103 * Remove all sections from polyline
105 HYDRODATA_EXPORT void removeAll();
108 * Returns the painter path.
109 * Note: currently only the first section of the polyline data is taken into account.
111 HYDRODATA_EXPORT QPainterPath painterPath() const;
114 * Sets the wire contour of the object.
116 HYDRODATA_EXPORT void SetWire( const TopoDS_Wire& theWire );
119 * Returns the wire contour of the object.
121 HYDRODATA_EXPORT TopoDS_Wire Wire() const;
125 * Update the wire contour on the basis of the polyline data.
127 void UpdateWire( const PolylineData& theSections );
131 friend class HYDROData_Iterator;
134 * Creates new object in the internal data structure. Use higher level objects
135 * to create objects with real content.
137 HYDROData_Polyline();
140 * Destructs properties of the object and object itself, removes it from the document.
142 ~HYDROData_Polyline();