X-Git-Url: http://git.salome-platform.org/gitweb/?a=blobdiff_plain;f=src%2FHYDROData%2FHYDROData_Tool.h;h=e8fd7967bf0c23ad11f9f511a346fc59b6a5c53e;hb=d398a8be8e0b0259b476b358d53d234ce4c82379;hp=85824d6ef10f7cf5bec3358bf7b0ccfc0e0e8f62;hpb=d63a2e4caa93023bac64aef525cc4f597bc72512;p=modules%2Fhydro.git diff --git a/src/HYDROData/HYDROData_Tool.h b/src/HYDROData/HYDROData_Tool.h index 85824d6e..e8fd7967 100644 --- a/src/HYDROData/HYDROData_Tool.h +++ b/src/HYDROData/HYDROData_Tool.h @@ -1,16 +1,49 @@ +// 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, 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 +// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU +// Lesser General Public License for more details. +// +// You should have received a copy of the GNU Lesser General Public +// License along with this library; if not, write to the Free Software +// Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA +// +// See http://www.salome-platform.org/ or email : webmaster.salome@opencascade.com +// #ifndef HYDROData_Tool_HeaderFile #define HYDROData_Tool_HeaderFile +#include "HYDROData.h" +#include #include -#include - -class QFile; -class QStringList; class Handle_HYDROData_Document; +class Handle_HYDROData_Entity; +class HYDROData_SequenceOfObjects; +class MapOfTreatedObjects; +class gp_XY; +class QColor; +class QFile; +class TCollection_ExtendedString; +#ifdef WIN32 + enum TopAbs_State; +#else + #include +#endif +class TopoDS_Edge; +class TopoDS_Face; +class TopoDS_Shape; +class TopoDS_Wire; +class TopTools_SequenceOfShape; +class Quantity_Color; -class HYDROData_Tool { +class HYDRODATA_EXPORT HYDROData_Tool { public: @@ -19,11 +52,78 @@ public: const QString& theSep = "\n" ); /** - * Enables "MustBeUpdated" flag for Images that are depended on "MustBeUpdated" images. - * \param theDoc document where this operation is performed + * \brief Generate name for new object. + * \param theDoc document + * \param thePrefix name prefix + * \param theUsedNames list of already used names + * \param theIsTryToUsePurePrefix if true - the prefix will be returned if the name equal to the prefix is not busy + * \return generated name */ - static void SetMustBeUpdatedImages( Handle_HYDROData_Document theDoc ); + static QString GenerateObjectName( const Handle_HYDROData_Document& theDoc, + const QString& thePrefix, + const QStringList& theUsedNames = QStringList(), + const bool theIsTryToUsePurePrefix = false ); + + /** + * \brief Checks the type of object. + * \param theObject object to check + * \return true if object is geometry object + */ + static bool IsGeometryObject( const Handle_HYDROData_Entity& theObject ); + + /** + * \brief Updates the child object name. + * \param theOldStr old father object name + * \param theNewStr new father object name + * \param theObject object to update + */ + static void UpdateChildObjectName( const QString& theOldStr, + const QString& theNewStr, + const Handle_HYDROData_Entity& theObject ); + + /** + * \brief Generate name for new object in python environment. + * \param theTreatedObjects objects which was alredy created by dump operation + * \param thePrefix name prefix + * \return generated name + */ + static QString GenerateNameForPython( const MapOfTreatedObjects& theTreatedObjects, + const QString& thePrefix ); + /** + * Computes Point State from TopAbs (simplified & limited method). + */ + + static TopAbs_State ComputePointState( const gp_XY& thePnt2d, + const TopoDS_Face& theFace ); + + static double GetAltitudeForEdge( const TopoDS_Edge& theEdge, + const gp_XY& thePoint, + double theParameterTolerance, + double theSquareDistanceTolerance, + double theInvalidAltitude ); + static double GetAltitudeForWire( const TopoDS_Wire& theWire, + const gp_XY& thePoint, + double theParameterTolerance, + double theSquareDistanceTolerance, + double theInvalidAltitude ); + + /** + * \brief Returns the first shape from the group. + * \param theGroups the list of groups + * \param theGroupId the group id + */ + static TopoDS_Shape getFirstShapeFromGroup( const HYDROData_SequenceOfObjects& theGroups, + const int theGroupId ); + + static TCollection_ExtendedString toExtString( const QString& ); + static QString toQString( const TCollection_ExtendedString& ); + + static Quantity_Color toOccColor( const QColor& ); + static QColor toQtColor( const Quantity_Color& ); + + static bool IsNan( double theValue ); + static bool IsInf( double theValue ); }; inline bool ValuesEquals( const double& theFirst, const double& theSecond ) @@ -42,8 +142,12 @@ inline bool ValuesLessEquals( const double& theFirst, const double& theSecond ) return theFirst <= theSecond || ValuesEquals( theFirst, theSecond ); } - - +HYDRODATA_EXPORT std::ostream& operator<<( std::ostream& theStream, const QString& theText ); +HYDRODATA_EXPORT std::ostream& operator<<( std::ostream& theStream, const QColor& theText ); +HYDRODATA_EXPORT std::ostream& operator<<( std::ostream& theStream, const TopoDS_Shape& theShape ); +HYDRODATA_EXPORT std::ostream& operator<<( std::ostream& theStream, const TopoDS_Face& theFace ); +HYDRODATA_EXPORT bool operator == ( const gp_XY& thePoint1, const gp_XY& thePoint2 ); +HYDRODATA_EXPORT std::ostream& operator<<( std::ostream& theStream, const gp_XY& theXY ); #endif