#include "HYDROData_ArtificialObject.h"
+#include <TopoDS_Face.hxx>
+#include <TopoDS_Wire.hxx>
+
class Handle(HYDROData_Polyline3D);
class Handle(HYDROData_Profile);
class TopTools_SequenceOfShape;
*/
class HYDROData_Channel : public HYDROData_ArtificialObject
{
+public:
+
+ struct PrsDefinition
+ {
+ TopoDS_Shape myPrs3D;
+ TopoDS_Face myPrs2D;
+ TopoDS_Wire myLeftBank;
+ TopoDS_Wire myRightBank;
+ TopoDS_Wire myInlet;
+ TopoDS_Wire myOutlet;
+ };
+
protected:
/**
* Enumeration of tags corresponding to the persistent object parameters.
};
public:
+
DEFINE_STANDARD_RTTI(HYDROData_Channel);
+public:
+
+ /**
+ * Creates the presentations(2D and 3D) by given guide line and profile.
+ */
+ HYDRODATA_EXPORT static bool CreatePresentations( const Handle(HYDROData_Polyline3D)& theGuideLine,
+ const Handle(HYDROData_Profile)& theProfile,
+ PrsDefinition& thePrs );
+
+public:
+
/**
* Returns the kind of this object. Must be redefined in all objects of known type.
*/
*/
HYDRODATA_EXPORT virtual void Update();
+ /**
+ * Checks that object has 2D presentation. Reimlemented to retun true.
+ */
+ HYDRODATA_EXPORT virtual bool IsHas2dPrs() const;
+
/**
* Returns default filling color for new channel.
*/
* Returns the type of child altitude object.
* Reimplemented to create chanel altitude object.
*/
- virtual ObjectKind getAltitudeObjectType() const;
-
-private:
-
- void findEdges( const TopTools_SequenceOfShape& theInShapes,
- const TopTools_ListOfShape& theEdges3D,
- TopTools_SequenceOfShape& theOutShapes ) const;
-
- void findEdges( const TopTools_SequenceOfShape& theInShapes,
- const TopoDS_Shape& theEdge3D,
- TopTools_SequenceOfShape& theOutShapes ) const;
+ HYDRODATA_EXPORT virtual ObjectKind getAltitudeObjectType() const;
protected: