X-Git-Url: http://git.salome-platform.org/gitweb/?a=blobdiff_plain;f=src%2FHYDROData%2FHYDROData_Polyline.h;h=78f8736efaf44a97d8a7e7f8ccad45d298af2546;hb=c374597f70481110faa82dc189353d689d66bc0c;hp=61a22bbcfc581ec88c072539321e8111f743ca18;hpb=b58558f56e97ff01757710155cd9a8429b34ae46;p=modules%2Fhydro.git diff --git a/src/HYDROData/HYDROData_Polyline.h b/src/HYDROData/HYDROData_Polyline.h index 61a22bbc..78f8736e 100755 --- a/src/HYDROData/HYDROData_Polyline.h +++ b/src/HYDROData/HYDROData_Polyline.h @@ -3,12 +3,28 @@ #include +#include + #include #include #include +class TopoDS_Wire; + DEFINE_STANDARD_HANDLE(HYDROData_Polyline, HYDROData_Object) +struct PolylineSection +{ +public: + enum SectionType{ SECTION_POLYLINE=0, SECTION_SPLINE=1 }; + + PolylineSection(){ myIsClosed=true; myType=SECTION_POLYLINE; mySectionName="Section";} + TCollection_ExtendedString mySectionName; + SectionType myType; + bool myIsClosed; + QList myCoords; +}; + /**\class HYDROData_Polyline * \brief Class that stores/retreives information about the painter path. * @@ -17,6 +33,24 @@ DEFINE_STANDARD_HANDLE(HYDROData_Polyline, HYDROData_Object) */ class HYDROData_Polyline : public HYDROData_Object { +public: + + typedef QList PolylineData; + +protected: + /** + * Enumeration of tags corresponding to the persistent object parameters. + */ + enum DataTag + { + DataTag_First = HYDROData_Object::DataTag_First + 100, ///< first tag, to reserve + DataTag_SectionsName, + DataTag_SectionsClosed, + DataTag_SectionsSize, + DataTag_SectionsType, + DataTag_ZValue + }; + public: DEFINE_STANDARD_RTTI(HYDROData_Polyline); @@ -26,53 +60,75 @@ public: HYDRODATA_EXPORT virtual const ObjectKind GetKind() const {return KIND_POLYLINE;} /** - * Replace current array by points list - * \param thePoint the point to add + * Returns the top shape of the object. */ - HYDRODATA_EXPORT void setPoints( QList thePointsList ); + HYDRODATA_EXPORT virtual TopoDS_Shape GetTopShape() const; /** - * Add point to the end of point list - * \param thePoint the point to add + * Returns the 3d shape of the object. */ - HYDRODATA_EXPORT void addPoint( const QPointF& thePoint ); - + HYDRODATA_EXPORT virtual TopoDS_Shape GetShape3D() const; + /** - * Add point to the point list at the specified position - * \param theIndex the index of the list the point will insert after + * Dump object to Python script representation. */ - HYDRODATA_EXPORT bool insertPoint( int theIndex, const QPointF& thePoint); + HYDRODATA_EXPORT virtual QStringList DumpToPython( MapOfTreatedObjects& theTreatedObjects ) const; /** - * Remove point from polyline - * \param theIndex the point index + * Returns data of object wrapped to QVariant. + * Reimplemented to wrap and return saved path. */ - HYDRODATA_EXPORT bool removePoint( int theIndex ); + HYDRODATA_EXPORT virtual QVariant GetDataVariant(); /** - * Remove all points from polyline - * \param theIndex the point index + * Replace current polyline data by new sections list + * \param theSections the sections list */ - HYDRODATA_EXPORT void removeAllPoints(); + HYDRODATA_EXPORT void SetPolylineData( const PolylineData& theSections ); /** - * Return list point count - * \return list point count + * Return polyline data + * \return polyline section list + */ + HYDRODATA_EXPORT PolylineData GetPolylineData() const; + + /** + * Returns true if polyline is closed */ - HYDRODATA_EXPORT int pointsCount(); + HYDRODATA_EXPORT bool IsClosed() const; /** - * Returns list of points - * \return list of points + * Return polyline dimension + * \return polyline dimension (2 or 3) */ - HYDRODATA_EXPORT QList points(); + HYDRODATA_EXPORT int GetDimension() const; + /** + * Set polyline dimension (2 or 3) + * \param theDimension the polyline dimension + */ + HYDRODATA_EXPORT void SetDimension( int theDimension ); /** - * Returns the painter path. The painter path is construct by lines + * Remove all sections from polyline */ - HYDRODATA_EXPORT QPainterPath painterPathLinear(); + HYDRODATA_EXPORT void RemoveAll(); + /** + * Returns the painter path. + * Note: currently only the first section of the polyline data is taken into account. + */ + HYDRODATA_EXPORT QPainterPath GetPainterPath() const; + + HYDRODATA_EXPORT void SetZValue( const double theZValue ); + HYDRODATA_EXPORT double ZValue() const; + +protected: + + /** + * Update the wire contour on the basis of the polyline data. + */ + void UpdateWire( const PolylineData& theSections ); protected: @@ -88,7 +144,6 @@ protected: * Destructs properties of the object and object itself, removes it from the document. */ ~HYDROData_Polyline(); - }; #endif