X-Git-Url: http://git.salome-platform.org/gitweb/?a=blobdiff_plain;f=src%2FHYDROGUI%2FHYDROGUI_Tool.cxx;h=f86499f2b94171631fa6e7e5688ecdeb05ebc8ee;hb=a0964e8c4caecf35f149dbc669714901c5fd2336;hp=e030e1db13e33016a05b5d17269e9143e0cb509e;hpb=a735d3579cae0b95c56436cae00b09473a2b85db;p=modules%2Fhydro.git diff --git a/src/HYDROGUI/HYDROGUI_Tool.cxx b/src/HYDROGUI/HYDROGUI_Tool.cxx index e030e1db..f86499f2 100644 --- a/src/HYDROGUI/HYDROGUI_Tool.cxx +++ b/src/HYDROGUI/HYDROGUI_Tool.cxx @@ -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 @@ -20,37 +16,29 @@ // See http://www.salome-platform.org/ or email : webmaster.salome@opencascade.com // -#include "HYDROGUI_Tool.h" - -#include "HYDROGUI_DataModel.h" -#include "HYDROGUI_DataObject.h" -#include "HYDROGUI_Module.h" -#include "HYDROGUI_Prs.h" - +#include #include #include - -#include - -#include -#include -#include - -#include - -#include - -#include -#include -#include - -#include +#include +#include +#include +#include +#include +#include #include +#include +#include +#include +#include +#include +#include // Definition of this id allows to use 'latin1' (Qt alias for 'ISO-8859-1') // encoding instead of default 'System' #define USE_LATIN1_ENCODING +// #define DEB_GROUPS 1 + QString HYDROGUI_Tool::ToQString( const TCollection_AsciiString& src ) { #ifdef USE_LATIN1_ENCODING @@ -131,308 +119,223 @@ Handle(TCollection_HExtendedString) HYDROGUI_Tool::ToHExtString( const QString& return new TCollection_HExtendedString( ToExtString( src ) ); } -void HYDROGUI_Tool::LambertToDouble( const int theDegrees, - const int theMinutes, - const double theSeconds, - double& theCoord ) -{ - // ouv: check the case of negative degrees - theCoord = theDegrees * 3600 + theMinutes * 60 + theSeconds; -} - -void HYDROGUI_Tool::DoubleToLambert( const double theCoord, - int& theDegrees, - int& theMinutes, - double& theSeconds ) +QString HYDROGUI_Tool::GetTempDir( const bool theToCreate ) { - // ouv: check the case of negative degrees - theDegrees = int( theCoord / 3600 ); + QString aRes; - double aRemainder = theCoord - theDegrees * 3600; - theMinutes = int( aRemainder / 60 ); - - theSeconds = aRemainder - theMinutes * 60; -} - -bool HYDROGUI_Tool::IsEqual( const Handle(HYDROData_Object)& theObj1, - const Handle(HYDROData_Object)& theObj2 ) -{ - if( !theObj1.IsNull() && !theObj2.IsNull() ) - return theObj1->Label() == theObj2->Label(); //ouv: check that the names can be used here - return false; -} + char* tmpdir = getenv ( "HYDRO_TMP_DIR" ); + if ( tmpdir ) + { + // try to create folder if it does not exist + QFileInfo fi( tmpdir ); + if ( !fi.exists() && theToCreate ) + { + if ( QDir().mkdir( tmpdir ) ) + QFile::setPermissions( tmpdir, (QFile::Permissions)0x4FFFF ); + QFileInfo fi( tmpdir ); + if ( !fi.exists() || !fi.isWritable() ) + tmpdir = 0; + } + } + if ( !tmpdir ) + tmpdir = getenv ( "TEMP" ); + if ( !tmpdir ) + tmpdir = getenv ( "TMP" ); + if ( !tmpdir ) + { +#ifdef WNT + tmpdir = "C:\\"; +#else + tmpdir = strdup( "/tmp" ); +#endif + } + aRes = tmpdir; + + QFileInfo fi( aRes ); + if ( !fi.exists() || !fi.isWritable() ) + aRes = QString::null; -void HYDROGUI_Tool::SetActiveViewManager( HYDROGUI_Module* theModule, - SUIT_ViewManager* theViewManager ) -{ - if( theViewManager ) - if( SUIT_ViewWindow* aViewWindow = theViewManager->getActiveView() ) - if( STD_TabDesktop* aTabDesktop = dynamic_cast( theModule->getApp()->desktop() ) ) - if( QtxWorkstack* aWorkstack = aTabDesktop->workstack() ) - aWorkstack->setActiveWindow( aViewWindow ); + return aRes; } -void HYDROGUI_Tool::GetPrsSubObjects( HYDROGUI_Module* theModule, - HYDROData_SequenceOfObjects& theSeq ) +void HYDROGUI_Tool::GetObjectReferences( const Handle(HYDROData_Entity)& theObj, + HYDROData_SequenceOfObjects& theRefObjects, + QStringList& theRefNames ) { - Handle(HYDROData_Document) aDocument = HYDROData_Document::Document( theModule->getStudyId() ); - if( aDocument.IsNull() ) + if( theObj.IsNull() ) return; - HYDROData_Iterator anIterator( aDocument, KIND_IMAGE ); - for( ; anIterator.More(); anIterator.Next() ) - { - Handle(HYDROData_Object) anObject = anIterator.Current(); - if( !anObject.IsNull() ) - theSeq.Append( anObject ); - } + HYDROData_SequenceOfObjects anAllRefObjects = theObj->GetAllReferenceObjects(); + theRefObjects.Append( anAllRefObjects ); - anIterator = HYDROData_Iterator( aDocument, KIND_POLYLINE ); - for( ; anIterator.More(); anIterator.Next() ) + for( int i = 1, n = anAllRefObjects.Length(); i <= n; ++i ) { - Handle(HYDROData_Object) anObject = anIterator.Current(); - if( !anObject.IsNull() ) - theSeq.Append( anObject ); - } -} + Handle(HYDROData_Entity) aRefObj = theRefObjects.Value( i ); + if( aRefObj.IsNull() || aRefObj->IsRemoved() ) + continue; -HYDROGUI_Prs* HYDROGUI_Tool::GetPresentation( const Handle(HYDROData_Object)& theObj, - const GraphicsView_ObjectList& theObjects ) -{ - if( !theObj.IsNull() ) - { - GraphicsView_ObjectListIterator anIter( theObjects ); - while( anIter.hasNext() ) - { - if( HYDROGUI_Prs* aPrs = dynamic_cast( anIter.next() ) ) - { - Handle(HYDROData_Object) anObj = aPrs->getObject(); - if( IsEqual( anObj, theObj ) ) - return aPrs; - } - } - } - return NULL; -} + QString aRefObjectName = aRefObj->GetName(); + if( theRefNames.contains( aRefObjectName ) ) + continue; -GraphicsView_ObjectList HYDROGUI_Tool::GetPrsList( GraphicsView_ViewPort* theViewPort ) -{ - GraphicsView_ObjectList aList; - if( theViewPort ) - { - GraphicsView_ObjectListIterator anIter( theViewPort->getObjects() ); - while( anIter.hasNext() ) - if( HYDROGUI_Prs* aPrs = dynamic_cast( anIter.next() ) ) - aList.append( aPrs ); + theRefObjects.Append( aRefObj ); + theRefNames.append( aRefObjectName ); + + GetObjectReferences( aRefObj, theRefObjects, theRefNames ); } - return aList; } -HYDROData_SequenceOfObjects HYDROGUI_Tool::GetSelectedObjects( HYDROGUI_Module* theModule ) +HYDROData_SequenceOfObjects HYDROGUI_Tool::GetObjectBackReferences( const Handle(HYDROData_Entity)& theObj ) { - HYDROData_SequenceOfObjects aSeq; + if( theObj.IsNull() ) + return HYDROData_SequenceOfObjects(); - HYDROGUI_DataModel* aModel = theModule->getDataModel(); + QString anObjName = theObj->GetName(); - SUIT_SelectionMgr* aSelectionMgr = theModule->getApp()->selectionMgr(); - SUIT_DataOwnerPtrList anOwners; - aSelectionMgr->selected( anOwners ); + Handle(HYDROData_Document) aDoc = HYDROData_Document::Document( theObj->Label() ); + QMap aMapOfBackRefs = + GetObjectsBackReferences( aDoc, QStringList() << anObjName ); - QStringList aCollectedNameList; // to avoid duplication - foreach( SUIT_DataOwner* aSUITOwner, anOwners ) - { - if( LightApp_DataOwner* anOwner = dynamic_cast( aSUITOwner ) ) - { - Handle(HYDROData_Object) anObject = aModel->objectByEntry( anOwner->entry() ); - if( !anObject.IsNull() ) - { - QString aName = anObject->GetName(); - if( !aCollectedNameList.contains( aName ) ) - { - aSeq.Append( anObject ); - aCollectedNameList.append( aName ); - } - } - } - } - return aSeq; + return aMapOfBackRefs[ anObjName ]; } -Handle(HYDROData_Object) HYDROGUI_Tool::GetSelectedObject( HYDROGUI_Module* theModule ) +QMap HYDROGUI_Tool::GetObjectsBackReferences( + const Handle_HYDROData_Document& theDocument, const QStringList& theObjectNames ) { - HYDROData_SequenceOfObjects aSeq = GetSelectedObjects( theModule ); - if( !aSeq.IsEmpty() ) - return aSeq.First(); - return NULL; -} - -ObjectKind HYDROGUI_Tool::GetSelectedPartition( HYDROGUI_Module* theModule ) -{ - HYDROGUI_DataModel* aModel = theModule->getDataModel(); + QMap aResMap; - SUIT_SelectionMgr* aSelectionMgr = theModule->getApp()->selectionMgr(); - SUIT_DataOwnerPtrList anOwners; - aSelectionMgr->selected( anOwners ); + if( theObjectNames.isEmpty() ) + return aResMap; - if( anOwners.size() != 1 ) - return KIND_UNKNOWN; + if( theDocument.IsNull() ) + return aResMap; - if( LightApp_DataOwner* anOwner = dynamic_cast( anOwners.first().operator->() ) ) + HYDROData_Iterator anIterator( theDocument ); + for( ; anIterator.More(); anIterator.Next() ) { - QString anEntry = anOwner->entry(); - QString aPrefix = HYDROGUI_DataObject::entryPrefix(); - if( anEntry.left( aPrefix.length() ) == aPrefix ) + Handle(HYDROData_Entity) anObject = anIterator.Current(); + if( anObject.IsNull() || anObject->IsRemoved() ) + continue; + + QString anObjectName = anObject->GetName(); + if ( theObjectNames.contains( anObjectName ) ) + continue; + + HYDROData_SequenceOfObjects aRefObjects = anObject->GetAllReferenceObjects(); + for ( int i = 1, n = aRefObjects.Length(); i <= n; ++i ) { - anEntry.remove( aPrefix ); - for( ObjectKind anObjectKind = KIND_UNKNOWN + 1; anObjectKind <= KIND_LAST; anObjectKind++ ) - if( HYDROGUI_DataModel::partitionName( anObjectKind ) == anEntry ) - return anObjectKind; + 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 KIND_UNKNOWN; + + return aResMap; } -Handle(HYDROData_Object) HYDROGUI_Tool::FindObjectByName( HYDROGUI_Module* theModule, - const QString& theName, - const ObjectKind theObjectKind ) +QDockWidget* HYDROGUI_Tool::WindowDock( QWidget* wid ) { - Handle(HYDROData_Object) anObject; - - Handle(HYDROData_Document) aDocument = HYDROData_Document::Document( theModule->getStudyId() ); - if( aDocument.IsNull() ) - return anObject; + if ( !wid ) + return 0; - HYDROData_Iterator anIter( aDocument, theObjectKind ); - for( ; anIter.More(); anIter.Next() ) + QDockWidget* dock = 0; + QWidget* w = wid->parentWidget(); + while ( w && !dock ) { - Handle(HYDROData_Object) anObjectRef = anIter.Current(); - if( !anObjectRef.IsNull() && anObjectRef->GetName() == theName ) - { - anObject = anObjectRef; - break; - } + dock = ::qobject_cast( w ); + w = w->parentWidget(); } - return anObject; + return dock; } -QString HYDROGUI_Tool::GenerateObjectName( HYDROGUI_Module* theModule, - const QString& thePrefix ) +QStringList HYDROGUI_Tool::FindExistingObjectsNames( const Handle(HYDROData_Document)& theDoc, + const ObjectKind theObjectKind, + bool isCheckValidProfile ) { - QString aName; - int anId = 1; - while( anId < 100 ) - { - aName = QString( "%1_%2" ).arg( thePrefix ).arg( QString::number( anId++ ) ); + QStringList aNames; + + HYDROData_Iterator anIter( theDoc, theObjectKind ); + for ( ; anIter.More(); anIter.Next() ) { + Handle(HYDROData_Entity) anObject = anIter.Current(); - // check that there are no other objects with the same name in the document - Handle(HYDROData_Object) anObject = FindObjectByName( theModule, aName, KIND_UNKNOWN ); - if( anObject.IsNull() ) - break; + 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 aName; -} -size_t HYDROGUI_Tool::GetActiveGraphicsViewId( HYDROGUI_Module* theModule ) -{ - size_t aViewId = 0; - SUIT_ViewManager* aViewMgr = theModule->getApp()->activeViewManager(); - if( !aViewMgr || aViewMgr->getType() != GraphicsView_Viewer::Type() ) - return aViewId; - - if( SUIT_ViewModel* aViewer = aViewMgr->getViewModel() ) - aViewId = (size_t)aViewer; - return aViewId; + return aNames; } -QList HYDROGUI_Tool::GetGraphicsViewIdList( HYDROGUI_Module* theModule ) +QString HYDROGUI_Tool::GetCoordinateString( const double theNumber, bool isInLocale ) { - QList aList; - ViewManagerList aViewMgrs; - theModule->getApp()->viewManagers( GraphicsView_Viewer::Type(), aViewMgrs ); - QListIterator anIter( aViewMgrs ); - while( anIter.hasNext() ) + if( isInLocale ) { - if( SUIT_ViewManager* aViewMgr = anIter.next() ) - { - if( SUIT_ViewModel* aViewer = aViewMgr->getViewModel() ) - aList.append( (size_t)aViewer ); - } + static QLocale aLocale( QLocale::English, QLocale::France ); + return aLocale.toString( theNumber, 'f', 2 ); } - return aList; + else + return QString::number( theNumber, 'f', 2 ); } -void HYDROGUI_Tool::GetObjectReferences( const Handle(HYDROData_Image)& theImage, - HYDROData_SequenceOfObjects& theRefObjects, - QStringList& theRefNames ) +Handle(Image_PixMap) HYDROGUI_Tool::Pixmap( const QImage& theImage ) { - if( theImage.IsNull() ) - return; - - for( int anIndex = 0, aNbRef = theImage->NbReferences(); anIndex < aNbRef; anIndex++ ) - { - Handle(HYDROData_Object) aRefObj = theImage->Reference( anIndex ); - if( !aRefObj.IsNull() && !aRefObj->IsRemoved() ) + 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() ) { - QString aName = aRefObj->GetName(); - if( !theRefNames.contains( aName ) ) - { - theRefObjects.Append( aRefObj ); - theRefNames.append( aRefObj->GetName() ); - if( aRefObj->GetKind() == KIND_IMAGE ) + tmpPix->InitTrash( Image_PixMap::ImgGray, anImage.width(), anImage.height(), anImage.width() ); + for ( int r = 0; r < anImage.height(); r++ ) { - Handle(HYDROData_Image) aRefImage = Handle(HYDROData_Image)::DownCast( aRefObj ); - if( !aRefImage.IsNull() ) - GetObjectReferences( aRefImage, theRefObjects, theRefNames ); + Standard_Byte* aRowData = tmpPix->ChangeRow( anImage.height() - r - 1 ); + for ( int p = 0; p < anImage.width(); p++ ) + aRowData[p] = qRed( anImage.pixel( p, r ) ); } - } } - } -} - -void HYDROGUI_Tool::GetObjectBackReferences( HYDROGUI_Module* theModule, - const Handle(HYDROData_Object)& theObj, - HYDROData_SequenceOfObjects& theBackRefObjects, - QStringList& theBackRefNames ) -{ - if( theObj.IsNull() ) - return; - - Handle(HYDROData_Document) aDocument = HYDROData_Document::Document( theModule->getStudyId() ); - if( aDocument.IsNull() ) - return; + 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; + } - QString aName = theObj->GetName(); + tmpPix->InitWrapper( aFormat, (Standard_Byte*)anImage.bits(), anImage.width(), anImage.height(), anImage.bytesPerLine() ); + } - HYDROData_Iterator anIterator( aDocument, KIND_IMAGE ); - for( ; anIterator.More(); anIterator.Next() ) - { - Handle(HYDROData_Image) anImage = Handle(HYDROData_Image)::DownCast( anIterator.Current() ); - if( !anImage.IsNull() ) + if ( !tmpPix.IsNull() ) { - HYDROData_SequenceOfObjects aRefObjects; - QStringList aRefNames; - GetObjectReferences( anImage, aRefObjects, aRefNames ); - if( aRefNames.contains( aName ) ) - { - theBackRefObjects.Append( anImage ); - theBackRefNames.append( anImage->GetName() ); - } + pix = new Image_PixMap(); + pix->InitCopy( *tmpPix.operator->() ); + pix->SetTopDown( tmpPix->IsTopDown() ); } - } -} - -QDockWidget* HYDROGUI_Tool::WindowDock( QWidget* wid ) -{ - if ( !wid ) - return 0; - - QDockWidget* dock = 0; - QWidget* w = wid->parentWidget(); - while ( w && !dock ) - { - dock = ::qobject_cast( w ); - w = w->parentWidget(); - } - return dock; + return pix; } +