2024-01-20 19:16:41 +05:00
// Copyright (C) 2011-2024 CEA, EDF
2021-12-01 21:12:39 +05:00
//
// 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
//
# include "SMESHGUI_HomardBoundaryDlg.h"
# include "SMESHGUI_HomardAdaptDlg.h"
# include "SMESHGUI_HomardListGroup.h"
# include "SMESHGUI_Utils.h"
# include <QFileDialog>
# include <QMessageBox>
# include "SalomeApp_Tools.h"
# include "SMESHGUI_HomardUtils.h"
# include <utilities.h>
# include <SUIT_Desktop.h>
# include <SUIT_MessageBox.h>
# include <SUIT_ResourceMgr.h>
# include <SUIT_Session.h>
# include <SUIT_ViewManager.h>
# include "math.h"
# define PI 3.141592653589793
using namespace std ;
// ----------------------------------------------------------------------------------
SMESH_CreateBoundaryAn : : SMESH_CreateBoundaryAn ( SMESHGUI_HomardAdaptDlg * parent , bool modal ,
SMESHHOMARD : : HOMARD_Gen_var myHomardGen0 ,
QString caseName ) :
/* Constructs a SMESH_CreateBoundaryAn
appele pour une vraie creation
initialise un cylindre et non une sphere
*/
QDialog ( 0 ) , SMESH_Ui_CreateBoundaryAn ( ) ,
_parent ( parent ) ,
_Name ( " " ) ,
_Type ( 1 ) ,
_BoundaryAnXcentre ( 0 ) , _BoundaryAnYcentre ( 0 ) , _BoundaryAnZcentre ( 0 ) , _BoundaryAnRayon ( 0 ) ,
_BoundaryAnXaxis ( 0 ) , _BoundaryAnYaxis ( 0 ) , _BoundaryAnZaxis ( 0 ) ,
_Xcentre ( 0 ) , _Ycentre ( 0 ) , _Zcentre ( 0 ) , _Rayon ( 0 ) ,
_Xmin ( 0 ) , _Xmax ( 0 ) , _Xincr ( 0 ) , _Ymin ( 0 ) , _Ymax ( 0 ) , _Yincr ( 0 ) , _Zmin ( 0 ) , _Zmax ( 0 ) , _Zincr ( 0 ) , _DMax ( 0 ) ,
_BoundaryAnXcone1 ( 0 ) , _BoundaryAnYcone1 ( 0 ) , _BoundaryAnZcone1 ( 0 ) , _BoundaryAnRayon1 ( 0 ) ,
_BoundaryAnXcone2 ( 0 ) , _BoundaryAnYcone2 ( 0 ) , _BoundaryAnZcone2 ( 0 ) , _BoundaryAnRayon2 ( 0 ) ,
_BoundaryAnXaxisCone ( 0 ) , _BoundaryAnYaxisCone ( 0 ) , _BoundaryAnZaxisCone ( 0 ) ,
_BoundaryAnXorigCone ( 0 ) , _BoundaryAnYorigCone ( 0 ) , _BoundaryAnZorigCone ( 0 ) ,
_BoundaryAngle ( 0 ) ,
_BoundaryAnToreXcentre ( 0 ) , _BoundaryAnToreYcentre ( 0 ) , _BoundaryAnToreZcentre ( 0 ) ,
_BoundaryAnToreXaxe ( 0 ) , _BoundaryAnToreYaxe ( 0 ) , _BoundaryAnToreZaxe ( 0 ) ,
_BoundaryAnToreRRev ( 0 ) , _BoundaryAnToreRPri ( 0 ) ,
Chgt ( false )
{
MESSAGE ( " Constructeur " ) ;
myHomardGen = SMESHHOMARD : : HOMARD_Gen : : _duplicate ( myHomardGen0 ) ;
setupUi ( this ) ;
setModal ( modal ) ;
// Gestion des icones
QPixmap pix ;
QIcon IS ;
SUIT_ResourceMgr * resMgr = SUIT_Session : : session ( ) - > resourceMgr ( ) ;
pix = resMgr - > loadPixmap ( " HOMARD " , " spherepoint.png " ) ;
IS = QIcon ( pix ) ;
RBSphere - > setIcon ( IS ) ;
pix = resMgr - > loadPixmap ( " HOMARD " , " cylinderpointvector.png " ) ;
IS = QIcon ( pix ) ;
RBCylindre - > setIcon ( IS ) ;
pix = resMgr - > loadPixmap ( " HOMARD " , " cone.png " ) ;
IS = QIcon ( pix ) ;
RBCone - > setIcon ( IS ) ;
pix = resMgr - > loadPixmap ( " HOMARD " , " conepointvector.png " ) ;
IS = QIcon ( pix ) ;
RB_Def_angle - > setIcon ( IS ) ;
pix = resMgr - > loadPixmap ( " HOMARD " , " conedxyz.png " ) ;
IS = QIcon ( pix ) ;
RB_Def_radius - > setIcon ( IS ) ;
pix = resMgr - > loadPixmap ( " HOMARD " , " toruspointvector.png " ) ;
IS = QIcon ( pix ) ;
RBTore - > setIcon ( IS ) ;
InitConnect ( ) ;
SetNewName ( ) ;
InitValBoundaryAn ( ) ; // Cherche les valeurs de la boite englobante le maillage
InitMinMax ( ) ; // Initialise les bornes des boutons
SetCylinder ( ) ; // Propose un cylindre en premier choix
}
// -------------------------------------------------------------------------------
SMESH_CreateBoundaryAn : : SMESH_CreateBoundaryAn ( SMESHGUI_HomardAdaptDlg * parent ,
SMESHHOMARD : : HOMARD_Gen_var myHomardGen0 ,
QString caseName ) :
QDialog ( 0 ) , SMESH_Ui_CreateBoundaryAn ( ) ,
_parent ( parent ) ,
_Name ( " " ) ,
_Type ( 1 ) ,
_BoundaryAnXcentre ( 0 ) , _BoundaryAnYcentre ( 0 ) , _BoundaryAnZcentre ( 0 ) , _BoundaryAnRayon ( 0 ) ,
_BoundaryAnXaxis ( 0 ) , _BoundaryAnYaxis ( 0 ) , _BoundaryAnZaxis ( 0 ) ,
// Pour affichage lors de l edition d une BoundaryAn sans nom de Cas
_Xcentre ( 0 ) , _Ycentre ( 0 ) , _Zcentre ( 0 ) , _Rayon ( 0 ) ,
_Xmin ( 1 ) , _Xmax ( 1 ) , _Xincr ( 1 ) , _Ymin ( 1 ) , _Ymax ( 1 ) , _Yincr ( 1 ) , _Zmin ( 1 ) , _Zmax ( 1 ) , _Zincr ( 1 ) , _DMax ( 1 ) ,
Chgt ( false )
{
// MESSAGE("Debut de SMESH_CreateBoundaryAn")
myHomardGen = SMESHHOMARD : : HOMARD_Gen : : _duplicate ( myHomardGen0 ) ;
setupUi ( this ) ;
SUIT_ResourceMgr * resMgr = SUIT_Session : : session ( ) - > resourceMgr ( ) ;
QPixmap pix = resMgr - > loadPixmap ( " HOMARD " , " spherepoint.png " ) ;
QIcon IS = QIcon ( pix ) ;
RBSphere - > setIcon ( IS ) ;
QPixmap pix2 = resMgr - > loadPixmap ( " HOMARD " , " cylinderpointvector.png " ) ;
QIcon IS2 = QIcon ( pix2 ) ;
RBCylindre - > setIcon ( IS2 ) ;
QPixmap pix3 = resMgr - > loadPixmap ( " HOMARD " , " cone.png " ) ;
QIcon IS3 = QIcon ( pix3 ) ;
RBCone - > setIcon ( IS3 ) ;
QPixmap pix4 = resMgr - > loadPixmap ( " HOMARD " , " conepointvector.png " ) ;
QIcon IS4 = QIcon ( pix4 ) ;
RB_Def_angle - > setIcon ( IS4 ) ;
QPixmap pix5 = resMgr - > loadPixmap ( " HOMARD " , " conedxyz.png " ) ;
QIcon IS5 = QIcon ( pix5 ) ;
RB_Def_radius - > setIcon ( IS5 ) ;
setModal ( true ) ;
InitConnect ( ) ;
}
// ------------------------------------------------------------------------
SMESH_CreateBoundaryAn : : ~ SMESH_CreateBoundaryAn ( )
// ------------------------------------------------------------------------
{
// no need to delete child widgets, Qt does it all for us
}
// ------------------------------------------------------------------------
void SMESH_CreateBoundaryAn : : InitConnect ( )
// ------------------------------------------------------------------------
{
connect ( RBCylindre , SIGNAL ( clicked ( ) ) , this , SLOT ( SetCylinder ( ) ) ) ;
connect ( RBSphere , SIGNAL ( clicked ( ) ) , this , SLOT ( SetSphere ( ) ) ) ;
connect ( RBCone , SIGNAL ( clicked ( ) ) , this , SLOT ( SetCone ( ) ) ) ;
connect ( RB_Def_radius , SIGNAL ( clicked ( ) ) , this , SLOT ( SetConeR ( ) ) ) ;
connect ( RB_Def_angle , SIGNAL ( clicked ( ) ) , this , SLOT ( SetConeA ( ) ) ) ;
connect ( RBTore , SIGNAL ( clicked ( ) ) , this , SLOT ( SetTore ( ) ) ) ;
connect ( buttonOk , SIGNAL ( pressed ( ) ) , this , SLOT ( PushOnOK ( ) ) ) ;
connect ( buttonApply , SIGNAL ( pressed ( ) ) , this , SLOT ( PushOnApply ( ) ) ) ;
connect ( buttonCancel , SIGNAL ( pressed ( ) ) , this , SLOT ( close ( ) ) ) ;
connect ( buttonHelp , SIGNAL ( pressed ( ) ) , this , SLOT ( PushOnHelp ( ) ) ) ;
}
// ------------------------------------------------------------------------
void SMESH_CreateBoundaryAn : : InitValBoundaryAn ( )
// ------------------------------------------------------------------------
{
//
// 1. Les coordonnees extremes du maillage
//
SMESHHOMARD : : HOMARD_Cas_var aCas = myHomardGen - > GetCase ( ) ;
SMESHHOMARD : : extrema_var MesExtremes = aCas - > GetBoundingBox ( ) ;
int num = MesExtremes - > length ( ) ;
ASSERT ( num = = 10 ) ;
_Xmin = MesExtremes [ 0 ] ; _Xmax = MesExtremes [ 1 ] ; _Xincr = MesExtremes [ 2 ] ;
_Ymin = MesExtremes [ 3 ] ; _Ymax = MesExtremes [ 4 ] ; _Yincr = MesExtremes [ 5 ] ;
_Zmin = MesExtremes [ 6 ] ; _Zmax = MesExtremes [ 7 ] ; _Zincr = MesExtremes [ 8 ] ;
_DMax = MesExtremes [ 9 ] ;
MESSAGE ( " _Xmin : " < < _Xmin < < " _Xmax : " < < _Xmax < < " _Xincr : " < < _Xincr ) ;
MESSAGE ( " _Ymin : " < < _Ymin < < " _Ymax : " < < _Ymax < < " _Yincr : " < < _Yincr ) ;
MESSAGE ( " _Zmin : " < < _Zmin < < " _Zmax : " < < _Zmax < < " _Zincr : " < < _Zincr ) ;
MESSAGE ( " _DMax : " < < _DMax ) ;
// 2. Caracteristiques des frontieres
// en X
_Xcentre = ( _Xmin + _Xmax ) / 2. ;
// en Y
_Ycentre = ( _Ymin + _Ymax ) / 2. ;
// en Z
_Zcentre = ( _Zmin + _Zmax ) / 2. ;
// Rayon
_Rayon = _DMax / 4. ;
}
// ------------------------------------------------------------------------
void SMESH_CreateBoundaryAn : : InitMinMax ( )
// ------------------------------------------------------------------------
{
// Cylindre
// . X du centre
SpinBox_Xcent - > setValue ( _Xcentre ) ;
SpinBox_Xcent - > setSingleStep ( _Xincr ) ;
// . Y du centre
SpinBox_Ycent - > setValue ( _Ycentre ) ;
SpinBox_Ycent - > setSingleStep ( _Yincr ) ;
// . Z du centre
SpinBox_Zcent - > setValue ( _Zcentre ) ;
SpinBox_Zcent - > setSingleStep ( _Zincr ) ;
// . X de l'axe
SpinBox_Xaxis - > setValue ( 0. ) ;
SpinBox_Xaxis - > setSingleStep ( 0.1 ) ;
// . Y de l'axe
SpinBox_Yaxis - > setValue ( 0. ) ;
SpinBox_Yaxis - > setSingleStep ( 0.1 ) ;
// . Z de l'axe
SpinBox_Zaxis - > setValue ( 1. ) ;
SpinBox_Zaxis - > setSingleStep ( 0.1 ) ;
// . Rayon
SpinBox_Radius - > setValue ( _Rayon ) ;
SpinBox_Radius - > setSingleStep ( _Rayon / 10. ) ;
// Sphere
// . X du centre
SpinBox_Xcentre - > setValue ( _Xcentre ) ;
SpinBox_Xcentre - > setSingleStep ( _Xincr ) ;
// . Y du centre
SpinBox_Ycentre - > setValue ( _Ycentre ) ;
SpinBox_Ycentre - > setSingleStep ( _Yincr ) ;
// . Z du centre
SpinBox_Zcentre - > setValue ( _Zcentre ) ;
SpinBox_Zcentre - > setSingleStep ( _Zincr ) ;
// . Rayon
SpinBox_Rayon - > setValue ( _Rayon ) ;
SpinBox_Rayon - > setSingleStep ( _Rayon / 10. ) ;
// Cone en rayons
// . X des centres
_BoundaryAnXcone1 = _Xcentre ;
SpinBox_Cone_X1 - > setSingleStep ( _Xincr ) ;
_BoundaryAnXcone2 = _Xcentre ;
SpinBox_Cone_X2 - > setSingleStep ( _Xincr ) ;
// . Y des centres
_BoundaryAnYcone1 = _Ycentre ;
SpinBox_Cone_Y1 - > setSingleStep ( _Yincr ) ;
_BoundaryAnYcone2 = _Ycentre ;
SpinBox_Cone_Y2 - > setSingleStep ( _Yincr ) ;
// . Z des centres
_BoundaryAnZcone1 = _Zmin ;
SpinBox_Cone_Z1 - > setSingleStep ( _Zincr ) ;
_BoundaryAnZcone2 = _Zmax ;
SpinBox_Cone_Z2 - > setSingleStep ( _Zincr ) ;
// . Rayons/Angles
_BoundaryAnRayon1 = 0. ;
_BoundaryAnRayon2 = _Rayon ;
SpinBox_Cone_V2 - > setSingleStep ( _Rayon / 10. ) ;
// Cone en angle
convertRayonAngle ( 1 ) ;
SpinBox_Cone_X1 - > setValue ( _BoundaryAnXaxisCone ) ;
SpinBox_Cone_Y1 - > setValue ( _BoundaryAnYaxisCone ) ;
SpinBox_Cone_Z1 - > setValue ( _BoundaryAnZaxisCone ) ;
SpinBox_Cone_V1 - > setValue ( _BoundaryAngle ) ;
SpinBox_Cone_X2 - > setValue ( _BoundaryAnXorigCone ) ;
SpinBox_Cone_Y2 - > setValue ( _BoundaryAnYorigCone ) ;
SpinBox_Cone_Z2 - > setValue ( _BoundaryAnZorigCone ) ;
// Tore
// . X du centre
SpinBoxToreXcent - > setValue ( _Xcentre ) ;
SpinBoxToreXcent - > setSingleStep ( _Xincr ) ;
// . Y du centre
SpinBoxToreYcent - > setValue ( _Ycentre ) ;
SpinBoxToreYcent - > setSingleStep ( _Yincr ) ;
// . Z du centre
SpinBoxToreZcent - > setValue ( _Zcentre ) ;
SpinBoxToreZcent - > setSingleStep ( _Zincr ) ;
// . X de l'axe
SpinBoxToreXaxe - > setValue ( 0. ) ;
SpinBoxToreXaxe - > setSingleStep ( 0.1 ) ;
// . Y de l'axe
SpinBoxToreYaxe - > setValue ( 0. ) ;
SpinBoxToreYaxe - > setSingleStep ( 0.1 ) ;
// . Z de l'axe
SpinBoxToreZaxe - > setValue ( 1. ) ;
SpinBoxToreZaxe - > setSingleStep ( 0.1 ) ;
// . Rayon de revolution
SpinBoxToreRRev - > setValue ( _Rayon ) ;
SpinBoxToreRRev - > setSingleStep ( _Rayon / 10. ) ;
// . Rayon primaire
SpinBoxToreRPri - > setValue ( _Rayon / 3. ) ;
SpinBoxToreRPri - > setSingleStep ( _Rayon / 20. ) ;
}
// ------------------------------------------------------------------------
bool SMESH_CreateBoundaryAn : : PushOnApply ( )
// ------------------------------------------------------------------------
// Appele lorsque l'un des boutons Ok ou Apply est presse
//
{
if ( LEName - > text ( ) . trimmed ( ) = = " " )
{
QMessageBox : : critical ( 0 , QObject : : tr ( " HOM_ERROR " ) ,
QObject : : tr ( " HOM_BOUN_NAME " ) ) ;
return false ;
}
switch ( _Type )
{
case 1 : // il s agit d un cylindre
{
if ( ( _BoundaryAnXcentre ! = SpinBox_Xcent - > value ( ) ) | |
( _BoundaryAnYcentre ! = SpinBox_Ycent - > value ( ) ) | |
( _BoundaryAnZcentre ! = SpinBox_Zcent - > value ( ) ) | |
( _BoundaryAnRayon ! = SpinBox_Radius - > value ( ) ) | |
( _BoundaryAnXaxis ! = SpinBox_Xaxis - > value ( ) ) | |
( _BoundaryAnYaxis ! = SpinBox_Yaxis - > value ( ) ) | |
( _BoundaryAnZaxis ! = SpinBox_Zaxis - > value ( ) ) )
{
Chgt = true ;
_BoundaryAnXaxis = SpinBox_Xaxis - > value ( ) ;
_BoundaryAnYaxis = SpinBox_Yaxis - > value ( ) ;
_BoundaryAnZaxis = SpinBox_Zaxis - > value ( ) ;
_BoundaryAnXcentre = SpinBox_Xcent - > value ( ) ;
_BoundaryAnYcentre = SpinBox_Ycent - > value ( ) ;
_BoundaryAnZcentre = SpinBox_Zcent - > value ( ) ;
_BoundaryAnRayon = SpinBox_Radius - > value ( ) ;
}
break ;
}
case 2 : // il s agit d une sphere
{
if ( ( _BoundaryAnXcentre ! = SpinBox_Xcentre - > value ( ) ) | |
( _BoundaryAnYcentre ! = SpinBox_Ycentre - > value ( ) ) | |
( _BoundaryAnZcentre ! = SpinBox_Zcentre - > value ( ) ) | |
( _BoundaryAnRayon ! = SpinBox_Rayon - > value ( ) ) )
{
Chgt = true ;
_BoundaryAnXcentre = SpinBox_Xcentre - > value ( ) ;
_BoundaryAnYcentre = SpinBox_Ycentre - > value ( ) ;
_BoundaryAnZcentre = SpinBox_Zcentre - > value ( ) ;
_BoundaryAnRayon = SpinBox_Rayon - > value ( ) ;
}
break ;
}
case 3 : // il s agit d un cone defini par un axe et un angle
{
if ( ( _BoundaryAnXaxisCone ! = SpinBox_Cone_X1 - > value ( ) ) | |
( _BoundaryAnYaxisCone ! = SpinBox_Cone_Y1 - > value ( ) ) | |
( _BoundaryAnZaxisCone ! = SpinBox_Cone_Z1 - > value ( ) ) | |
( _BoundaryAnXorigCone ! = SpinBox_Cone_X2 - > value ( ) ) | |
( _BoundaryAnYorigCone ! = SpinBox_Cone_Y2 - > value ( ) ) | |
( _BoundaryAnZorigCone ! = SpinBox_Cone_Z2 - > value ( ) ) | |
( _BoundaryAngle ! = SpinBox_Cone_V1 - > value ( ) ) )
{
Chgt = true ;
_BoundaryAnXaxisCone = SpinBox_Cone_X1 - > value ( ) ;
_BoundaryAnYaxisCone = SpinBox_Cone_Y1 - > value ( ) ;
_BoundaryAnZaxisCone = SpinBox_Cone_Z1 - > value ( ) ;
_BoundaryAnXorigCone = SpinBox_Cone_X2 - > value ( ) ;
_BoundaryAnYorigCone = SpinBox_Cone_Y2 - > value ( ) ;
_BoundaryAnZorigCone = SpinBox_Cone_Z2 - > value ( ) ;
_BoundaryAngle = SpinBox_Cone_V1 - > value ( ) ;
}
break ;
}
case 4 : // il s agit d un cone defini par les 2 rayons
{
if ( ( _BoundaryAnXcone1 ! = SpinBox_Cone_X1 - > value ( ) ) | |
( _BoundaryAnYcone1 ! = SpinBox_Cone_Y1 - > value ( ) ) | |
( _BoundaryAnZcone1 ! = SpinBox_Cone_Z1 - > value ( ) ) | |
( _BoundaryAnRayon1 ! = SpinBox_Cone_V1 - > value ( ) ) | |
( _BoundaryAnXcone2 ! = SpinBox_Cone_X2 - > value ( ) ) | |
( _BoundaryAnYcone2 ! = SpinBox_Cone_Y2 - > value ( ) ) | |
( _BoundaryAnZcone2 ! = SpinBox_Cone_Z2 - > value ( ) ) | |
( _BoundaryAnRayon2 ! = SpinBox_Cone_V2 - > value ( ) ) )
{
Chgt = true ;
_BoundaryAnXcone1 = SpinBox_Cone_X1 - > value ( ) ;
_BoundaryAnYcone1 = SpinBox_Cone_Y1 - > value ( ) ;
_BoundaryAnZcone1 = SpinBox_Cone_Z1 - > value ( ) ;
_BoundaryAnRayon1 = SpinBox_Cone_V1 - > value ( ) ;
_BoundaryAnXcone2 = SpinBox_Cone_X2 - > value ( ) ;
_BoundaryAnYcone2 = SpinBox_Cone_Y2 - > value ( ) ;
_BoundaryAnZcone2 = SpinBox_Cone_Z2 - > value ( ) ;
_BoundaryAnRayon2 = SpinBox_Cone_V2 - > value ( ) ;
}
break ;
}
case 5 : // il s agit d un tore
{
if ( ( _BoundaryAnToreXcentre ! = SpinBoxToreXcent - > value ( ) ) | |
( _BoundaryAnToreYcentre ! = SpinBoxToreYcent - > value ( ) ) | |
( _BoundaryAnToreZcentre ! = SpinBoxToreZcent - > value ( ) ) | |
( _BoundaryAnToreRRev ! = SpinBoxToreRRev - > value ( ) ) | |
( _BoundaryAnToreRPri ! = SpinBoxToreRPri - > value ( ) ) | |
( _BoundaryAnToreXaxe ! = SpinBoxToreXaxe - > value ( ) ) | |
( _BoundaryAnToreYaxe ! = SpinBoxToreYaxe - > value ( ) ) | |
( _BoundaryAnToreZaxe ! = SpinBoxToreZaxe - > value ( ) ) )
{
Chgt = true ;
_BoundaryAnToreXcentre = SpinBoxToreXcent - > value ( ) ;
_BoundaryAnToreYcentre = SpinBoxToreYcent - > value ( ) ;
_BoundaryAnToreZcentre = SpinBoxToreZcent - > value ( ) ;
_BoundaryAnToreRRev = SpinBoxToreRRev - > value ( ) ;
_BoundaryAnToreRPri = SpinBoxToreRPri - > value ( ) ;
_BoundaryAnToreXaxe = SpinBoxToreXaxe - > value ( ) ;
_BoundaryAnToreYaxe = SpinBoxToreYaxe - > value ( ) ;
_BoundaryAnToreZaxe = SpinBoxToreZaxe - > value ( ) ;
}
break ;
}
}
// Controles
// L'axe pour un cylindre
if ( _Type = = 5 )
{
double daux = _BoundaryAnXaxis * _BoundaryAnXaxis + _BoundaryAnYaxis * _BoundaryAnYaxis + _BoundaryAnZaxis * _BoundaryAnZaxis ;
if ( daux < 0.0000001 )
{
QMessageBox : : critical ( 0 , QObject : : tr ( " HOM_ERROR " ) ,
QObject : : tr ( " HOM_AXE " ) ) ;
return false ;
}
}
//
// Création ou mise à jour de la frontière
//
bool bOK = CreateOrUpdateBoundaryAn ( ) ;
//if ( bOK ) { HOMARD_UTILS::updateObjBrowser() ; }
return bOK ;
}
// ---------------------------------------------------
bool SMESH_CreateBoundaryAn : : CreateOrUpdateBoundaryAn ( )
//----------------------------------------------------
// Creation de l'objet boundary
{
MESSAGE ( " Debut de CreateOrUpdateBoundaryAn avec _Type = " < < _Type < < " , _Name = " < < _Name . toStdString ( ) . c_str ( ) < < " et LEName = " < < LEName - > text ( ) . trimmed ( ) . toStdString ( ) . c_str ( ) ) ;
//
if ( _Name ! = LEName - > text ( ) . trimmed ( ) )
{
_Name = LEName - > text ( ) . trimmed ( ) ;
try
{
switch ( _Type )
{
case 1 : // il s agit d un cylindre
{ aBoundaryAn = myHomardGen - > CreateBoundaryCylinder ( CORBA : : string_dup ( _Name . toStdString ( ) . c_str ( ) ) , \
_BoundaryAnXcentre , _BoundaryAnYcentre , _BoundaryAnZcentre , _BoundaryAnXaxis , _BoundaryAnYaxis , _BoundaryAnZaxis , _BoundaryAnRayon ) ;
break ;
}
case 2 : // il s agit d une sphere
{ aBoundaryAn = myHomardGen - > CreateBoundarySphere ( CORBA : : string_dup ( _Name . toStdString ( ) . c_str ( ) ) , \
_BoundaryAnXcentre , _BoundaryAnYcentre , _BoundaryAnZcentre , _BoundaryAnRayon ) ;
break ;
}
case 3 : // il s agit d un cone defini par un axe et un angle
{ aBoundaryAn = myHomardGen - > CreateBoundaryConeA ( CORBA : : string_dup ( _Name . toStdString ( ) . c_str ( ) ) , \
_BoundaryAnXaxisCone , _BoundaryAnYaxisCone , _BoundaryAnZaxisCone , _BoundaryAngle , \
_BoundaryAnXorigCone , _BoundaryAnYorigCone , _BoundaryAnYorigCone ) ;
break ;
}
case 4 : // il s agit d un cone defini par les 2 rayons
{ aBoundaryAn = myHomardGen - > CreateBoundaryConeR ( CORBA : : string_dup ( _Name . toStdString ( ) . c_str ( ) ) , \
_BoundaryAnXcone1 , _BoundaryAnYcone1 , _BoundaryAnZcone1 , _BoundaryAnRayon1 , \
_BoundaryAnXcone2 , _BoundaryAnYcone2 , _BoundaryAnZcone2 , _BoundaryAnRayon2 ) ;
break ;
}
case 5 : // il s agit d un tore
{ aBoundaryAn = myHomardGen - > CreateBoundaryTorus ( CORBA : : string_dup ( _Name . toStdString ( ) . c_str ( ) ) , \
_BoundaryAnToreXcentre , _BoundaryAnToreYcentre , _BoundaryAnToreZcentre , _BoundaryAnToreXaxe , _BoundaryAnToreYaxe , _BoundaryAnToreZaxe , _BoundaryAnToreRRev , _BoundaryAnToreRPri ) ;
break ;
}
}
}
catch ( SALOME : : SALOME_Exception & S_ex )
{
QMessageBox : : critical ( 0 , QObject : : tr ( " HOM_ERROR " ) ,
QObject : : tr ( CORBA : : string_dup ( S_ex . details . text ) ) ) ;
return false ;
}
_parent - > AddBoundaryAn ( _Name ) ;
return true ;
}
else {
QMessageBox : : warning ( 0 , QObject : : tr ( " HOM_WARNING " ) ,
QObject : : tr ( " HOM_SELECT_OBJECT_4 " ) ) ;
return false ;
}
MESSAGE ( " Fin de CreateOrUpdateBoundaryAn " ) ;
}
// ------------------------------------------------------------------------
void SMESH_CreateBoundaryAn : : PushOnOK ( )
// ------------------------------------------------------------------------
{
if ( PushOnApply ( ) ) this - > close ( ) ;
}
// ------------------------------------------------------------------------
void SMESH_CreateBoundaryAn : : PushOnHelp ( )
// ------------------------------------------------------------------------
{
SMESH : : ShowHelpFile ( QString ( " homard_create_boundary.html#analytical-boundary " ) ) ;
}
// -----------------------------------
void SMESH_CreateBoundaryAn : : SetNewName ( )
// -----------------------------------
{
// Recherche d'un nom par defaut qui n'existe pas encore
SMESHHOMARD : : listeBoundarys_var MyObjects = myHomardGen - > GetAllBoundarysName ( ) ;
int num = 0 ; QString aName = " " ;
while ( aName = = " " )
{
aName . setNum ( num + 1 ) ;
aName . insert ( 0 , QString ( " Boun_ " ) ) ;
for ( int i = 0 ; i < MyObjects - > length ( ) ; i + + )
{
if ( aName = = QString ( MyObjects [ i ] ) )
{
num + + ;
aName = " " ;
break ;
}
}
}
LEName - > setText ( aName ) ;
}
// ------------------------------------------------------------------------
void SMESH_CreateBoundaryAn : : SetCylinder ( )
// ------------------------------------------------------------------------
{
2022-11-15 11:04:21 +05:00
MESSAGE ( " Debut de SetCylinder " ) ;
2021-12-01 21:12:39 +05:00
gBCylindre - > setVisible ( 1 ) ;
gBSphere - > setVisible ( 0 ) ;
gBCone - > setVisible ( 0 ) ;
gBTore - > setVisible ( 0 ) ;
//
_Type = 1 ;
//
adjustSize ( ) ;
// MESSAGE("Fin de SetCylinder")
}
// ------------------------------------------------------------------------
void SMESH_CreateBoundaryAn : : SetSphere ( )
// ------------------------------------------------------------------------
{
2022-11-15 11:04:21 +05:00
MESSAGE ( " Debut de SetSphere " ) ;
2021-12-01 21:12:39 +05:00
gBCylindre - > setVisible ( 0 ) ;
gBSphere - > setVisible ( 1 ) ;
gBCone - > setVisible ( 0 ) ;
gBTore - > setVisible ( 0 ) ;
//
_Type = 2 ;
//
adjustSize ( ) ;
// MESSAGE("Fin de SetSphere")
}
// ------------------------------------------------------------------------
void SMESH_CreateBoundaryAn : : SetConeR ( )
// ------------------------------------------------------------------------
{
2022-11-15 11:04:21 +05:00
MESSAGE ( " Debut de SetConeR " ) ;
2021-12-01 21:12:39 +05:00
//
// Stockage et conversion des valeurs si elles ont change
if ( ( _BoundaryAnXaxisCone ! = SpinBox_Cone_X1 - > value ( ) ) | |
( _BoundaryAnYaxisCone ! = SpinBox_Cone_Y1 - > value ( ) ) | |
( _BoundaryAnZaxisCone ! = SpinBox_Cone_Z1 - > value ( ) ) | |
( _BoundaryAnXorigCone ! = SpinBox_Cone_X2 - > value ( ) ) | |
( _BoundaryAnYorigCone ! = SpinBox_Cone_Y2 - > value ( ) ) | |
( _BoundaryAnZorigCone ! = SpinBox_Cone_Z2 - > value ( ) ) | |
( _BoundaryAngle ! = SpinBox_Cone_V1 - > value ( ) ) )
{
2022-11-15 11:04:21 +05:00
MESSAGE ( " Stockage et conversion " ) ;
2021-12-01 21:12:39 +05:00
_BoundaryAnXaxisCone = SpinBox_Cone_X1 - > value ( ) ;
_BoundaryAnYaxisCone = SpinBox_Cone_Y1 - > value ( ) ;
_BoundaryAnZaxisCone = SpinBox_Cone_Z1 - > value ( ) ;
_BoundaryAnXorigCone = SpinBox_Cone_X2 - > value ( ) ;
_BoundaryAnYorigCone = SpinBox_Cone_Y2 - > value ( ) ;
_BoundaryAnZorigCone = SpinBox_Cone_Z2 - > value ( ) ;
_BoundaryAngle = SpinBox_Cone_V1 - > value ( ) ;
convertRayonAngle ( - 1 ) ;
}
//
_Type = 4 ;
//
TLCone_X1 - > setText ( QApplication : : translate ( " CreateBoundaryAn " , " X centre 1 " , 0 ) ) ;
SpinBox_Cone_X1 - > setValue ( _BoundaryAnXcone1 ) ;
TLCone_Y1 - > setText ( QApplication : : translate ( " CreateBoundaryAn " , " Y centre 1 " , 0 ) ) ;
SpinBox_Cone_Y1 - > setValue ( _BoundaryAnYcone1 ) ;
TLCone_Z1 - > setText ( QApplication : : translate ( " CreateBoundaryAn " , " Z centre 1 " , 0 ) ) ;
SpinBox_Cone_Z1 - > setValue ( _BoundaryAnZcone1 ) ;
//
TLCone_V1 - > setText ( QApplication : : translate ( " CreateBoundaryAn " , " Radius 1 " , 0 ) ) ;
SpinBox_Cone_V1 - > setSingleStep ( _Rayon / 10. ) ;
SpinBox_Cone_V1 - > setMaximum ( 100000. * _DMax ) ;
SpinBox_Cone_V1 - > setValue ( _BoundaryAnRayon1 ) ;
//
TLCone_X2 - > setText ( QApplication : : translate ( " CreateBoundaryAn " , " X centre 2 " , 0 ) ) ;
SpinBox_Cone_X2 - > setValue ( _BoundaryAnXcone2 ) ;
TLCone_Y2 - > setText ( QApplication : : translate ( " CreateBoundaryAn " , " Y centre 2 " , 0 ) ) ;
SpinBox_Cone_Y2 - > setValue ( _BoundaryAnYcone2 ) ;
TLCone_Z2 - > setText ( QApplication : : translate ( " CreateBoundaryAn " , " Z centre 2 " , 0 ) ) ;
SpinBox_Cone_Z2 - > setValue ( _BoundaryAnZcone2 ) ;
//
TLCone_V2 - > setVisible ( 1 ) ;
SpinBox_Cone_V2 - > setVisible ( 1 ) ;
TLCone_V2 - > setText ( QApplication : : translate ( " CreateBoundaryAn " , " Radius 2 " , 0 ) ) ;
SpinBox_Cone_V2 - > setValue ( _BoundaryAnRayon2 ) ;
//
// MESSAGE("Fin de SetConeR")
}
// ------------------------------------------------------------------------
void SMESH_CreateBoundaryAn : : SetConeA ( )
// ------------------------------------------------------------------------
{
2022-11-15 11:04:21 +05:00
MESSAGE ( " Debut de SetConeA " ) ;
2021-12-01 21:12:39 +05:00
// Stockage et conversion des valeurs si elles ont change
if ( ( _BoundaryAnXcone1 ! = SpinBox_Cone_X1 - > value ( ) ) | |
( _BoundaryAnYcone1 ! = SpinBox_Cone_Y1 - > value ( ) ) | |
( _BoundaryAnZcone1 ! = SpinBox_Cone_Z1 - > value ( ) ) | |
( _BoundaryAnRayon1 ! = SpinBox_Cone_V1 - > value ( ) ) | |
( _BoundaryAnXcone2 ! = SpinBox_Cone_X2 - > value ( ) ) | |
( _BoundaryAnYcone2 ! = SpinBox_Cone_Y2 - > value ( ) ) | |
( _BoundaryAnZcone2 ! = SpinBox_Cone_Z2 - > value ( ) ) | |
( _BoundaryAnRayon2 ! = SpinBox_Cone_V2 - > value ( ) ) )
{
2022-11-15 11:04:21 +05:00
MESSAGE ( " Stockage et conversion " ) ;
2021-12-01 21:12:39 +05:00
_BoundaryAnXcone1 = SpinBox_Cone_X1 - > value ( ) ;
_BoundaryAnYcone1 = SpinBox_Cone_Y1 - > value ( ) ;
_BoundaryAnZcone1 = SpinBox_Cone_Z1 - > value ( ) ;
_BoundaryAnRayon1 = SpinBox_Cone_V1 - > value ( ) ;
_BoundaryAnXcone2 = SpinBox_Cone_X2 - > value ( ) ;
_BoundaryAnYcone2 = SpinBox_Cone_Y2 - > value ( ) ;
_BoundaryAnZcone2 = SpinBox_Cone_Z2 - > value ( ) ;
_BoundaryAnRayon2 = SpinBox_Cone_V2 - > value ( ) ;
convertRayonAngle ( 1 ) ;
}
//
_Type = 3 ;
//
TLCone_X1 - > setText ( QApplication : : translate ( " CreateBoundaryAn " , " X axis " , 0 ) ) ;
SpinBox_Cone_X1 - > setValue ( _BoundaryAnXaxisCone ) ;
TLCone_Y1 - > setText ( QApplication : : translate ( " CreateBoundaryAn " , " Y axis " , 0 ) ) ;
SpinBox_Cone_Y1 - > setValue ( _BoundaryAnYaxisCone ) ;
TLCone_Z1 - > setText ( QApplication : : translate ( " CreateBoundaryAn " , " Z axis " , 0 ) ) ;
SpinBox_Cone_Z1 - > setValue ( _BoundaryAnZaxisCone ) ;
//
TLCone_X2 - > setText ( QApplication : : translate ( " CreateBoundaryAn " , " X centre " , 0 ) ) ;
SpinBox_Cone_X2 - > setValue ( _BoundaryAnXorigCone ) ;
TLCone_Y2 - > setText ( QApplication : : translate ( " CreateBoundaryAn " , " Y centre " , 0 ) ) ;
SpinBox_Cone_Y2 - > setValue ( _BoundaryAnYorigCone ) ;
TLCone_Z2 - > setText ( QApplication : : translate ( " CreateBoundaryAn " , " Z centre " , 0 ) ) ;
SpinBox_Cone_Z2 - > setValue ( _BoundaryAnZorigCone ) ;
//
TLCone_V1 - > setText ( QApplication : : translate ( " CreateBoundaryAn " , " Angle " , 0 ) ) ;
SpinBox_Cone_V1 - > setValue ( _BoundaryAngle ) ;
SpinBox_Cone_V1 - > setSingleStep ( 1. ) ;
SpinBox_Cone_V1 - > setMaximum ( 90. ) ;
//
TLCone_V2 - > setVisible ( 0 ) ;
SpinBox_Cone_V2 - > setVisible ( 0 ) ;
// MESSAGE("Fin de SetConeA")
}
// ------------------------------------------------------------------------
void SMESH_CreateBoundaryAn : : SetCone ( )
// ------------------------------------------------------------------------
{
2022-11-15 11:04:21 +05:00
MESSAGE ( " Debut de SetCone " ) ;
2021-12-01 21:12:39 +05:00
gBCylindre - > setVisible ( 0 ) ;
gBSphere - > setVisible ( 0 ) ;
gBCone - > setVisible ( 1 ) ;
gBTore - > setVisible ( 0 ) ;
//
if ( RB_Def_radius - > isChecked ( ) )
{
SetConeR ( ) ;
}
else
{
SetConeA ( ) ;
}
//
adjustSize ( ) ;
// MESSAGE("Fin de SetCone")
}
// ------------------------------------------------------------------------
void SMESH_CreateBoundaryAn : : SetTore ( )
// ------------------------------------------------------------------------
{
2022-11-15 11:04:21 +05:00
MESSAGE ( " Debut de SetTore " ) ;
2021-12-01 21:12:39 +05:00
gBCylindre - > setVisible ( 0 ) ;
gBSphere - > setVisible ( 0 ) ;
gBCone - > setVisible ( 0 ) ;
gBTore - > setVisible ( 1 ) ;
//
_Type = 5 ;
//
adjustSize ( ) ;
// MESSAGE("Fin de SetTore")
}
// ------------------------------------------------------------------------
void SMESH_CreateBoundaryAn : : convertRayonAngle ( int option )
// ------------------------------------------------------------------------
// Conversion entre les deux formulations du cone :
// par deux rayons ou avec un axe et un angle.
// Voir sfcoi1 de HOMARD
{
2022-11-15 11:04:21 +05:00
MESSAGE ( " Debut de convertRayonAngle, option = " < < option ) ;
2021-12-01 21:12:39 +05:00
//
// o
// ! .
// ! .
// RA! .
// ! o
// ! RB! .
// ! ! .
// A----------------B----------O
//
// Thales : RA/RB = AO/BO ==> BO = AB*RB/(RA-RB)
// Angle : tg(alpha) = RA/AO
//
double daux ;
// De rayon vers angle :
if ( option = = 1 )
{
double xa , ya , za , ra ;
double xb , yb , zb , rb ;
// Positionnement de A vers B, avec RA>RB
if ( _BoundaryAnRayon1 > _BoundaryAnRayon2 )
{
xa = _BoundaryAnXcone1 ;
ya = _BoundaryAnYcone1 ;
za = _BoundaryAnZcone1 ;
ra = _BoundaryAnRayon1 ;
xb = _BoundaryAnXcone2 ;
yb = _BoundaryAnYcone2 ;
zb = _BoundaryAnZcone2 ;
rb = _BoundaryAnRayon2 ;
}
else
{
xa = _BoundaryAnXcone2 ;
ya = _BoundaryAnYcone2 ;
za = _BoundaryAnZcone2 ;
ra = _BoundaryAnRayon2 ;
xb = _BoundaryAnXcone1 ;
yb = _BoundaryAnYcone1 ;
zb = _BoundaryAnZcone1 ;
rb = _BoundaryAnRayon1 ;
}
// Axe : relie les deux centres, de A vers B. L'axe est normalise
_BoundaryAnXaxisCone = xb - xa ;
_BoundaryAnYaxisCone = yb - ya ;
_BoundaryAnZaxisCone = zb - za ;
daux = sqrt ( _BoundaryAnXaxisCone * _BoundaryAnXaxisCone + _BoundaryAnYaxisCone * _BoundaryAnYaxisCone + _BoundaryAnZaxisCone * _BoundaryAnZaxisCone ) ;
_BoundaryAnXaxisCone = _BoundaryAnXaxisCone / daux ;
_BoundaryAnYaxisCone = _BoundaryAnYaxisCone / daux ;
_BoundaryAnZaxisCone = _BoundaryAnZaxisCone / daux ;
// Origine
daux = daux * rb / ( ra - rb ) ;
_BoundaryAnXorigCone = xb + daux * _BoundaryAnXaxisCone ;
_BoundaryAnYorigCone = yb + daux * _BoundaryAnYaxisCone ;
_BoundaryAnZorigCone = zb + daux * _BoundaryAnZaxisCone ;
// Angle en degre
daux = ra / sqrt ( ( _BoundaryAnXorigCone - xa ) * ( _BoundaryAnXorigCone - xa ) + ( _BoundaryAnYorigCone - ya ) * ( _BoundaryAnYorigCone - ya ) + ( _BoundaryAnZorigCone - za ) * ( _BoundaryAnZorigCone - za ) ) ;
_BoundaryAngle = atan ( daux ) * 180. / PI ;
}
// D'angle vers rayon :
else
{
double xax , yax , zax ;
// L'axe est normalise
daux = sqrt ( _BoundaryAnXaxisCone * _BoundaryAnXaxisCone + _BoundaryAnYaxisCone * _BoundaryAnYaxisCone + _BoundaryAnZaxisCone * _BoundaryAnZaxisCone ) ;
xax = _BoundaryAnXaxisCone / daux ;
yax = _BoundaryAnYaxisCone / daux ;
zax = _BoundaryAnZaxisCone / daux ;
// Centre 1 : l'origine
_BoundaryAnXcone1 = _BoundaryAnXorigCone ;
_BoundaryAnYcone1 = _BoundaryAnYorigCone ;
_BoundaryAnZcone1 = _BoundaryAnZorigCone ;
// Rayon 1 : nul
_BoundaryAnRayon1 = 0. ;
// Centre 2 : l'origine decalee d'une longueur arbitraire le long de l'axe
_BoundaryAnXcone2 = _BoundaryAnXorigCone + _DMax * xax ;
_BoundaryAnYcone2 = _BoundaryAnYorigCone + _DMax * yax ;
_BoundaryAnZcone2 = _BoundaryAnZorigCone + _DMax * zax ;
// Rayon 2 : a calculer
_BoundaryAnRayon2 = _DMax * tan ( _BoundaryAngle * PI / 180. ) ;
}
// MESSAGE("Fin de convertRayonAngle")
}
// -------------------------------------------------------------------------------
SMESH_CreateBoundaryCAO : : SMESH_CreateBoundaryCAO ( SMESHGUI_HomardAdaptDlg * parent , bool modal ,
SMESHHOMARD : : HOMARD_Gen_var myHomardGen0 ,
QString caseName , QString aName )
// ---------------------------------------------------------------------------------
/* Constructs a SMESH_CreateBoundaryCAO */
:
QDialog ( 0 ) , SMESH_Ui_CreateBoundaryCAO ( ) ,
_parent ( parent ) , _aName ( aName ) ,
myHomardGen ( SMESHHOMARD : : HOMARD_Gen : : _duplicate ( myHomardGen0 ) )
{
2022-11-15 11:04:21 +05:00
MESSAGE ( " Constructeur " ) ;
2021-12-01 21:12:39 +05:00
setupUi ( this ) ;
setModal ( modal ) ;
InitConnect ( ) ;
if ( _aName = = QString ( " " ) ) { SetNewName ( ) ; } ;
}
// ------------------------------------------------------------------------
SMESH_CreateBoundaryCAO : : ~ SMESH_CreateBoundaryCAO ( )
// ------------------------------------------------------------------------
{
// no need to delete child widgets, Qt does it all for us
}
// ------------------------------------------------------------------------
void SMESH_CreateBoundaryCAO : : InitConnect ( )
// ------------------------------------------------------------------------
{
connect ( PushFichier , SIGNAL ( pressed ( ) ) , this , SLOT ( SetCAOFile ( ) ) ) ;
connect ( buttonOk , SIGNAL ( pressed ( ) ) , this , SLOT ( PushOnOK ( ) ) ) ;
connect ( buttonApply , SIGNAL ( pressed ( ) ) , this , SLOT ( PushOnApply ( ) ) ) ;
connect ( buttonCancel , SIGNAL ( pressed ( ) ) , this , SLOT ( close ( ) ) ) ;
connect ( buttonHelp , SIGNAL ( pressed ( ) ) , this , SLOT ( PushOnHelp ( ) ) ) ;
connect ( CBGroupe , SIGNAL ( stateChanged ( int ) ) , this , SLOT ( SetFiltrage ( ) ) ) ;
}
// ------------------------------------------------------------------------
bool SMESH_CreateBoundaryCAO : : PushOnApply ( )
// ------------------------------------------------------------------------
// Appele lorsque l'un des boutons Ok ou Apply est presse
//
{
// Verifications
QString aName = LEName - > text ( ) . trimmed ( ) ;
if ( aName = = " " ) {
QMessageBox : : critical ( 0 , QObject : : tr ( " HOM_ERROR " ) ,
QObject : : tr ( " HOM_BOUN_NAME " ) ) ;
return false ;
}
// La CAO
QString aCAOFile = LEFileName - > text ( ) . trimmed ( ) ;
if ( aCAOFile = = QString ( " " ) )
{
QMessageBox : : critical ( 0 , QObject : : tr ( " HOM_ERROR " ) ,
QObject : : tr ( " HOM_BOUN_CAO " ) ) ;
return false ;
}
// Creation de l'objet CORBA si ce n'est pas deja fait sous le meme nom
if ( _aName ! = aName )
{
try
{
_aName = aName ;
aBoundary = myHomardGen - > CreateBoundaryCAO ( CORBA : : string_dup ( _aName . toStdString ( ) . c_str ( ) ) , aCAOFile . toStdString ( ) . c_str ( ) ) ;
_parent - > AddBoundaryCAO ( _aName ) ;
}
catch ( SALOME : : SALOME_Exception & S_ex )
{
QMessageBox : : critical ( 0 , QObject : : tr ( " HOM_ERROR " ) ,
QObject : : tr ( CORBA : : string_dup ( S_ex . details . text ) ) ) ;
return false ;
}
}
// Les groupes
AssocieLesGroupes ( ) ;
//HOMARD_UTILS::updateObjBrowser();
return true ;
}
// ------------------------------------------------------------------------
void SMESH_CreateBoundaryCAO : : PushOnOK ( )
// ------------------------------------------------------------------------
{
if ( PushOnApply ( ) ) this - > close ( ) ;
if ( _parent ) { _parent - > raise ( ) ; _parent - > activateWindow ( ) ; } ;
}
// ------------------------------------------------------------------------
void SMESH_CreateBoundaryCAO : : PushOnHelp ( )
// ------------------------------------------------------------------------
{
SMESH : : ShowHelpFile ( QString ( " homard_create_boundary.html#cao-boundary " ) ) ;
}
// ------------------------------------------------------------------------
void SMESH_CreateBoundaryCAO : : AssocieLesGroupes ( )
// ------------------------------------------------------------------------
{
SMESHHOMARD : : ListGroupType_var aSeqGroupe = new SMESHHOMARD : : ListGroupType ;
aSeqGroupe - > length ( _listeGroupesBoundary . size ( ) ) ;
QStringList : : const_iterator it ;
int i = 0 ;
for ( it = _listeGroupesBoundary . constBegin ( ) ; it ! = _listeGroupesBoundary . constEnd ( ) ; it + + )
aSeqGroupe [ i + + ] = ( * it ) . toStdString ( ) . c_str ( ) ;
aBoundary - > SetGroups ( aSeqGroupe ) ;
}
// -------------------------------------------------
void SMESH_CreateBoundaryCAO : : SetNewName ( )
// --------------------------------------------------
{
SMESHHOMARD : : listeBoundarys_var MyObjects = myHomardGen - > GetAllBoundarysName ( ) ;
int num = 0 ; QString aName = " " ;
while ( aName = = QString ( " " ) )
{
aName . setNum ( num + 1 ) ;
aName . insert ( 0 , QString ( " Boun_ " ) ) ;
for ( int i = 0 ; i < MyObjects - > length ( ) ; i + + )
{
if ( aName = = QString ( MyObjects [ i ] ) )
{
num + + ;
aName = " " ;
break ;
}
}
}
LEName - > setText ( aName ) ;
}
// ------------------------------------------------------------------------
void SMESH_CreateBoundaryCAO : : SetCAOFile ( )
// ------------------------------------------------------------------------
{
QString aCAOFile = SMESH_HOMARD_QT_COMMUN : : PushNomFichier ( false , QString ( " xao " ) ) ;
if ( ! ( aCAOFile . isEmpty ( ) ) ) LEFileName - > setText ( aCAOFile ) ;
}
// ------------------------------------------------------------------------
void SMESH_CreateBoundaryCAO : : setGroups ( QStringList listGroup )
// ------------------------------------------------------------------------
{
_listeGroupesBoundary = listGroup ;
}
// ------------------------------------------------------------------------
void SMESH_CreateBoundaryCAO : : SetFiltrage ( )
// ------------------------------------------------------------------------
{
if ( ! CBGroupe - > isChecked ( ) ) return ;
SMESH_CreateListGroupCAO * aDlg = new SMESH_CreateListGroupCAO
( this , true , SMESHHOMARD : : HOMARD_Gen : : _duplicate ( myHomardGen ) ,
" Case_1 " , _listeGroupesBoundary ) ;
aDlg - > show ( ) ;
}
// -------------------------------------------------------------------------------
SMESH_CreateBoundaryDi : : SMESH_CreateBoundaryDi ( SMESHGUI_HomardAdaptDlg * parent , bool modal ,
SMESHHOMARD : : HOMARD_Gen_var myHomardGen0 ,
QString caseName , QString aName )
// ---------------------------------------------------------------------------------
/* Constructs a SMESH_CreateBoundaryDi */
:
QDialog ( 0 ) , SMESH_Ui_CreateBoundaryDi ( ) ,
_parent ( parent ) , _aName ( aName ) ,
myHomardGen ( SMESHHOMARD : : HOMARD_Gen : : _duplicate ( myHomardGen0 ) )
{
MESSAGE ( " Constructeur " ) ;
setupUi ( this ) ;
setModal ( modal ) ;
InitConnect ( ) ;
if ( _aName = = QString ( " " ) ) { SetNewName ( ) ; } ;
}
// ------------------------------------------------------------------------
SMESH_CreateBoundaryDi : : ~ SMESH_CreateBoundaryDi ( )
// ------------------------------------------------------------------------
{
// no need to delete child widgets, Qt does it all for us
}
// ------------------------------------------------------------------------
void SMESH_CreateBoundaryDi : : InitConnect ( )
// ------------------------------------------------------------------------
{
connect ( PushFichier , SIGNAL ( pressed ( ) ) , this , SLOT ( SetMeshFile ( ) ) ) ;
connect ( buttonOk , SIGNAL ( pressed ( ) ) , this , SLOT ( PushOnOK ( ) ) ) ;
connect ( buttonApply , SIGNAL ( pressed ( ) ) , this , SLOT ( PushOnApply ( ) ) ) ;
connect ( buttonCancel , SIGNAL ( pressed ( ) ) , this , SLOT ( close ( ) ) ) ;
connect ( buttonHelp , SIGNAL ( pressed ( ) ) , this , SLOT ( PushOnHelp ( ) ) ) ;
connect ( CBGroupe , SIGNAL ( stateChanged ( int ) ) , this , SLOT ( SetFiltrage ( ) ) ) ;
}
// ------------------------------------------------------------------------
bool SMESH_CreateBoundaryDi : : PushOnApply ( )
// ------------------------------------------------------------------------
// Appele lorsque l'un des boutons Ok ou Apply est presse
//
{
// Verifications
QString aName = LEName - > text ( ) . trimmed ( ) ;
if ( aName = = " " ) {
QMessageBox : : critical ( 0 , QObject : : tr ( " HOM_ERROR " ) ,
QObject : : tr ( " HOM_BOUN_NAME " ) ) ;
return false ;
}
// Le maillage de la frontiere discrete
QString aMeshFile = LEFileName - > text ( ) . trimmed ( ) ;
if ( aMeshFile = = QString ( " " ) )
{
QMessageBox : : critical ( 0 , QObject : : tr ( " HOM_ERROR " ) ,
QObject : : tr ( " HOM_BOUN_MESH " ) ) ;
return false ;
}
// Le nom du maillage de la frontiere discrete
QString aMeshName = SMESH_HOMARD_QT_COMMUN : : LireNomMaillage ( aMeshFile ) ;
if ( aMeshName = = " " )
{
QMessageBox : : critical ( 0 , QObject : : tr ( " HOM_ERROR " ) ,
QObject : : tr ( " HOM_MED_FILE_2 " ) ) ;
return false ;
}
// Creation de l'objet CORBA si ce n'est pas deja fait sous le meme nom
if ( _aName ! = aName )
{
try
{
_aName = aName ;
aBoundary = myHomardGen - > CreateBoundaryDi ( CORBA : : string_dup ( _aName . toStdString ( ) . c_str ( ) ) , aMeshName . toStdString ( ) . c_str ( ) , aMeshFile . toStdString ( ) . c_str ( ) ) ;
_parent - > AddBoundaryDi ( _aName ) ;
}
catch ( SALOME : : SALOME_Exception & S_ex )
{
QMessageBox : : critical ( 0 , QObject : : tr ( " HOM_ERROR " ) ,
QObject : : tr ( CORBA : : string_dup ( S_ex . details . text ) ) ) ;
return false ;
}
}
// Les groupes
AssocieLesGroupes ( ) ;
//HOMARD_UTILS::updateObjBrowser();
return true ;
}
// ------------------------------------------------------------------------
void SMESH_CreateBoundaryDi : : PushOnOK ( )
// ------------------------------------------------------------------------
{
if ( PushOnApply ( ) ) this - > close ( ) ;
if ( _parent ) { _parent - > raise ( ) ; _parent - > activateWindow ( ) ; } ;
}
// ------------------------------------------------------------------------
void SMESH_CreateBoundaryDi : : PushOnHelp ( )
// ------------------------------------------------------------------------
{
SMESH : : ShowHelpFile ( QString ( " homard_create_boundary.html#discrete-boundary " ) ) ;
}
// ------------------------------------------------------------------------
void SMESH_CreateBoundaryDi : : AssocieLesGroupes ( )
// ------------------------------------------------------------------------
{
SMESHHOMARD : : ListGroupType_var aSeqGroupe = new SMESHHOMARD : : ListGroupType ;
aSeqGroupe - > length ( _listeGroupesBoundary . size ( ) ) ;
QStringList : : const_iterator it ;
int i = 0 ;
for ( it = _listeGroupesBoundary . constBegin ( ) ; it ! = _listeGroupesBoundary . constEnd ( ) ; it + + )
aSeqGroupe [ i + + ] = ( * it ) . toStdString ( ) . c_str ( ) ;
aBoundary - > SetGroups ( aSeqGroupe ) ;
}
// -------------------------------------------------
void SMESH_CreateBoundaryDi : : SetNewName ( )
// --------------------------------------------------
{
SMESHHOMARD : : listeBoundarys_var MyObjects = myHomardGen - > GetAllBoundarysName ( ) ;
int num = 0 ; QString aName = " " ;
while ( aName = = QString ( " " ) )
{
aName . setNum ( num + 1 ) ;
aName . insert ( 0 , QString ( " Boun_ " ) ) ;
for ( int i = 0 ; i < MyObjects - > length ( ) ; i + + )
{
if ( aName = = QString ( MyObjects [ i ] ) )
{
num + + ;
aName = " " ;
break ;
}
}
}
LEName - > setText ( aName ) ;
}
// ------------------------------------------------------------------------
void SMESH_CreateBoundaryDi : : SetMeshFile ( )
// ------------------------------------------------------------------------
{
QString aMeshFile = SMESH_HOMARD_QT_COMMUN : : PushNomFichier ( false , QString ( " med " ) ) ;
if ( ! ( aMeshFile . isEmpty ( ) ) ) LEFileName - > setText ( aMeshFile ) ;
}
// ------------------------------------------------------------------------
void SMESH_CreateBoundaryDi : : setGroups ( QStringList listGroup )
// ------------------------------------------------------------------------
{
_listeGroupesBoundary = listGroup ;
}
// ------------------------------------------------------------------------
void SMESH_CreateBoundaryDi : : SetFiltrage ( )
// // ------------------------------------------------------------------------
{
if ( ! CBGroupe - > isChecked ( ) ) return ;
SMESH_CreateListGroup * aDlg = new SMESH_CreateListGroup
( this , true , SMESHHOMARD : : HOMARD_Gen : : _duplicate ( myHomardGen ) ,
" Case_1 " , _listeGroupesBoundary ) ;
aDlg - > show ( ) ;
}
// ------------------------------------------------------------------------
SMESH_EditBoundaryAn : : SMESH_EditBoundaryAn ( SMESHGUI_HomardAdaptDlg * parent , bool modal ,
SMESHHOMARD : : HOMARD_Gen_var myHomardGen0 ,
QString caseName , QString Name ) :
// ------------------------------------------------------------------------
/* Constructs a SMESH_EditBoundaryAn
herite de SMESH_CreateBoundaryAn
*/
SMESH_CreateBoundaryAn ( parent , myHomardGen0 , caseName )
{
MESSAGE ( " Debut de SMESH_EditBoundaryAn pour " < < Name . toStdString ( ) . c_str ( ) ) ;
setWindowTitle ( QObject : : tr ( " HOM_BOUN_A_EDIT_WINDOW_TITLE " ) ) ;
_Name = Name ;
aBoundaryAn = myHomardGen - > GetBoundary ( _Name . toStdString ( ) . c_str ( ) ) ;
InitValEdit ( ) ;
}
// ------------------------------------------------------------------------
SMESH_EditBoundaryAn : : ~ SMESH_EditBoundaryAn ( )
// ------------------------------------------------------------------------
{
// no need to delete child widgets, Qt does it all for us
}
// ------------------------------------------------------------------------
void SMESH_EditBoundaryAn : : InitValEdit ( )
// ------------------------------------------------------------------------
{
LEName - > setText ( _Name ) ;
LEName - > setReadOnly ( true ) ;
_Type = aBoundaryAn - > GetType ( ) ;
MESSAGE ( " _Type : " < < _Type ) ;
InitValBoundaryAnLimit ( ) ;
InitValBoundaryAn ( ) ;
switch ( _Type )
{
case 1 : // il s agit d un cylindre
{
InitValBoundaryAnCylindre ( ) ;
SetCylinder ( ) ;
break ;
}
case 2 : // il s agit d une sphere
{
InitValBoundaryAnSphere ( ) ;
SetSphere ( ) ;
break ;
}
case 3 : // il s agit d un cone defini par un axe et un angle
{
InitValBoundaryAnConeA ( ) ;
SetConeA ( ) ;
break ;
}
case 4 : // il s agit d un cone defini par les 2 rayons
{
InitValBoundaryAnConeR ( ) ;
SetConeR ( ) ;
break ;
}
case 5 : // il s agit d un tore
{
InitValBoundaryAnTore ( ) ;
SetTore ( ) ;
break ;
}
} ;
}
// ------------------------------------------------------------------------
void SMESH_EditBoundaryAn : : InitValBoundaryAnLimit ( )
// ------------------------------------------------------------------------
{
SMESHHOMARD : : double_array_var mesCoordLimits = aBoundaryAn - > GetLimit ( ) ;
ASSERT ( mesCoordLimits - > length ( ) = = 3 ) ;
_Xincr = mesCoordLimits [ 0 ] ;
_Yincr = mesCoordLimits [ 1 ] ;
_Zincr = mesCoordLimits [ 2 ] ;
}
// ------------------------------------------------------------------------
void SMESH_EditBoundaryAn : : InitValBoundaryAnCylindre ( )
// ------------------------------------------------------------------------
{
SMESHHOMARD : : double_array_var mesCoordBoundary = aBoundaryAn - > GetCoords ( ) ;
ASSERT ( mesCoordBoundary - > length ( ) = = 7 ) ;
_BoundaryAnXcentre = mesCoordBoundary [ 0 ] ;
_BoundaryAnYcentre = mesCoordBoundary [ 1 ] ;
_BoundaryAnZcentre = mesCoordBoundary [ 2 ] ;
_BoundaryAnXaxis = mesCoordBoundary [ 3 ] ;
_BoundaryAnYaxis = mesCoordBoundary [ 4 ] ;
_BoundaryAnZaxis = mesCoordBoundary [ 5 ] ;
_BoundaryAnRayon = mesCoordBoundary [ 6 ] ;
}
// ------------------------------------------------------------------------
void SMESH_EditBoundaryAn : : InitValBoundaryAnSphere ( )
// ------------------------------------------------------------------------
{
SMESHHOMARD : : double_array_var mesCoordBoundary = aBoundaryAn - > GetCoords ( ) ;
ASSERT ( mesCoordBoundary - > length ( ) = = 4 ) ;
_BoundaryAnXcentre = mesCoordBoundary [ 0 ] ;
_BoundaryAnYcentre = mesCoordBoundary [ 1 ] ;
_BoundaryAnZcentre = mesCoordBoundary [ 2 ] ;
_BoundaryAnRayon = mesCoordBoundary [ 3 ] ;
}
// ------------------------------------------------------------------------
void SMESH_EditBoundaryAn : : InitValBoundaryAnConeA ( )
// ------------------------------------------------------------------------
{
SMESHHOMARD : : double_array_var mesCoordBoundary = aBoundaryAn - > GetCoords ( ) ;
ASSERT ( mesCoordBoundary - > length ( ) = = 7 ) ;
_BoundaryAnXaxisCone = mesCoordBoundary [ 0 ] ;
_BoundaryAnYaxisCone = mesCoordBoundary [ 1 ] ;
_BoundaryAnZaxisCone = mesCoordBoundary [ 2 ] ;
_BoundaryAngle = mesCoordBoundary [ 3 ] ;
_BoundaryAnXorigCone = mesCoordBoundary [ 4 ] ;
_BoundaryAnYorigCone = mesCoordBoundary [ 5 ] ;
_BoundaryAnZorigCone = mesCoordBoundary [ 6 ] ;
convertRayonAngle ( - 1 ) ;
}
// ------------------------------------------------------------------------
void SMESH_EditBoundaryAn : : InitValBoundaryAnConeR ( )
// ------------------------------------------------------------------------
{
SMESHHOMARD : : double_array_var mesCoordBoundary = aBoundaryAn - > GetCoords ( ) ;
ASSERT ( mesCoordBoundary - > length ( ) = = 8 ) ;
_BoundaryAnXcone1 = mesCoordBoundary [ 0 ] ;
_BoundaryAnYcone1 = mesCoordBoundary [ 1 ] ;
_BoundaryAnZcone1 = mesCoordBoundary [ 2 ] ;
_BoundaryAnRayon1 = mesCoordBoundary [ 3 ] ;
_BoundaryAnXcone2 = mesCoordBoundary [ 4 ] ;
_BoundaryAnYcone2 = mesCoordBoundary [ 5 ] ;
_BoundaryAnZcone2 = mesCoordBoundary [ 6 ] ;
_BoundaryAnRayon2 = mesCoordBoundary [ 7 ] ;
convertRayonAngle ( 1 ) ;
}
// ------------------------------------------------------------------------
void SMESH_EditBoundaryAn : : InitValBoundaryAnTore ( )
// ------------------------------------------------------------------------
{
SMESHHOMARD : : double_array_var mesCoordBoundary = aBoundaryAn - > GetCoords ( ) ;
ASSERT ( mesCoordBoundary - > length ( ) = = 8 ) ;
_BoundaryAnXcentre = mesCoordBoundary [ 0 ] ;
_BoundaryAnYcentre = mesCoordBoundary [ 1 ] ;
_BoundaryAnZcentre = mesCoordBoundary [ 2 ] ;
_BoundaryAnXaxis = mesCoordBoundary [ 3 ] ;
_BoundaryAnYaxis = mesCoordBoundary [ 4 ] ;
_BoundaryAnZaxis = mesCoordBoundary [ 5 ] ;
_BoundaryAnRayon1 = mesCoordBoundary [ 6 ] ;
_BoundaryAnRayon2 = mesCoordBoundary [ 7 ] ;
}
// ------------------------------------------------------------------------
void SMESH_EditBoundaryAn : : SetCylinder ( )
// ------------------------------------------------------------------------
{
gBCylindre - > setVisible ( 1 ) ;
gBSphere - > setVisible ( 0 ) ;
gBCone - > setVisible ( 0 ) ;
gBTore - > setVisible ( 0 ) ;
RBCylindre - > setChecked ( 1 ) ;
_Type = 1 ;
RBSphere - > setDisabled ( true ) ;
RBCone - > setDisabled ( true ) ;
RBTore - > setDisabled ( true ) ;
SpinBox_Xcent - > setValue ( _BoundaryAnXcentre ) ;
SpinBox_Ycent - > setValue ( _BoundaryAnYcentre ) ;
SpinBox_Zcent - > setValue ( _BoundaryAnZcentre ) ;
SpinBox_Xaxis - > setValue ( _BoundaryAnXaxis ) ;
SpinBox_Yaxis - > setValue ( _BoundaryAnYaxis ) ;
SpinBox_Zaxis - > setValue ( _BoundaryAnZaxis ) ;
SpinBox_Xaxis - > setSingleStep ( 0.1 ) ;
SpinBox_Xcentre - > setSingleStep ( _Xincr ) ;
SpinBox_Yaxis - > setSingleStep ( 0.1 ) ;
SpinBox_Ycentre - > setSingleStep ( _Yincr ) ;
SpinBox_Zaxis - > setSingleStep ( 0.1 ) ;
SpinBox_Zcentre - > setSingleStep ( _Zincr ) ;
// Rayon
SpinBox_Radius - > setValue ( _BoundaryAnRayon ) ;
SpinBox_Radius - > setSingleStep ( _BoundaryAnRayon / 10. ) ;
//
adjustSize ( ) ;
}
// ------------------------------------------------------------------------
void SMESH_EditBoundaryAn : : SetSphere ( )
// ------------------------------------------------------------------------
{
gBCylindre - > setVisible ( 0 ) ;
gBSphere - > setVisible ( 1 ) ;
RBSphere - > setChecked ( 1 ) ;
gBCone - > setVisible ( 0 ) ;
gBTore - > setVisible ( 0 ) ;
RBCylindre - > setDisabled ( true ) ;
RBCone - > setDisabled ( true ) ;
RBTore - > setDisabled ( true ) ;
_Type = 2 ;
SpinBox_Xcentre - > setValue ( _BoundaryAnXcentre ) ;
if ( _Xincr > 0 ) { SpinBox_Xcentre - > setSingleStep ( _Xincr ) ; }
else { SpinBox_Xcentre - > setSingleStep ( 1 ) ; }
SpinBox_Ycentre - > setValue ( _BoundaryAnYcentre ) ;
if ( _Yincr > 0 ) { SpinBox_Ycentre - > setSingleStep ( _Yincr ) ; }
else { SpinBox_Ycentre - > setSingleStep ( 1 ) ; }
SpinBox_Zcentre - > setValue ( _BoundaryAnZcentre ) ;
if ( _Zincr > 0 ) { SpinBox_Zcentre - > setSingleStep ( _Zincr ) ; }
else { SpinBox_Zcentre - > setSingleStep ( 1 ) ; }
SpinBox_Rayon - > setValue ( _BoundaryAnRayon ) ;
//
adjustSize ( ) ;
}
// ------------------------------------------------------------------------
void SMESH_EditBoundaryAn : : SetConeA ( )
// ------------------------------------------------------------------------
{
gBCylindre - > setVisible ( 0 ) ;
gBSphere - > setVisible ( 0 ) ;
gBCone - > setVisible ( 1 ) ;
RBCone - > setChecked ( 1 ) ;
gBTore - > setVisible ( 0 ) ;
RB_Def_angle - > setChecked ( 1 ) ;
RBCylindre - > setDisabled ( true ) ;
RBSphere - > setDisabled ( true ) ;
RBTore - > setDisabled ( true ) ;
_Type = 3 ;
//
TLCone_X1 - > setText ( QApplication : : translate ( " CreateBoundaryAn " , " X axis " , 0 ) ) ;
SpinBox_Cone_X1 - > setValue ( _BoundaryAnXaxisCone ) ;
TLCone_Y1 - > setText ( QApplication : : translate ( " CreateBoundaryAn " , " Y axis " , 0 ) ) ;
SpinBox_Cone_Y1 - > setValue ( _BoundaryAnYaxisCone ) ;
TLCone_Z1 - > setText ( QApplication : : translate ( " CreateBoundaryAn " , " Z axis " , 0 ) ) ;
SpinBox_Cone_Z1 - > setValue ( _BoundaryAnZaxisCone ) ;
//
TLCone_X2 - > setText ( QApplication : : translate ( " CreateBoundaryAn " , " X centre " , 0 ) ) ;
SpinBox_Cone_X2 - > setValue ( _BoundaryAnXorigCone ) ;
TLCone_Y2 - > setText ( QApplication : : translate ( " CreateBoundaryAn " , " Y centre " , 0 ) ) ;
SpinBox_Cone_Y2 - > setValue ( _BoundaryAnYorigCone ) ;
TLCone_Z2 - > setText ( QApplication : : translate ( " CreateBoundaryAn " , " Z centre " , 0 ) ) ;
SpinBox_Cone_Z2 - > setValue ( _BoundaryAnZorigCone ) ;
//
TLCone_V1 - > setText ( QApplication : : translate ( " CreateBoundaryAn " , " Angle " , 0 ) ) ;
SpinBox_Cone_V1 - > setValue ( _BoundaryAngle ) ;
SpinBox_Cone_V1 - > setSingleStep ( 1. ) ;
SpinBox_Cone_V1 - > setMaximum ( 90. ) ;
//
TLCone_V2 - > setVisible ( 0 ) ;
SpinBox_Cone_V2 - > setVisible ( 0 ) ;
//
adjustSize ( ) ;
}
// ------------------------------------------------------------------------
void SMESH_EditBoundaryAn : : SetConeR ( )
// ------------------------------------------------------------------------
{
gBCylindre - > setVisible ( 0 ) ;
gBSphere - > setVisible ( 0 ) ;
gBCone - > setVisible ( 1 ) ;
gBTore - > setVisible ( 0 ) ;
RBCone - > setChecked ( 1 ) ;
RB_Def_radius - > setChecked ( 1 ) ;
RBCylindre - > setDisabled ( true ) ;
RBSphere - > setDisabled ( true ) ;
RBTore - > setDisabled ( true ) ;
_Type = 4 ;
//
TLCone_X1 - > setText ( QApplication : : translate ( " CreateBoundaryAn " , " X centre 1 " , 0 ) ) ;
SpinBox_Cone_X1 - > setValue ( _BoundaryAnXcone1 ) ;
TLCone_Y1 - > setText ( QApplication : : translate ( " CreateBoundaryAn " , " Y centre 1 " , 0 ) ) ;
SpinBox_Cone_Y1 - > setValue ( _BoundaryAnYcone1 ) ;
TLCone_Z1 - > setText ( QApplication : : translate ( " CreateBoundaryAn " , " Z centre 1 " , 0 ) ) ;
SpinBox_Cone_Z1 - > setValue ( _BoundaryAnZcone1 ) ;
//
TLCone_V1 - > setText ( QApplication : : translate ( " CreateBoundaryAn " , " Radius 1 " , 0 ) ) ;
SpinBox_Cone_V1 - > setSingleStep ( _Rayon / 10. ) ;
SpinBox_Cone_V1 - > setMaximum ( 100000. * _DMax ) ;
SpinBox_Cone_V1 - > setValue ( _BoundaryAnRayon1 ) ;
//
TLCone_X2 - > setText ( QApplication : : translate ( " CreateBoundaryAn " , " X centre 2 " , 0 ) ) ;
SpinBox_Cone_X2 - > setValue ( _BoundaryAnXcone2 ) ;
TLCone_Y2 - > setText ( QApplication : : translate ( " CreateBoundaryAn " , " Y centre 2 " , 0 ) ) ;
SpinBox_Cone_Y2 - > setValue ( _BoundaryAnYcone2 ) ;
TLCone_Z2 - > setText ( QApplication : : translate ( " CreateBoundaryAn " , " Z centre 2 " , 0 ) ) ;
SpinBox_Cone_Z2 - > setValue ( _BoundaryAnZcone2 ) ;
//
TLCone_V2 - > setVisible ( 1 ) ;
SpinBox_Cone_V2 - > setVisible ( 1 ) ;
TLCone_V2 - > setText ( QApplication : : translate ( " CreateBoundaryAn " , " Radius 2 " , 0 ) ) ;
SpinBox_Cone_V2 - > setValue ( _BoundaryAnRayon2 ) ;
//
adjustSize ( ) ;
}
// ------------------------------------------------------------------------
void SMESH_EditBoundaryAn : : SetTore ( )
// ------------------------------------------------------------------------
{
gBCylindre - > setVisible ( 0 ) ;
gBSphere - > setVisible ( 0 ) ;
gBCone - > setVisible ( 0 ) ;
gBTore - > setVisible ( 1 ) ;
RBTore - > setChecked ( 1 ) ;
_Type = 5 ;
RBCylindre - > setDisabled ( true ) ;
RBSphere - > setDisabled ( true ) ;
RBCone - > setDisabled ( true ) ;
SpinBoxToreXcent - > setValue ( _BoundaryAnXcentre ) ;
SpinBoxToreYcent - > setValue ( _BoundaryAnYcentre ) ;
SpinBoxToreZcent - > setValue ( _BoundaryAnZcentre ) ;
SpinBoxToreXaxe - > setValue ( _BoundaryAnXaxis ) ;
SpinBoxToreYaxe - > setValue ( _BoundaryAnYaxis ) ;
SpinBoxToreZaxe - > setValue ( _BoundaryAnZaxis ) ;
SpinBoxToreXaxe - > setSingleStep ( 0.1 ) ;
SpinBoxToreXcent - > setSingleStep ( _Xincr ) ;
SpinBoxToreYaxe - > setSingleStep ( 0.1 ) ;
SpinBoxToreYcent - > setSingleStep ( _Yincr ) ;
SpinBoxToreZaxe - > setSingleStep ( 0.1 ) ;
SpinBoxToreZcent - > setSingleStep ( _Zincr ) ;
// Rayon de revolution
SpinBoxToreRRev - > setValue ( _BoundaryAnRayon1 ) ;
SpinBoxToreRRev - > setSingleStep ( _BoundaryAnRayon1 / 10. ) ;
// Rayon primaire
SpinBoxToreRPri - > setValue ( _BoundaryAnRayon2 ) ;
SpinBoxToreRPri - > setSingleStep ( _BoundaryAnRayon2 / 10. ) ;
//
adjustSize ( ) ;
}
// ---------------------------------------------------
bool SMESH_EditBoundaryAn : : CreateOrUpdateBoundaryAn ( )
//----------------------------------------------------
// Mise a jour des attributs de la BoundaryAn
{
switch ( _Type )
{
case 1 : // il s agit d un cylindre
{
aBoundaryAn - > SetCylinder ( _BoundaryAnXcentre , _BoundaryAnYcentre , _BoundaryAnZcentre , _BoundaryAnXaxis , _BoundaryAnYaxis , _BoundaryAnZaxis , _BoundaryAnRayon ) ;
break ;
}
case 2 : // il s agit d une sphere
{
aBoundaryAn - > SetSphere ( _BoundaryAnXcentre , _BoundaryAnYcentre , _BoundaryAnZcentre , _BoundaryAnRayon ) ;
break ;
}
case 3 : // il s agit d un cone defini par un axe et un angle
{
aBoundaryAn = myHomardGen - > CreateBoundaryConeA ( CORBA : : string_dup ( _Name . toStdString ( ) . c_str ( ) ) , \
_BoundaryAnXaxisCone , _BoundaryAnYaxisCone , _BoundaryAnZaxisCone , _BoundaryAngle , \
_BoundaryAnXorigCone , _BoundaryAnYorigCone , _BoundaryAnYorigCone ) ;
break ;
}
case 4 : // il s agit d un cone defini par les 2 rayons
{
aBoundaryAn = myHomardGen - > CreateBoundaryConeR ( CORBA : : string_dup ( _Name . toStdString ( ) . c_str ( ) ) , \
_BoundaryAnXcone1 , _BoundaryAnYcone1 , _BoundaryAnZcone1 , _BoundaryAnRayon1 , \
_BoundaryAnXcone2 , _BoundaryAnYcone2 , _BoundaryAnZcone2 , _BoundaryAnRayon2 ) ;
break ;
}
case 5 : // il s agit d un tore
{
aBoundaryAn - > SetTorus ( _BoundaryAnXcentre , _BoundaryAnYcentre , _BoundaryAnZcentre , _BoundaryAnXaxis , _BoundaryAnYaxis , _BoundaryAnZaxis , _BoundaryAnRayon1 , _BoundaryAnRayon2 ) ;
break ;
}
}
if ( Chgt ) myHomardGen - > InvalideBoundary ( _Name . toStdString ( ) . c_str ( ) ) ;
//HOMARD_UTILS::updateObjBrowser();
return true ;
}
// --------------------------------------------------------------------------------------
/* Constructs a SMESH_EditBoundaryCAO
herite de SMESH_CreateBoundaryCAO
*/
// --------------------------------------------------------------------------------------
SMESH_EditBoundaryCAO : : SMESH_EditBoundaryCAO ( SMESHGUI_HomardAdaptDlg * parent , bool modal ,
SMESHHOMARD : : HOMARD_Gen_var myHomardGen0 ,
QString caseName , QString Name ) :
SMESH_CreateBoundaryCAO ( parent , modal , myHomardGen0 , caseName , Name )
{
MESSAGE ( " Debut de Boundary pour " < < Name . toStdString ( ) . c_str ( ) ) ;
setWindowTitle ( QObject : : tr ( " HOM_BOUN_C_EDIT_WINDOW_TITLE " ) ) ;
try {
aBoundary = myHomardGen - > GetBoundary ( CORBA : : string_dup ( _aName . toStdString ( ) . c_str ( ) ) ) ;
InitValEdit ( ) ;
}
catch ( SALOME : : SALOME_Exception & S_ex ) {
QMessageBox : : critical ( 0 , QObject : : tr ( " HOM_ERROR " ) ,
QObject : : tr ( CORBA : : string_dup ( S_ex . details . text ) ) ) ;
return ;
}
SMESHHOMARD : : ListGroupType_var maListe = aBoundary - > GetGroups ( ) ;
for ( int i = 0 ; i < maListe - > length ( ) ; i + + )
_listeGroupesBoundary < < QString ( maListe [ i ] ) ;
}
// ------------------------------
SMESH_EditBoundaryCAO : : ~ SMESH_EditBoundaryCAO ( )
// ------------------------------
{
}
// ------------------------------
void SMESH_EditBoundaryCAO : : InitValEdit ( )
// ------------------------------
{
LEName - > setText ( _aName ) ;
LEName - > setReadOnly ( true ) ;
QString aDataFile = aBoundary - > GetDataFile ( ) ;
LEFileName - > setText ( aDataFile ) ;
LEFileName - > setReadOnly ( 1 ) ;
PushFichier - > setVisible ( 0 ) ;
//
adjustSize ( ) ;
}
// ------------------------------
bool SMESH_EditBoundaryCAO : : PushOnApply ( )
// ------------------------------
{
return true ;
}
// ------------------------------------------------------------------------
void SMESH_EditBoundaryCAO : : SetFiltrage ( )
// ------------------------------------------------------------------------
{
if ( ! CBGroupe - > isChecked ( ) ) return ;
//SMESHHOMARD::HOMARD_Cas_var monCas = myHomardGen->GetCase();
//SMESHHOMARD::ListGroupType_var _listeGroupesCas = monCas->GetGroups();
SMESH_EditListGroupCAO * aDlg = new SMESH_EditListGroupCAO
( this , true , SMESHHOMARD : : HOMARD_Gen : : _duplicate ( myHomardGen ) ,
" Case_1 " , _listeGroupesBoundary ) ;
aDlg - > show ( ) ;
}
// ------------------------------------------------------------------------------------
/* Constructs a SMESH_EditBoundaryDi
herite de SMESH_CreateBoundaryDi
*/
// ------------------------------------------------------------------------------------
SMESH_EditBoundaryDi : : SMESH_EditBoundaryDi ( SMESHGUI_HomardAdaptDlg * parent , bool modal ,
SMESHHOMARD : : HOMARD_Gen_var myHomardGen0 ,
QString caseName , QString Name ) :
SMESH_CreateBoundaryDi ( parent , modal , myHomardGen0 , caseName , Name )
{
MESSAGE ( " Debut de Boundary pour " < < Name . toStdString ( ) . c_str ( ) ) ;
setWindowTitle ( QObject : : tr ( " HOM_BOUN_D_EDIT_WINDOW_TITLE " ) ) ;
try {
aBoundary = myHomardGen - > GetBoundary ( CORBA : : string_dup ( _aName . toStdString ( ) . c_str ( ) ) ) ;
InitValEdit ( ) ;
}
catch ( SALOME : : SALOME_Exception & S_ex ) {
QMessageBox : : critical ( 0 , QObject : : tr ( " HOM_ERROR " ) ,
QObject : : tr ( CORBA : : string_dup ( S_ex . details . text ) ) ) ;
return ;
}
SMESHHOMARD : : ListGroupType_var maListe = aBoundary - > GetGroups ( ) ;
for ( int i = 0 ; i < maListe - > length ( ) ; i + + )
_listeGroupesBoundary < < QString ( maListe [ i ] ) ;
}
// ------------------------------
SMESH_EditBoundaryDi : : ~ SMESH_EditBoundaryDi ( )
// ------------------------------
{
}
// ------------------------------
void SMESH_EditBoundaryDi : : InitValEdit ( )
// ------------------------------
{
LEName - > setText ( _aName ) ;
LEName - > setReadOnly ( true ) ;
QString aDataFile = aBoundary - > GetDataFile ( ) ;
LEFileName - > setText ( aDataFile ) ;
LEFileName - > setReadOnly ( 1 ) ;
PushFichier - > setVisible ( 0 ) ;
//
adjustSize ( ) ;
}
// ------------------------------
bool SMESH_EditBoundaryDi : : PushOnApply ( )
// ------------------------------
{
return true ;
}
// ------------------------------------------------------------------------
void SMESH_EditBoundaryDi : : SetFiltrage ( )
// // ------------------------------------------------------------------------
{
if ( ! CBGroupe - > isChecked ( ) ) return ;
SMESHHOMARD : : HOMARD_Cas_var monCas = myHomardGen - > GetCase ( ) ;
SMESHHOMARD : : ListGroupType_var _listeGroupesCas = monCas - > GetGroups ( ) ;
SMESH_EditListGroup * aDlg = new SMESH_EditListGroup
( this , true , SMESHHOMARD : : HOMARD_Gen : : _duplicate ( myHomardGen ) ,
" Case_1 " , _listeGroupesBoundary ) ;
aDlg - > show ( ) ;
}