Salome HOME
Updated copyright comment
[modules/hexablock.git] / src / HEXABLOCKGUI / MyGEOMBase_Skeleton.cxx
old mode 100755 (executable)
new mode 100644 (file)
index 2d1e20a..b78bda8
@@ -1,9 +1,9 @@
-// Copyright (C) 2009-2013  CEA/DEN, EDF R&D
+// Copyright (C) 2009-2024  CEA, EDF
 //
 // 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
 // See http://www.salome-platform.org/ or email : webmaster.salome@opencascade.com
 //
 
+
 #include "MyGEOMBase_Skeleton.hxx"
-#include "GEOMBase.h"
 #include "HEXABLOCKGUI_VtkDocumentGraphicView.hxx"
 
 #include "MyDlgRef.hxx"
-#include <GeometryGUI.h>
 
 #include <SalomeApp_Application.h>
 #include <SalomeApp_DoubleSpinBox.h>
@@ -37,6 +36,9 @@
 #include <QKeyEvent>
 #include <QSpinBox>
 #include <QDoubleSpinBox>
+#include <QButtonGroup>
+
+using namespace HEXABLOCK::GUI;
 
 //=================================================================================
 // class    : MyGEOMBase_Skeleton()
 //            The dialog will by default be modeless, unless you set 'modal' to
 //            true to construct a modal dialog.
 //=================================================================================
-MyGEOMBase_Skeleton::MyGEOMBase_Skeleton( GeometryGUI* theGeometryGUI, QWidget* parent,
-                                      bool modal, Qt::WindowFlags fl )
-  : QDialog( parent, fl ),
-    MyGEOMBase_Helper( dynamic_cast<SUIT_Desktop*>( parent ) ),
-    myGeomGUI( theGeometryGUI ),
+MyGEOMBase_Skeleton::MyGEOMBase_Skeleton( QWidget* parent, Qt::WindowFlags fl )
+  : HexaBaseDialog(parent, NEW_MODE, fl),
     myRBGroup( 0 )
 {
-//   setAttribute( Qt::WA_DeleteOnClose );
-
-  setModal( modal );
 
   myMainFrame = new MyDlgRef_Skeleton( this );
   QVBoxLayout* topLayout = new QVBoxLayout( this );
   topLayout->setMargin( 0 ); topLayout->setSpacing( 0 );
   topLayout->addWidget( myMainFrame );
 
-  myMainFrame->GroupBoxName->setTitle( tr( "GEOM_RESULT_NAME_GRP" ) );
-  myMainFrame->NameLabel->setText( tr( "GEOM_RESULT_NAME_LBL" ) );
-
   myMainFrame->GroupBoxPublish->setTitle( tr( "GEOM_PUBLISH_RESULT_GRP" ) );
   myMainFrame->CheckBoxRestoreSS->setText( tr( "GEOM_RESTORE_SUB_SHAPES" ) );
   myMainFrame->CheckBoxAddPrefix->setText( tr( "GEOM_RSS_ADD_FREFIX" ) );
   myMainFrame->CheckBoxPreview->setText( tr("GEOM_PREVIEW") );
 
-  buttonCancel()->setText( tr( "GEOM_BUT_CLOSE" ) );
-  //buttonOk()->setText( tr( "GEOM_BUT_APPLY_AND_CLOSE" ) );
-  buttonApply()->setText( tr( "GEOM_BUT_APPLY" ) );
-  buttonHelp()->setText( tr( "GEOM_BUT_HELP" ) );
-
   myRBGroup = new QButtonGroup( this );
   myRBGroup->addButton( myMainFrame->RadioButton1, 0 );
   myRBGroup->addButton( myMainFrame->RadioButton2, 1 );
@@ -82,7 +70,6 @@ MyGEOMBase_Skeleton::MyGEOMBase_Skeleton( GeometryGUI* theGeometryGUI, QWidget*
   myRBGroup->addButton( myMainFrame->RadioButton5, 4 );
 
   connect( myRBGroup, SIGNAL( buttonClicked( int ) ), this, SIGNAL( constructorsClicked( int ) ) );
-
   Init();
 }
 
@@ -92,8 +79,6 @@ MyGEOMBase_Skeleton::MyGEOMBase_Skeleton( GeometryGUI* theGeometryGUI, QWidget*
 //=================================================================================
 MyGEOMBase_Skeleton::~MyGEOMBase_Skeleton()
 {
-  if ( myGeomGUI )
-    myGeomGUI->SetActiveDialogBox( 0 );
 }
 
 //=================================================================================
@@ -102,38 +87,10 @@ MyGEOMBase_Skeleton::~MyGEOMBase_Skeleton()
 //=================================================================================
 void MyGEOMBase_Skeleton::Init()
 {
-  SalomeApp_Application* app = (SalomeApp_Application*)( SUIT_Session::session()->activeApplication() );
-  if ( !myGeomGUI && app )
-    myGeomGUI = dynamic_cast<GeometryGUI*>( app->module( "Geometry" ) );
-
-  /* init variables */
-  if ( myGeomGUI )
-    myGeomGUI->SetActiveDialogBox( this );
-
-  /* signals and slots connections */
-  connect( buttonCancel(), SIGNAL( clicked() ), this, SLOT( close() ) );
-  if ( myGeomGUI ) {
-    connect( myGeomGUI, SIGNAL( SignalDeactivateActiveDialog() ), this, SLOT( DeactivateActiveDialog() ) );
-    connect( myGeomGUI, SIGNAL( SignalCloseAllDialogs() ),        this, SLOT( close() ) );
-  }
-
-  // connect help button on a private slot that displays help information
-  connect( buttonHelp(), SIGNAL( clicked() ), this, SLOT( ClickOnHelp() ) );
-
-  connect( myMainFrame->CheckBoxPreview, SIGNAL(toggled(bool)), this, SLOT(processPreview()) );
-
   /* displays Dialog */
   myMainFrame->RadioButton1->setChecked( true );
   myMainFrame->RadioButton4->hide();
   myMainFrame->RadioButton5->hide();
-
-  myMainFrame->CheckBoxRestoreSS->setChecked( false );
-  myMainFrame->CheckBoxAddPrefix->setChecked( true );
-
-  SUIT_ResourceMgr* resMgr = SUIT_Session::session()->resourceMgr();
-  bool aPrv = (resMgr == 0) ? false : resMgr->booleanValue( "Geometry", "geom_preview", false );
-
-  myMainFrame->CheckBoxPreview->setChecked( aPrv );
   myMainFrame->GroupBoxPublish->hide();
 }
 
@@ -154,120 +111,12 @@ void MyGEOMBase_Skeleton::initSpinBox( QSpinBox* spinBox,
 //=================================================================================
 void MyGEOMBase_Skeleton::initSpinBox( SalomeApp_DoubleSpinBox* spinBox,
                                      double min,  double max,
-                                     double step, const char* quantity )
+                                     double step, const char* quantity, unsigned int decimals)
 {
-  // Obtain precision from preferences
-  SUIT_ResourceMgr* resMgr = SUIT_Session::session()->resourceMgr();
-  int aPrecision = resMgr->integerValue( "Geometry", quantity, 6 );
-
-  spinBox->setPrecision( aPrecision );
-  spinBox->setDecimals( qAbs( aPrecision ) ); // it's necessary to set decimals before the range setting,
-                                    // by default Qt rounds boundaries to 2 decimals at setRange
+  spinBox->setPrecision( decimals );
+  spinBox->setDecimals( decimals );
   spinBox->setRange( min, max );
   spinBox->setSingleStep( step );
-
-  // Add a hint for the user saying how to tune precision
-  QString userPropName = QObject::tr( QString( "GEOM_PREF_%1" ).arg( quantity ).toLatin1().constData() );
-  spinBox->setProperty( "validity_tune_hint",
-                        QVariant( QObject::tr( "GEOM_PRECISION_HINT" ).arg( userPropName ) ) );
-}
-
-//=================================================================================
-// function : updateAttributes()
-// purpose  : Workaround for Translation and Rotation operations with unchecked option "Create a copy".
-//            In this case PublishInStudy isn't called, so we need to update object's attributes manually
-//=================================================================================
-void MyGEOMBase_Skeleton::updateAttributes( GEOM::GEOM_Object_ptr theObj,
-                                          const QStringList& theParameters)
-{
-  SALOMEDS::Study_var aStudy = GeometryGUI::ClientStudyToStudy(getStudy()->studyDS());
-  SALOMEDS::StudyBuilder_var aStudyBuilder = aStudy->NewBuilder();
-  SALOMEDS::SObject_var aSObject = aStudy->FindObjectID(theObj->GetStudyEntry());
-  SALOMEDS::GenericAttribute_var anAttr = aStudyBuilder->FindOrCreateAttribute(aSObject, "AttributeString");
-  SALOMEDS::AttributeString_var aStringAttrib = SALOMEDS::AttributeString::_narrow(anAttr);
-
-  std::string aValue = aStringAttrib->Value();
-  if( aValue != "" )
-    aValue += "|";
-  for( int i = 0, n = theParameters.count(); i < n; i++ ) {
-    std::string aParameter = theParameters[i].toStdString();
-    if(aStudy->IsVariable(aParameter.c_str()))
-      aValue += aParameter;
-    if(i != n-1)
-      aValue += ":";
-  }
-  aStringAttrib->SetValue(aValue.c_str());
-}
-
-
-// ========================================================================== close
-// function : close()
-// purpose  : close the dockwidget
-//=================================================================================
-void MyGEOMBase_Skeleton::close()
-{
-//     _currentObj = NULL;
-
-       //Clear VTK selection //no need to test if the graphic view exist
-    HEXABLOCKGUI::currentDocGView->clearSelection();
-
-       //Clear OCC selection
-    if (HEXABLOCKGUI::currentOccGView != NULL)
-        HEXABLOCKGUI::currentOccGView->clearSelection();
-
-       //Close the dialog box
-       if (parentWidget()) parentWidget()->close();
-}
-
-//=================================================================================
-// function : LineEditReturnPressed()
-// purpose  :
-//=================================================================================
-void MyGEOMBase_Skeleton::LineEditReturnPressed()
-{
-  if (!myEditCurrentArgument)
-    return;
-
-  /* User name of object input management                          */
-  /* If successfull the selection is changed and signal emitted... */
-  /* so SelectionIntoArgument() is automatically called.           */
-  const QString objectUserName = myEditCurrentArgument->text();
-  QWidget* thisWidget = (QWidget*)this;
-
-  SALOME_ListIO aList;
-  LightApp_SelectionMgr* aSelMgr = myGeomGUI->getApp()->selectionMgr();
-  if (aSelMgr)
-    aSelMgr->selectedObjects(aList);
-  if (GEOMBase::SelectionByNameInDialogs(thisWidget, objectUserName, aList))
-    myEditCurrentArgument->setText(objectUserName);
-}
-
-//=================================================================================
-// function : DeactivateActiveDialog()
-// purpose  :
-//=================================================================================
-void MyGEOMBase_Skeleton::DeactivateActiveDialog()
-{
-  this->setEnabled( false );
-  globalSelection(HEXABLOCKGUI::currentOccGView->getViewWindow());
-  if ( myGeomGUI ) {
-    myGeomGUI->SetActiveDialogBox( 0 );
-    disconnect( myGeomGUI->getApp()->selectionMgr(), 0, this, 0 );
-  }
-  erasePreview();
-}
-
-//=================================================================================
-// function : ActivateThisDialog()
-// purpose  :
-//=================================================================================
-void MyGEOMBase_Skeleton::ActivateThisDialog()
-{
-  /* Emit a signal to deactivate the active dialog */
-  if ( myGeomGUI ) myGeomGUI->EmitSignalDeactivateDialog();
-  this->setEnabled( true );
-  if ( myGeomGUI ) myGeomGUI->SetActiveDialogBox( (QDialog*)this );
-  return;
 }
 
 //=================================================================================
@@ -276,31 +125,10 @@ void MyGEOMBase_Skeleton::ActivateThisDialog()
 //=================================================================================
 void MyGEOMBase_Skeleton::closeEvent( QCloseEvent* e )
 {
-  if ( myGeomGUI ) {
-    disconnect( myGeomGUI->getApp()->selectionMgr(), 0, this, 0 );
-    myGeomGUI->getApp()->updateActions();
-  }
-  QDialog::closeEvent( e );
-}
+    TopoDS_Shape shape;
+    HEXABLOCKGUI::currentOccGView->displayPreview(shape);
 
-//=================================================================================
-// function : initName()
-// purpose  : initialize the Name field with a string "thePrefix_X" (Vertex_3)
-//=================================================================================
-void MyGEOMBase_Skeleton::initName( const QString& thePrefix )
-{
-  if ( !thePrefix.isNull() )
-    setPrefix( thePrefix );
-  myMainFrame->ResultName->setText( GEOMBase::GetDefaultName( getPrefix() ) );
-}
-
-//=================================================================================
-// function : getNewObjectName()
-// purpose  : returns contents of Name field
-//=================================================================================
-QString MyGEOMBase_Skeleton::getNewObjectName() const
-{
-  return myMainFrame->ResultName->text();
+    QDialog::closeEvent( e );
 }
 
 //=================================================================================
@@ -338,45 +166,13 @@ void MyGEOMBase_Skeleton::unsetConstructorId()
   QList<QAbstractButton*> btnList = myRBGroup->buttons();
   for ( int j = 0; j < 2; j++ )
   {
-    QList<QAbstractButton*>::const_iterator it = btnList.constBegin();
-    for ( ; it != btnList.constEnd(); ++it )
+    QList<QAbstractButton*>::const_iterator it = btnList.constBegin(), itEnd = btnList.constEnd();
+    for ( ; it != itEnd; ++it )
       (*it)->setCheckable( j == 1 );
   }
   myRBGroup->setExclusive( isExclusive );
 }
 
-//=================================================================================
-// function : ClickOnHelp()
-// purpose  :
-//=================================================================================
-void MyGEOMBase_Skeleton::ClickOnHelp()
-{
-  LightApp_Application* app = (LightApp_Application*)( SUIT_Session::session()->activeApplication() );
-  if ( app )
-    app->onHelpContextModule( myGeomGUI ? app->moduleName( myGeomGUI->moduleName() ) : QString(""), myHelpFileName );
-  else {
-    QString platform;
-#ifdef WIN32
-    platform = "winapplication";
-#else
-    platform = "application";
-#endif
-    SUIT_MessageBox::warning( 0, QObject::tr( "WRN_WARNING" ),
-                              QObject::tr( "EXTERNAL_BROWSER_CANNOT_SHOW_PAGE" ).
-                              arg( app->resourceMgr()->stringValue( "ExternalBrowser", platform ) ).arg( myHelpFileName ),
-                              QObject::tr( "BUT_OK" ) );
-  }
-}
-
-//=================================================================================
-//  function : setHelpFileName()
-//  purpose  : set name for help file html
-//=================================================================================
-void MyGEOMBase_Skeleton::setHelpFileName( const QString& theName )
-{
-  myHelpFileName = theName;
-}
-
 MyDlgRef_Skeleton* MyGEOMBase_Skeleton::mainFrame()
 {
   return myMainFrame;
@@ -387,43 +183,6 @@ QWidget* MyGEOMBase_Skeleton::centralWidget()
   return myMainFrame->GroupMedium;
 }
 
-QPushButton* MyGEOMBase_Skeleton::buttonCancel() const
-{
-  return myMainFrame->buttonCancel;
-}
-
-/*QPushButton* MyGEOMBase_Skeleton::buttonOk() const
-{
-  return myMainFrame->buttonOk;
-}*/
-
-QPushButton* MyGEOMBase_Skeleton::buttonApply() const
-{
-  return myMainFrame->buttonApply;
-}
-
-QPushButton* MyGEOMBase_Skeleton::buttonHelp() const
-{
-  return myMainFrame->buttonHelp;
-}
-
-//=================================================================================
-// function : keyPressEvent()
-// purpose  :
-//=================================================================================
-void MyGEOMBase_Skeleton::keyPressEvent( QKeyEvent* e )
-{
-  QDialog::keyPressEvent( e );
-  if ( e->isAccepted() )
-    return;
-
-  if ( e->key() == Qt::Key_F1 ) {
-    e->accept();
-    ClickOnHelp();
-  }
-}
-
-
 //=================================================================================
 // function : showOnlyPreviewControl()
 // purpose  : display only CheckBoxPreview check box,
@@ -435,10 +194,3 @@ void MyGEOMBase_Skeleton::showOnlyPreviewControl(){
   mainFrame()->CheckBoxAddPrefix->hide();
 }
 
-//=================================================================================
-// function : processPreview()
-// purpose  : Display preview if CheckBoxPreview is checked
-//=================================================================================
-void MyGEOMBase_Skeleton::processPreview() {
-  displayPreview(mainFrame()->CheckBoxPreview->isChecked());
-}