+ Handle(HYDROData_Entity) aRefObject = aRefObjects.Value( i );
+ if( aRefObject.IsNull() || aRefObject->IsRemoved() )
+ continue;
+
+ QString aRefObjectName = aRefObject->GetName();
+ if ( !theObjectNames.contains( aRefObjectName ) )
+ continue;
+
+ aResMap[ aRefObjectName ].Append( anObject );
+ }
+ }
+
+ return aResMap;
+}
+
+QDockWidget* HYDROGUI_Tool::WindowDock( QWidget* wid )
+{
+ if ( !wid )
+ return 0;
+
+ QDockWidget* dock = 0;
+ QWidget* w = wid->parentWidget();
+ while ( w && !dock )
+ {
+ dock = ::qobject_cast<QDockWidget*>( w );
+ w = w->parentWidget();
+ }
+ return dock;
+}
+
+QColor HYDROGUI_Tool::GenerateFillingColor( HYDROGUI_Module* theModule,
+ const QStringList& theZoneNames )
+{
+ Handle(HYDROData_Document) aDocument = HYDROData_Document::Document( theModule->getStudyId() );
+ return GenerateFillingColor( aDocument, theZoneNames );
+}
+
+QColor HYDROGUI_Tool::GenerateFillingColor( const Handle(HYDROData_Document)& theDoc,
+ const QStringList& theZoneNames )
+{
+ QColor aFillingColor( Qt::darkBlue );
+
+ int aCounter = 0;
+ int aR = 0, aG = 0, aB = 0;
+ QStringListIterator aZoneNameIter( theZoneNames );
+ while( aZoneNameIter.hasNext() )
+ {
+ const QString& aZoneName = aZoneNameIter.next();
+ Handle(HYDROData_ImmersibleZone) aRefZone =
+ Handle(HYDROData_ImmersibleZone)::DownCast( theDoc->FindObjectByName( aZoneName, KIND_IMMERSIBLE_ZONE ) );
+ if( !aRefZone.IsNull() )
+ {
+ QColor aRefColor = aRefZone->GetFillingColor();
+ aR += aRefColor.red();
+ aG += aRefColor.green();
+ aB += aRefColor.blue();
+ aCounter++;
+ }
+ }
+
+ if( aCounter > 0 )
+ {
+ aFillingColor = QColor( aR / aCounter, aG / aCounter, aB / aCounter );
+ }
+
+ return aFillingColor;
+}
+
+QStringList HYDROGUI_Tool::FindExistingObjectsNames( const Handle(HYDROData_Document)& theDoc,
+ const ObjectKind theObjectKind,
+ bool isCheckValidProfile )
+{
+ QStringList aNames;
+
+ HYDROData_Iterator anIter( theDoc, theObjectKind );
+ for ( ; anIter.More(); anIter.Next() ) {
+ Handle(HYDROData_Entity) anObject = anIter.Current();
+
+ bool isOK = !anObject.IsNull();
+
+ if( isOK && isCheckValidProfile )
+ {
+ Handle_HYDROData_Profile aProfile = Handle_HYDROData_Profile::DownCast( anObject );
+ if( !aProfile.IsNull() && !aProfile->IsValid() )
+ isOK = false;
+ }
+
+ if( isOK )
+ aNames.append( anObject->GetName() );
+ }
+
+ return aNames;
+}
+
+QString HYDROGUI_Tool::GetCoordinateString( const double theNumber, bool isInLocale )
+{
+ if( isInLocale )
+ {
+ static QLocale aLocale( QLocale::English, QLocale::France );
+ return aLocale.toString( theNumber, 'f', 2 );
+ }
+ else
+ return QString::number( theNumber, 'f', 2 );
+}
+
+Handle(Image_PixMap) HYDROGUI_Tool::Pixmap( const QImage& theImage )
+{
+ Handle(Image_PixMap) pix;
+ if ( theImage.isNull() || theImage.format() == QImage::Format_Invalid )
+ return pix;
+
+ Handle(Image_PixMap) tmpPix = new Image_PixMap();
+ tmpPix->SetTopDown( false );
+ QImage anImage = theImage.mirrored();
+ if ( !anImage.hasAlphaChannel() && anImage.allGray() )
+ {
+ tmpPix->InitTrash( Image_PixMap::ImgGray, anImage.width(), anImage.height(), anImage.width() );
+ for ( int r = 0; r < anImage.height(); r++ )
+ {
+ Standard_Byte* aRowData = tmpPix->ChangeRow( anImage.height() - r - 1 );
+ for ( int p = 0; p < anImage.width(); p++ )
+ aRowData[p] = qRed( anImage.pixel( p, r ) );
+ }
+ }
+ else
+ {
+ Image_PixMap::ImgFormat aFormat;
+ if ( anImage.hasAlphaChannel() )
+ {
+ if ( anImage.format() != QImage::Format_ARGB32 )
+ anImage = anImage.convertToFormat( QImage::Format_ARGB32 );
+ aFormat = Image_PixMap::ImgRGBA;
+ }
+ else
+ {
+ if ( anImage.format() != QImage::Format_RGB888 )
+ anImage = anImage.convertToFormat( QImage::Format_RGB888 );
+ aFormat = Image_PixMap::ImgRGB;
+ }
+
+ tmpPix->InitWrapper( aFormat, (Standard_Byte*)anImage.bits(), anImage.width(), anImage.height(), anImage.bytesPerLine() );
+ }
+
+ if ( !tmpPix.IsNull() )
+ {
+ pix = new Image_PixMap();
+ pix->InitCopy( *tmpPix.operator->() );
+ pix->SetTopDown( tmpPix->IsTopDown() );
+ }
+
+ return pix;
+}
+
+void HYDROGUI_Tool::DeleteGeomObjects( HYDROGUI_Module* theModule, const QStringList& theEntries )
+{
+ QStringList anEntryList;
+
+ // Get active SalomeApp_Study
+ SalomeApp_Study* aStudy = NULL;
+ if ( theModule && theModule->getApp() ) {
+ aStudy = dynamic_cast<SalomeApp_Study*>( theModule->getApp()->activeStudy() );
+ }
+ if ( !aStudy ) {
+ return;
+ }
+
+ // Get GEOM engine
+ GEOM::GEOM_Gen_var aGeomEngine = GeometryGUI::GetGeomGen();
+ if ( aGeomEngine->_is_nil() ) {
+ return;
+ }
+
+ // Delete GEOM objects
+ _PTR(StudyBuilder) aStudyBuilder( aStudy->studyDS()->NewBuilder() );
+ foreach ( const QString anEntry, theEntries ) {
+ _PTR(SObject) aSObject( aStudy->studyDS()->FindObjectID( qPrintable(anEntry) ) );
+ if ( aSObject ) {
+ GEOM::GEOM_Object_var aGeomObj =
+ GEOMBase::GetObjectFromIOR( aSObject->GetIOR().c_str() );
+
+ if ( !aGeomObj->_is_nil() ) {
+ aGeomEngine->RemoveObject( aGeomObj );