X-Git-Url: http://git.salome-platform.org/gitweb/?a=blobdiff_plain;f=src%2FHYDROPy%2FHYDROData_Entity.sip;h=4eae394f4e86a03f2095e38d41481646ffb62c6a;hb=61fb5fc7b0d481359dda905574e6bd548290716d;hp=04074c37954ec52cb915eea8c50c6c2280df3ffd;hpb=623f27e44b58b10a571def46700b447f6bf350cd;p=modules%2Fhydro.git diff --git a/src/HYDROPy/HYDROData_Entity.sip b/src/HYDROPy/HYDROData_Entity.sip index 04074c37..4eae394f 100644 --- a/src/HYDROPy/HYDROData_Entity.sip +++ b/src/HYDROPy/HYDROData_Entity.sip @@ -1,12 +1,8 @@ -// Copyright (C) 2007-2013 CEA/DEN, EDF R&D, OPEN CASCADE -// -// Copyright (C) 2003-2007 OPEN CASCADE, EADS/CCR, LIP6, CEA/DEN, -// CEDRAT, EDF R&D, LEG, PRINCIPIA R&D, BUREAU VERITAS -// +// Copyright (C) 2014-2015 EDF-R&D // This library is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either -// version 2.1 of the License. +// version 2.1 of the License, or (at your option) any later version. // // This library is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of @@ -44,6 +40,11 @@ const ObjectKind KIND_POLYLINEXY; const ObjectKind KIND_CALCULATION; const ObjectKind KIND_ZONE; const ObjectKind KIND_REGION; +const ObjectKind KIND_SHAPES_GROUP; +const ObjectKind KIND_SPLIT_GROUP; +const ObjectKind KIND_OBSTACLE_ALTITUDE; +const ObjectKind KIND_STRICKLER_TABLE; +const ObjectKind KIND_LAND_COVER_MAP; class HYDROData_Entity { @@ -59,41 +60,93 @@ class HYDROData_Entity sipClass = sipClass_HYDROData_Image; break; - case KIND_POLYLINEXY: - sipClass = sipClass_HYDROData_PolylineXY; + case KIND_POLYLINE: + sipClass = sipClass_HYDROData_Polyline3D; break; case KIND_BATHYMETRY: sipClass = sipClass_HYDROData_Bathymetry; break; - case KIND_OBSTACLE_ALTITUDE: - sipClass = sipClass_HYDROData_ObstacleAltitude; + case KIND_ALTITUDE: + sipClass = sipClass_HYDROData_AltitudeObject; break; case KIND_IMMERSIBLE_ZONE: sipClass = sipClass_HYDROData_ImmersibleZone; break; - - case KIND_CALCULATION: - sipClass = sipClass_HYDROData_CalculationCase; + + case KIND_RIVER: + sipClass = sipClass_HYDROData_River; + break; + + case KIND_STREAM: + sipClass = sipClass_HYDROData_Stream; + break; + + case KIND_CONFLUENCE: + sipClass = sipClass_HYDROData_Confluence; + break; + + case KIND_CHANNEL: + sipClass = sipClass_HYDROData_Channel; break; case KIND_OBSTACLE: sipClass = sipClass_HYDROData_Obstacle; break; - case KIND_REGION: - sipClass = sipClass_HYDROData_Region; + case KIND_DIGUE: + sipClass = sipClass_HYDROData_Digue; + break; + + case KIND_PROFILE: + sipClass = sipClass_HYDROData_Profile; + break; + + case KIND_PROFILEUZ: + sipClass = sipClass_HYDROData_ProfileUZ; + break; + + case KIND_POLYLINEXY: + sipClass = sipClass_HYDROData_PolylineXY; + break; + + case KIND_CALCULATION: + sipClass = sipClass_HYDROData_CalculationCase; break; case KIND_ZONE: sipClass = sipClass_HYDROData_Zone; break; + case KIND_REGION: + sipClass = sipClass_HYDROData_Region; + break; + case KIND_SHAPES_GROUP: sipClass = sipClass_HYDROData_ShapesGroup; break; + + case KIND_SPLIT_GROUP: + sipClass = sipClass_HYDROData_SplitShapesGroup; + break; + + case KIND_STREAM_ALTITUDE: + sipClass = sipClass_HYDROData_StreamAltitude; + break; + + case KIND_OBSTACLE_ALTITUDE: + sipClass = sipClass_HYDROData_ObstacleAltitude; + break; + + case KIND_STRICKLER_TABLE: + sipClass = sipClass_HYDROData_StricklerTable; + break; + + case KIND_LAND_COVER_MAP: + sipClass = sipClass_HYDROData_LandCoverMap; + break; case KIND_UNKNOWN: sipClass = sipClass_HYDROData_Entity; @@ -106,6 +159,16 @@ class HYDROData_Entity %End public: + enum Geometry + { + Geom_No = 1, + Geom_2d = 2, + Geom_Z = 4, + Geom_Groups = 8, + + Geom_3d = 6, + Geom_2d_and_groups = 10, + }; /** * Returns the kind of this object. Must be redefined in all objects of known type. @@ -127,6 +190,23 @@ public: */ virtual void Update(); + /** + * Checks that object has 2D presentation. Base implementation returns false. + */ + virtual bool IsHas2dPrs() const; + + /** + * Returns data of object wrapped to QVariant. + * Base implementation returns null value. + */ + virtual QVariant GetDataVariant(); + + /** + * Returns flag indicating that object is updateble or not. + */ + virtual bool CanBeUpdated() const; + + /** * Checks is object exists in the data structure. * \returns true is object is not exists in the data model @@ -136,21 +216,23 @@ public: /** * Removes object from the data structure. */ - void Remove(); + virtual void Remove(); /** - * Returns unique integer identifier of the object (may be used for ordering of objects) + * Returns father object. For object created under root document label + * this method always return NULL object. */ - int ID() const; - - /** - * Copies all properties of this to the destinated object. - * Objects must be the same type. - * \param theDestination initialized object (from any document) - target of copying - */ - /* - void CopyTo( HYDROData_Entity theDestination ) const; - */ + HYDROData_Entity GetFatherObject() const [Handle_HYDROData_Entity ()]; + %MethodCode + Handle(HYDROData_Entity) aFather; + + Py_BEGIN_ALLOW_THREADS + aFather = sipSelfWasArg ? sipCpp->HYDROData_Entity::GetFatherObject() : + sipCpp->GetFatherObject(); + Py_END_ALLOW_THREADS + + sipRes = createPointer( aFather ); + %End /** * Returns the list of all reference objects of this object. @@ -158,13 +240,31 @@ public: */ virtual HYDROData_SequenceOfObjects GetAllReferenceObjects() const; + + /** + * Returns the z-level for object presentation, -1 if no z-level. + */ + virtual bool GetZLevel( int& theLevel ) const [Standard_Boolean ( Standard_Integer& )]; + + /** + * Set the z-level for object presentation. + */ + virtual void SetZLevel( const int& theLevel ) [void ( const Standard_Integer& )]; + + /** + * Remove the z-level of object presentation. + */ + virtual void RemoveZLevel(); + + void SetColor( const QColor& theColor, const int theTag = 0 ); + protected: /** * Creates new object in the internal data structure. Use higher level objects * to create objects with real content. */ - HYDROData_Entity(); + HYDROData_Entity( Geometry ); /** * Destructs properties of the object and object itself, removes it from the document.