#include "HYDROData_ArtificialObject.h"
+#include <TopoDS_Face.hxx>
+#include <TopoDS_Wire.hxx>
+
class Handle(HYDROData_Polyline3D);
class Handle(HYDROData_Profile);
+class TopTools_SequenceOfShape;
+class TopTools_ListOfShape;
DEFINE_STANDARD_HANDLE(HYDROData_Channel, HYDROData_ArtificialObject)
*/
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.
+ */
+ HYDRODATA_EXPORT static QColor DefaultFillingColor();
+
+ /**
+ * Returns default border color for new channel.
+ */
+ HYDRODATA_EXPORT static QColor DefaultBorderColor();
+
public:
// Public methods to work with Channel
HYDRODATA_EXPORT virtual void RemoveProfile();
+protected:
+
+ /**
+ * Returns default filling color for new object.
+ */
+ HYDRODATA_EXPORT virtual QColor getDefaultFillingColor() const;
+
+ /**
+ * Returns default border color for new object.
+ */
+ HYDRODATA_EXPORT virtual QColor getDefaultBorderColor() const;
+
+ /**
+ * Returns the type of child altitude object.
+ * Reimplemented to create chanel altitude object.
+ */
+ HYDRODATA_EXPORT virtual ObjectKind getAltitudeObjectType() const;
+
protected:
friend class HYDROData_Iterator;