2 #ifndef HYDROData_ImmersibleZone_HeaderFile
3 #define HYDROData_ImmersibleZone_HeaderFile
5 #include <HYDROData_NaturalObject.h>
7 DEFINE_STANDARD_HANDLE(HYDROData_ImmersibleZone, HYDROData_NaturalObject)
9 class Handle(HYDROData_Bathymetry);
10 class Handle(HYDROData_Polyline);
12 /**\class HYDROData_ImmersibleZone
16 class HYDROData_ImmersibleZone : public HYDROData_NaturalObject
20 * Enumeration of tags corresponding to the persistent object parameters.
24 DataTag_First = HYDROData_NaturalObject::DataTag_First + 100, ///< first tag, to reserve
25 DataTag_FillingColor, ///< filling color of immersible zone
26 DataTag_BorderColor, ///< border color of immersible zone
27 DataTag_Polyline, ///< reference polyline
28 DataTag_Bathymetry, ///< reference bathymetry
32 DEFINE_STANDARD_RTTI(HYDROData_ImmersibleZone);
35 * Returns the kind of this object. Must be redefined in all objects of known type.
37 HYDRODATA_EXPORT virtual const ObjectKind GetKind() const {return KIND_IMMERSIBLE_ZONE;}
40 * Dump object to Python script representation.
42 HYDRODATA_EXPORT virtual QStringList DumpToPython( MapOfTreatedObjects& theTreatedObjects ) const;
45 * Returns the top shape of the object.
47 HYDRODATA_EXPORT virtual TopoDS_Shape GetTopShape() const;
50 * Returns the 3d shape of the object.
52 HYDRODATA_EXPORT virtual TopoDS_Shape GetShape3D() const;
56 * Returns default filling color for new zone.
58 HYDRODATA_EXPORT static QColor DefaultFillingColor();
61 * Sets filling color for zone.
63 HYDRODATA_EXPORT virtual void SetFillingColor( const QColor& theColor );
66 * Returns filling color of zone.
68 HYDRODATA_EXPORT virtual QColor GetFillingColor() const;
72 * Returns default border color for new zone.
74 HYDRODATA_EXPORT static QColor DefaultBorderColor();
77 * Sets border color for zone.
79 HYDRODATA_EXPORT virtual void SetBorderColor( const QColor& theColor );
82 * Returns border color of zone.
84 HYDRODATA_EXPORT virtual QColor GetBorderColor() const;
88 * Sets reference polyline object for zone.
90 HYDRODATA_EXPORT virtual void SetPolyline( const Handle(HYDROData_Polyline)& thePolyline );
93 * Returns reference polyline object of zone.
95 HYDRODATA_EXPORT virtual Handle(HYDROData_Polyline) GetPolyline() const;
98 * Remove reference polyline object of zone.
100 HYDRODATA_EXPORT virtual void RemovePolyline();
104 * Set reference bathymetry object for zone.
106 HYDRODATA_EXPORT virtual void SetBathymetry( const Handle(HYDROData_Bathymetry)& theBathymetry );
109 * Returns reference bathymetry object of zone.
111 HYDRODATA_EXPORT virtual Handle(HYDROData_Bathymetry) GetBathymetry() const;
114 * Clear the bathymetry object for zone.
116 HYDRODATA_EXPORT virtual void RemoveBathymetry();
120 friend class HYDROData_Iterator;
123 * Creates new object in the internal data structure. Use higher level objects
124 * to create objects with real content.
126 HYDRODATA_EXPORT HYDROData_ImmersibleZone();
129 * Destructs properties of the object and object itself, removes it from the document.
131 virtual HYDRODATA_EXPORT ~HYDROData_ImmersibleZone();