2010-05-14 21:32:37 +06:00
|
|
|
// Copyright (C) 2007-2010 CEA/DEN, EDF R&D, OPEN CASCADE
|
2009-02-17 10:27:49 +05:00
|
|
|
//
|
|
|
|
// Copyright (C) 2003-2007 OPEN CASCADE, EADS/CCR, LIP6, CEA/DEN,
|
|
|
|
// CEDRAT, EDF R&D, LEG, PRINCIPIA R&D, BUREAU VERITAS
|
|
|
|
//
|
|
|
|
// 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.
|
|
|
|
//
|
|
|
|
// 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
|
|
|
|
//
|
2010-05-14 21:32:37 +06:00
|
|
|
|
2009-02-17 10:27:49 +05:00
|
|
|
// SMESH SMESHGUI : GUI for SMESH component
|
|
|
|
// File : SMESHGUI_MeshUtils.cxx
|
|
|
|
// Author : Open CASCADE S.A.S.
|
|
|
|
// SMESH includes
|
|
|
|
//
|
2004-12-01 15:48:31 +05:00
|
|
|
#include "SMESHGUI_MeshUtils.h"
|
2009-02-17 10:27:49 +05:00
|
|
|
|
2010-11-25 17:44:43 +05:00
|
|
|
#include "SMESHGUI.h"
|
2004-12-01 15:48:31 +05:00
|
|
|
#include "SMESHGUI_Utils.h"
|
2003-05-19 19:54:48 +06:00
|
|
|
|
2009-02-17 10:27:49 +05:00
|
|
|
// SALOME KERNEL includes
|
|
|
|
#include <SALOMEDSClient_Study.hxx>
|
|
|
|
|
|
|
|
// Qt includes
|
|
|
|
#include <QStringList>
|
|
|
|
|
|
|
|
// IDL includes
|
|
|
|
#include <SALOMEconfig.h>
|
2004-12-01 15:48:31 +05:00
|
|
|
#include CORBA_SERVER_HEADER(SMESH_Group)
|
2010-11-25 17:44:43 +05:00
|
|
|
#include CORBA_SERVER_HEADER(SMESH_Measurements)
|
2004-12-01 15:48:31 +05:00
|
|
|
|
|
|
|
namespace SMESH
|
2003-05-19 19:54:48 +06:00
|
|
|
{
|
2004-12-01 15:48:31 +05:00
|
|
|
SMESH_Mesh_var GetMeshByIO(const Handle(SALOME_InteractiveObject)& theIO)
|
2004-06-18 14:34:31 +06:00
|
|
|
{
|
2004-12-01 15:48:31 +05:00
|
|
|
CORBA::Object_var anObj = IObjectToObject(theIO);
|
|
|
|
if(!CORBA::is_nil(anObj)){
|
|
|
|
SMESH_Mesh_var aMesh = SMESH_Mesh::_narrow(anObj);
|
|
|
|
if(!CORBA::is_nil(aMesh))
|
2009-10-01 12:28:20 +06:00
|
|
|
return aMesh;
|
2004-12-01 15:48:31 +05:00
|
|
|
SMESH_GroupBase_var aGroup = SMESH_GroupBase::_narrow(anObj);
|
|
|
|
if(!CORBA::is_nil(aGroup))
|
2009-10-01 12:28:20 +06:00
|
|
|
return aGroup->GetMesh();
|
2004-12-01 15:48:31 +05:00
|
|
|
SMESH_subMesh_var aSubMesh = SMESH_subMesh::_narrow(anObj);
|
|
|
|
if(!CORBA::is_nil(aSubMesh))
|
2009-10-01 12:28:20 +06:00
|
|
|
return aSubMesh->GetFather();
|
2004-12-01 15:48:31 +05:00
|
|
|
}
|
|
|
|
return SMESH_Mesh::_nil();
|
|
|
|
}
|
2003-05-19 19:54:48 +06:00
|
|
|
|
2009-02-17 10:27:49 +05:00
|
|
|
QString UniqueMeshName(const QString& theBaseName, const QString& thePostfix)
|
2008-03-07 12:47:05 +05:00
|
|
|
{
|
2009-02-17 10:27:49 +05:00
|
|
|
QString baseName = thePostfix.isEmpty() ?
|
|
|
|
theBaseName : theBaseName + "_" + thePostfix;
|
|
|
|
if ( _PTR(Study) aStudy = GetActiveStudyDocument() ) {
|
2008-03-07 12:47:05 +05:00
|
|
|
QString name = baseName;
|
2009-02-17 10:27:49 +05:00
|
|
|
while ( !aStudy->FindObjectByName( name.toLatin1().data(), "SMESH" ).empty() ) {
|
2008-03-07 12:47:05 +05:00
|
|
|
int nb = 0;
|
2009-10-01 12:28:20 +06:00
|
|
|
QStringList names = name.split("_", QString::KeepEmptyParts);
|
|
|
|
if ( names.count() > 0 ) {
|
|
|
|
bool ok;
|
|
|
|
int index = names.last().toInt( &ok );
|
|
|
|
if ( ok ) {
|
|
|
|
nb = index;
|
|
|
|
names.removeLast();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
names.append( QString::number( nb+1 ) );
|
|
|
|
name = names.join( "_" );
|
2008-03-07 12:47:05 +05:00
|
|
|
}
|
|
|
|
return name;
|
|
|
|
}
|
2009-02-17 10:27:49 +05:00
|
|
|
return baseName;
|
2008-03-07 12:47:05 +05:00
|
|
|
}
|
2010-11-25 17:44:43 +05:00
|
|
|
|
|
|
|
QString UniqueName(const QString& theBaseName, _PTR(SObject) theParent, const QString& thePostfix)
|
|
|
|
{
|
|
|
|
QString baseName = thePostfix.isEmpty() ?
|
|
|
|
theBaseName : theBaseName + "_" + thePostfix;
|
|
|
|
QString name = baseName;
|
|
|
|
if ( _PTR(Study) aStudy = GetActiveStudyDocument() ) {
|
|
|
|
_PTR(SObject) p = theParent;
|
|
|
|
if ( !p ) p = aStudy->FindComponent( "SMESH" );
|
|
|
|
if ( p ) {
|
|
|
|
_PTR(ChildIterator) iter = aStudy->NewChildIterator( p );
|
|
|
|
int idx = 0;
|
|
|
|
while( true ) {
|
|
|
|
bool found = false;
|
|
|
|
for ( ; iter->More(); iter->Next() ) {
|
|
|
|
_PTR(SObject) so = iter->Value();
|
|
|
|
if ( !so ) continue; // skip bad objects
|
|
|
|
_PTR(SObject) ref;
|
|
|
|
if ( so->ReferencedObject( ref ) ) continue; // skip references
|
|
|
|
QString n = so->GetName().c_str();
|
|
|
|
if ( !n.isEmpty() && n == name ) {
|
|
|
|
QStringList names = name.split("_", QString::KeepEmptyParts);
|
|
|
|
if ( names.count() > 0 ) {
|
|
|
|
bool ok;
|
|
|
|
names.last().toInt( &ok );
|
|
|
|
if ( ok )
|
|
|
|
names.removeLast();
|
|
|
|
}
|
|
|
|
names.append( QString::number( ++idx ) );
|
|
|
|
name = names.join( "_" );
|
|
|
|
found = true;
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
if ( !found ) break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return name;
|
|
|
|
}
|
|
|
|
|
|
|
|
SMESH::Measurements_var& GetMeasurements()
|
|
|
|
{
|
|
|
|
static SMESH::Measurements_var aMeasurements;
|
|
|
|
if (CORBA::is_nil(aMeasurements)) {
|
|
|
|
aMeasurements = SMESHGUI::GetSMESHGen()->CreateMeasurements();
|
|
|
|
}
|
|
|
|
return aMeasurements;
|
|
|
|
}
|
2009-02-17 10:27:49 +05:00
|
|
|
} // end of namespace SMESH
|