#include <HYDROData_Zone.h>
%End
-class HYDROData_Zone : HYDROData_Object
+class HYDROData_Zone : HYDROData_Entity
{
-%TypeHeaderCode
-#include <HYDROData_Zone.h>
+%ConvertToSubClassCode
+ switch ( sipCpp->GetKind() )
+ {
+ case KIND_ZONE:
+ sipClass = sipClass_HYDROData_Zone;
+ break;
+
+ default:
+ // We don't recognise the type.
+ sipClass = NULL;
+ }
%End
-%ConvertToSubClassCode
- if ( !Handle(HYDROData_Zone)::DownCast( sipCpp ).IsNull() )
- sipClass = sipClass_HYDROData_Zone;
- else
- sipClass = NULL;
+%TypeHeaderCode
+#include <HYDROData_Zone.h>
%End
public:
- const ObjectKind GetKind() const;
+ // Enumeration of mergin types for conflict altitudes
+ enum MergeAltitudesType
+ {
+ Merge_ZMIN, // The minimum values
+ Merge_ZMAX, // The maximum values
+ Merge_Object // Only one altitude will be taken into account
+ };
public:
/**
- * Sets filling color for zone.
+ * Sets the merging type for conflict altitudes.
+ * By default it is set to Merge_ZMIN.
*/
- void SetFillingColor( const QColor& theColor );
+ void SetMergeType( const MergeAltitudesType& theType );
/**
- * Returns filling color of zone.
+ * Returns the merging type for conflict altitudes.
*/
- QColor GetFillingColor() const;
+ MergeAltitudesType GetMergeType() const;
- /**
- * Sets border color for zone.
- */
- void SetBorderColor( const QColor& theColor );
/**
- * Returns border color of zone.
+ * Sets the reference altitude to resolve the conflict.
+ * This object is used only in case of "Merge_Object" merge type.
*/
- QColor GetBorderColor() const;
-
- /**
- * Sets reference polyline object for zone.
- */
- void SetPolyline( HYDROData_Polyline thePolyline ) [void (const Handle_HYDROData_Polyline&)];
+ void SetMergeAltitude( HYDROData_IAltitudeObject theAltitude ) [void (const Handle_HYDROData_IAltitudeObject&)];
%MethodCode
- Handle(HYDROData_Polyline) aRefPolyline =
- Handle(HYDROData_Polyline)::DownCast( createHandle( a0 ) );
- if ( !aRefPolyline.IsNull() )
+ Handle(HYDROData_IAltitudeObject) aRefAltitude =
+ Handle(HYDROData_IAltitudeObject)::DownCast( createHandle( a0 ) );
+ if ( !aRefAltitude.IsNull() )
{
Py_BEGIN_ALLOW_THREADS
- sipSelfWasArg ? sipCpp->HYDROData_Zone::SetPolyline( aRefPolyline ) :
- sipCpp->SetPolyline( aRefPolyline );
+ sipSelfWasArg ? sipCpp->HYDROData_Zone::SetMergeAltitude( aRefAltitude ) :
+ sipCpp->SetMergeAltitude( aRefAltitude );
Py_END_ALLOW_THREADS
}
%End
/**
- * Returns reference polyline object of zone.
+ * Returns the reference altitude to resolve the conflict.
*/
- HYDROData_Polyline GetPolyline() const [Handle_HYDROData_Polyline ()];
+ HYDROData_IAltitudeObject GetMergeAltitude() const [Handle_HYDROData_IAltitudeObject ()];
%MethodCode
- Handle(HYDROData_Polyline) aRefPolyline;
+ Handle(HYDROData_IAltitudeObject) aRefAltitude;
Py_BEGIN_ALLOW_THREADS
- aRefPolyline = sipSelfWasArg ? sipCpp->HYDROData_Zone::GetPolyline() :
- sipCpp->GetPolyline();
+ aRefAltitude = sipSelfWasArg ? sipCpp->HYDROData_Zone::GetMergeAltitude() :
+ sipCpp->GetMergeAltitude();
Py_END_ALLOW_THREADS
- sipRes = (HYDROData_Polyline*)createPointer( aRefPolyline );
+ sipRes = (HYDROData_IAltitudeObject*)createPointer( aRefAltitude );
%End
/**
- * Remove reference polyline object of zone.
+ * Removes the reference altitude for resolving the conflict.
*/
- void RemovePolyline();
+ void RemoveMergeAltitude();
- /**
- * Returns number of bathymetry objects for zone.
- */
- int NbBathymetries() const;
/**
- * Add reference bathymetry object for zone.
+ * dd new one geometry object for zone.
*/
- void AddBathymetry( HYDROData_Bathymetry theBathymetry ) [void (const Handle_HYDROData_Bathymetry&)];
+ void AddGeometryObject( HYDROData_Object theRegion ) [void (const Handle_HYDROData_Object&)];
%MethodCode
- Handle(HYDROData_Bathymetry) aRefBath =
- Handle(HYDROData_Bathymetry)::DownCast( createHandle( a0 ) );
- if ( !aRefBath.IsNull() )
+ Handle(HYDROData_Object) aGeomObj =
+ Handle(HYDROData_Object)::DownCast( createHandle( a0 ) );
+ if ( !aGeomObj.IsNull() )
{
Py_BEGIN_ALLOW_THREADS
- sipSelfWasArg ? sipCpp->HYDROData_Zone::AddBathymetry( aRefBath ) :
- sipCpp->AddBathymetry( aRefBath );
+ sipSelfWasArg ? sipCpp->HYDROData_Zone::AddGeometryObject( aGeomObj ) :
+ sipCpp->AddGeometryObject( aGeomObj );
Py_END_ALLOW_THREADS
}
%End
/**
- * Change reference bathymetry object with given index for zone.
- */
- void SetBathymetry( const int theIndex,
- HYDROData_Bathymetry theBathymetry ) [void (const int, const Handle_HYDROData_Bathymetry&)];
- %MethodCode
-
- Handle(HYDROData_Bathymetry) aRefBath =
- Handle(HYDROData_Bathymetry)::DownCast( createHandle( a1 ) );
- if ( !aRefBath.IsNull() )
- {
- Py_BEGIN_ALLOW_THREADS
- sipSelfWasArg ? sipCpp->HYDROData_Zone::SetBathymetry( a0, aRefBath ) :
- sipCpp->SetBathymetry( a0, aRefBath );
- Py_END_ALLOW_THREADS
- }
-
- %End
-
- /**
- * Returns reference bathymetry object of zone by it index.
- */
- HYDROData_Bathymetry GetBathymetry( const int theIndex ) const [Handle_HYDROData_Bathymetry (const int)];
- %MethodCode
-
- Handle(HYDROData_Bathymetry) aRefBath;
-
- Py_BEGIN_ALLOW_THREADS
- aRefBath = sipSelfWasArg ? sipCpp->HYDROData_Zone::GetBathymetry( a0 ) :
- sipCpp->GetBathymetry( a0 );
- Py_END_ALLOW_THREADS
-
- sipRes = (HYDROData_Bathymetry*)createPointer( aRefBath );
-
- %End
-
- /**
- * Returns list of all reference bathymetry objects of zone.
- */
- //HYDROData_SequenceOfObjects GetBathymetries() const;
-
- /**
- * Clear list of bathymetry objects of zone.
+ * Returns all geometry objects of zone.
*/
- void RemoveBathymetries();
+ HYDROData_SequenceOfObjects GetGeometryObjects() const;
/**
- * Returns the painter path. The painter path is construct by polyline
+ * Removes all geometry objects from zone.
*/
- QPainterPath GetPainterPath() const;
+ void RemoveGeometryObjects();
protected: