2013-04-01 18:25:01 +06:00
// Copyright (C) 2007-2013 CEA/DEN, EDF R&D, OPEN CASCADE
2003-07-09 20:33:44 +06:00
//
2012-08-09 13:58:02 +06:00
// Copyright (C) 2003-2007 OPEN CASCADE, EADS/CCR, LIP6, CEA/DEN,
// CEDRAT, EDF R&D, LEG, PRINCIPIA R&D, BUREAU VERITAS
2004-12-01 15:39:14 +05:00
//
2012-08-09 13:58:02 +06: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.
2004-12-01 15:39:14 +05:00
//
2012-08-09 13:58:02 +06:00
// 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.
2004-12-01 15:39:14 +05:00
//
2012-08-09 13:58:02 +06:00
// 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
2004-12-01 15:39:14 +05:00
//
2012-08-09 13:58:02 +06:00
// See http://www.salome-platform.org/ or email : webmaster.salome@opencascade.com
2003-07-09 20:33:44 +06:00
//
2012-08-09 13:58:02 +06:00
// File : GeometryGUI.cxx
// Author : Vadim SANDLER, Open CASCADE S.A.S. (vadim.sandler@opencascade.com)
# include <Standard_math.hxx> // E.A. must be included before Python.h to fix compilation on windows
# ifdef HAVE_FINITE
# undef HAVE_FINITE // VSR: avoid compilation warning on Linux : "HAVE_FINITE" redefined
# endif
# include "Python.h"
2003-05-12 21:24:23 +06:00
# include "GeometryGUI.h"
2012-08-09 13:58:02 +06:00
# include "GeometryGUI_Operations.h"
2005-06-02 13:17:09 +06:00
# include "GEOMGUI_OCCSelector.h"
# include "GEOMGUI_Selection.h"
2013-06-17 18:39:23 +06:00
# include "GEOMGUI_CreationInfoWdg.h"
2012-08-09 13:58:02 +06:00
# include "GEOM_Constants.h"
2005-09-27 12:32:15 +06:00
# include "GEOM_Displayer.h"
2009-02-13 17:16:39 +05:00
# include "GEOM_AISShape.hxx"
# include "GEOM_Actor.h"
2005-06-02 13:17:09 +06:00
2012-08-09 13:58:02 +06:00
# include <Material_ResourceMgr.h>
2013-02-12 17:35:16 +06:00
# include <Material_Model.h>
2012-08-09 13:58:02 +06:00
2009-02-13 17:16:39 +05:00
# include <SUIT_Desktop.h>
2005-06-02 13:17:09 +06:00
# include <SUIT_MessageBox.h>
# include <SUIT_ResourceMgr.h>
# include <SUIT_Session.h>
# include <SUIT_ViewManager.h>
# include <OCCViewer_ViewWindow.h>
# include <OCCViewer_ViewPort3d.h>
# include <OCCViewer_ViewModel.h>
# include <OCCViewer_ViewManager.h>
2009-02-13 17:16:39 +05:00
# include <SOCC_ViewModel.h>
# include <SOCC_ViewWindow.h>
2005-10-05 12:28:23 +06:00
# include <SVTK_ViewWindow.h>
2005-06-02 13:17:09 +06:00
# include <SVTK_RenderWindowInteractor.h>
# include <SVTK_InteractorStyle.h>
# include <SVTK_ViewModel.h>
# include <SalomeApp_Application.h>
2012-08-09 13:58:02 +06:00
# include <SalomeApp_DataObject.h>
2009-02-13 17:16:39 +05:00
# include <SalomeApp_Study.h>
2012-08-09 13:58:02 +06:00
# include <SalomeApp_Tools.h>
2009-02-13 17:16:39 +05:00
2005-11-03 13:30:14 +05:00
# include <LightApp_SelectionMgr.h>
# include <LightApp_VTKSelector.h>
2009-02-13 17:16:39 +05:00
# include <LightApp_DataObject.h>
2005-11-03 13:30:14 +05:00
# include <LightApp_Preferences.h>
2009-02-13 17:16:39 +05:00
2005-06-02 13:17:09 +06:00
# include <SALOME_LifeCycleCORBA.hxx>
2005-06-03 16:41:52 +06:00
# include <SALOME_ListIO.hxx>
2009-02-13 17:16:39 +05:00
# include <SALOME_ListIteratorOfListIO.hxx>
2004-12-01 15:39:14 +05:00
2009-02-13 17:16:39 +05:00
# include <SALOMEDSClient_ClientFactory.hxx>
# include <SALOMEDSClient_IParameters.hxx>
2005-06-02 13:17:09 +06:00
2012-08-09 13:58:02 +06:00
# include <Basics_OCCTVersion.hxx>
2009-02-13 17:16:39 +05:00
// External includes
# include <QMenu>
2012-08-09 13:58:02 +06:00
# include <QTime>
2009-02-13 17:16:39 +05:00
# include <QAction>
# include <QFileInfo>
# include <QString>
# include <QPainter>
2013-02-12 17:35:16 +06:00
# include <QSignalMapper>
2009-02-13 17:16:39 +05:00
# include <AIS_Drawer.hxx>
# include <AIS_ListOfInteractive.hxx>
# include <AIS_ListIteratorOfListOfInteractive.hxx>
2004-12-01 15:39:14 +05:00
# include <Prs3d_Drawer.hxx>
# include <Prs3d_IsoAspect.hxx>
2008-03-07 12:45:34 +05:00
# include <Aspect_TypeOfMarker.hxx>
2004-12-01 15:39:14 +05:00
# include <OSD_SharedLibrary.hxx>
2009-02-13 17:16:39 +05:00
# include <NCollection_DataMap.hxx>
2004-12-01 15:39:14 +05:00
2012-08-09 13:58:02 +06:00
# if OCC_VERSION_LARGE > 0x06040000 // Porting to OCCT6.5.1
# include <TColStd_HArray1OfByte.hxx>
# else
# include <Graphic3d_HArray1OfBytes.hxx>
# endif
2005-06-02 13:17:09 +06:00
# include <utilities.h>
2004-12-01 15:39:14 +05:00
# include <vtkCamera.h>
# include <vtkRenderer.h>
2003-05-12 21:24:23 +06:00
2013-06-17 18:39:23 +06:00
# include <Standard_Failure.hxx>
# include <Standard_ErrorHandler.hxx>
2009-02-13 17:16:39 +05:00
2013-06-17 18:39:23 +06:00
# include "GEOM_version.h"
# include "GEOMImpl_Types.hxx" // dangerous hxx (defines short-name macros) - include after all
2005-08-19 17:51:38 +06:00
2004-12-01 15:39:14 +05:00
extern " C " {
2005-06-02 13:17:09 +06:00
Standard_EXPORT CAM_Module * createModule ( ) {
return new GeometryGUI ( ) ;
2004-12-01 15:39:14 +05:00
}
2003-05-12 21:24:23 +06:00
2012-08-09 13:58:02 +06:00
Standard_EXPORT char * getModuleVersion ( ) {
return ( char * ) GEOM_VERSION_STR ;
}
}
2005-08-19 17:51:38 +06:00
2012-08-09 13:58:02 +06:00
GeometryGUI : : StudyTextureMap GeometryGUI : : myTextureMap ;
2005-08-19 17:51:38 +06:00
2006-05-06 14:44:32 +06:00
GEOM : : GEOM_Gen_var GeometryGUI : : myComponentGeom = GEOM : : GEOM_Gen : : _nil ( ) ;
2005-06-02 13:17:09 +06:00
2006-05-06 14:44:32 +06:00
GEOM : : GEOM_Gen_var GeometryGUI : : GetGeomGen ( )
{
// Bug 12290: exception in Mesh GUI on GEOMBase::GetShape() if Geometry GUI hasn't been loaded
if ( CORBA : : is_nil ( myComponentGeom ) )
InitGeomGen ( ) ;
return GeometryGUI : : myComponentGeom ;
}
2005-08-19 17:51:38 +06:00
2006-05-06 14:44:32 +06:00
bool GeometryGUI : : InitGeomGen ( )
2005-06-15 17:50:44 +06:00
{
GeometryGUI aGG ;
2012-12-13 14:40:36 +06:00
if ( CORBA : : is_nil ( myComponentGeom ) ) return false ;
2006-05-06 14:44:32 +06:00
return true ;
}
2005-06-15 17:50:44 +06:00
2005-08-18 12:15:31 +06:00
//=======================================================================
// function : ClientSObjectToObject
2008-03-07 12:45:34 +05:00
// purpose :
2005-08-18 12:15:31 +06:00
//=======================================================================
CORBA : : Object_var GeometryGUI : : ClientSObjectToObject ( _PTR ( SObject ) theSObject )
{
_PTR ( GenericAttribute ) anAttr ;
CORBA : : Object_var anObj ;
try {
std : : string aValue = theSObject - > GetIOR ( ) ;
if ( strcmp ( aValue . c_str ( ) , " " ) ! = 0 ) {
CORBA : : ORB_ptr anORB = SalomeApp_Application : : orb ( ) ;
anObj = anORB - > string_to_object ( aValue . c_str ( ) ) ;
}
} catch ( . . . ) {
INFOS ( " ClientSObjectToObject - Unknown exception was occured!!! " ) ;
}
return anObj . _retn ( ) ;
}
//=======================================================================
// function : ClientStudyToStudy
2008-03-07 12:45:34 +05:00
// purpose :
2005-08-18 12:15:31 +06:00
//=======================================================================
SALOMEDS : : Study_var GeometryGUI : : ClientStudyToStudy ( _PTR ( Study ) theStudy )
{
SALOME_NamingService * aNamingService = SalomeApp_Application : : namingService ( ) ;
CORBA : : Object_var aSMObject = aNamingService - > Resolve ( " /myStudyManager " ) ;
SALOMEDS : : StudyManager_var aStudyManager = SALOMEDS : : StudyManager : : _narrow ( aSMObject ) ;
int aStudyID = theStudy - > StudyId ( ) ;
SALOMEDS : : Study_var aDSStudy = aStudyManager - > GetStudyByID ( aStudyID ) ;
return aDSStudy . _retn ( ) ;
}
2012-12-13 14:40:36 +06:00
void GeometryGUI : : Modified ( bool theIsUpdateActions )
2004-12-01 15:39:14 +05:00
{
2012-12-13 14:40:36 +06:00
if ( SalomeApp_Application * app = dynamic_cast < SalomeApp_Application * > ( SUIT_Session : : session ( ) - > activeApplication ( ) ) ) {
if ( SalomeApp_Study * appStudy = dynamic_cast < SalomeApp_Study * > ( app - > activeStudy ( ) ) ) {
2012-08-09 13:58:02 +06:00
appStudy - > Modified ( ) ;
2012-12-13 14:40:36 +06:00
if ( theIsUpdateActions )
2012-08-09 13:58:02 +06:00
app - > updateActions ( ) ;
}
}
2009-02-13 17:16:39 +05:00
}
2012-08-09 13:58:02 +06:00
2003-05-12 21:24:23 +06:00
//=======================================================================
2004-12-01 15:39:14 +05:00
// function : GeometryGUI::GeometryGUI()
2003-05-12 21:24:23 +06:00
// purpose : Constructor
//=======================================================================
2004-12-01 15:39:14 +05:00
GeometryGUI : : GeometryGUI ( ) :
2013-02-12 17:35:16 +06:00
SalomeApp_Module ( " GEOM " )
2004-12-01 15:39:14 +05:00
{
2005-06-02 13:17:09 +06:00
if ( CORBA : : is_nil ( myComponentGeom ) )
2008-03-07 12:45:34 +05:00
{
2012-08-09 13:58:02 +06:00
Engines : : EngineComponent_var comp =
SalomeApp_Application : : lcc ( ) - > FindOrLoad_Component ( " FactoryServer " , " GEOM " ) ;
myComponentGeom = GEOM : : GEOM_Gen : : _narrow ( comp ) ;
2005-06-02 13:17:09 +06:00
}
2008-03-07 12:45:34 +05:00
2004-12-01 15:39:14 +05:00
myActiveDialogBox = 0 ;
2003-05-12 21:24:23 +06:00
2004-12-01 15:39:14 +05:00
gp_Pnt origin = gp_Pnt ( 0. , 0. , 0. ) ;
gp_Dir direction = gp_Dir ( 0. , 0. , 1. ) ;
myWorkingPlane = gp_Ax3 ( origin , direction ) ;
2005-06-02 13:17:09 +06:00
2005-09-27 12:32:15 +06:00
myDisplayer = 0 ;
2008-03-07 12:45:34 +05:00
myLocalSelectionMode = GEOM_ALLOBJECTS ;
2013-02-12 17:35:16 +06:00
2013-06-17 18:39:23 +06:00
myCreationInfoWdg = 0 ;
2013-02-12 17:35:16 +06:00
connect ( Material_ResourceMgr : : resourceMgr ( ) , SIGNAL ( changed ( ) ) , this , SLOT ( updateMaterials ( ) ) ) ;
2004-12-01 15:39:14 +05:00
}
2004-01-07 20:46:21 +05:00
2003-05-12 21:24:23 +06:00
//=======================================================================
2004-12-01 15:39:14 +05:00
// function : GeometryGUI::~GeometryGUI()
2003-05-12 21:24:23 +06:00
// purpose : Destructor
//=======================================================================
GeometryGUI : : ~ GeometryGUI ( )
{
2009-02-13 17:16:39 +05:00
while ( ! myOCCSelectors . isEmpty ( ) )
delete myOCCSelectors . takeFirst ( ) ;
while ( ! myVTKSelectors . isEmpty ( ) )
delete myVTKSelectors . takeFirst ( ) ;
2012-08-09 13:58:02 +06:00
qDeleteAll ( myGUIMap ) ;
2003-05-12 21:24:23 +06:00
}
//=======================================================================
2004-12-01 15:39:14 +05:00
// function : GeometryGUI::getLibrary()
// purpose : get or load GUI library by name [ internal ]
2003-05-12 21:24:23 +06:00
//=======================================================================
2005-06-02 13:17:09 +06:00
typedef GEOMGUI * ( * LibraryGUI ) ( GeometryGUI * ) ;
2004-12-01 15:39:14 +05:00
GEOMGUI * GeometryGUI : : getLibrary ( const QString & libraryName )
2003-05-12 21:24:23 +06:00
{
2004-12-01 15:39:14 +05:00
if ( ! myGUIMap . contains ( libraryName ) ) {
// try to load library if it is not loaded yet
2005-08-29 12:03:08 +06:00
# ifndef WNT
2012-08-09 13:58:02 +06:00
QString dirs = getenv ( " LD_LIBRARY_PATH " ) ;
QString sep = " : " ;
2005-08-29 12:03:08 +06:00
# else
2012-08-09 13:58:02 +06:00
QString dirs = getenv ( " PATH " ) ;
QString sep = " ; " ;
2005-08-29 12:03:08 +06:00
# endif
2012-08-09 13:58:02 +06:00
if ( ! dirs . isEmpty ( ) ) {
QStringList dirList = dirs . split ( sep , QString : : SkipEmptyParts ) ; // skip empty entries
QListIterator < QString > it ( dirList ) ; it . toBack ( ) ;
while ( it . hasPrevious ( ) ) {
QFileInfo fi ( Qtx : : addSlash ( it . previous ( ) ) + libraryName ) ;
if ( fi . exists ( ) ) {
OSD_SharedLibrary aSharedLibrary ( fi . fileName ( ) . toLatin1 ( ) . constData ( ) ) ;
bool res = aSharedLibrary . DlOpen ( OSD_RTLD_LAZY ) ;
if ( ! res ) {
MESSAGE ( " Can't open library : " < < aSharedLibrary . DlError ( ) ) ;
continue ; // continue search further
}
OSD_Function osdF = aSharedLibrary . DlSymb ( " GetLibGUI " ) ;
if ( osdF ! = NULL ) {
LibraryGUI func = ( GEOMGUI * ( * ) ( GeometryGUI * ) ) osdF ;
GEOMGUI * libGUI = ( * func ) ( this ) ;
if ( libGUI ) {
myGUIMap [ libraryName ] = libGUI ;
break ; // found and loaded!
}
}
}
2004-12-01 15:39:14 +05:00
}
}
}
2012-08-09 13:58:02 +06:00
return myGUIMap . contains ( libraryName ) ? myGUIMap [ libraryName ] : 0 ;
2003-05-12 21:24:23 +06:00
}
//=======================================================================
2004-12-01 15:39:14 +05:00
// function : GeometryGUI::ActiveWorkingPlane()
// purpose : Activate Working Plane View
2003-05-12 21:24:23 +06:00
//=======================================================================
2004-12-01 15:39:14 +05:00
void GeometryGUI : : ActiveWorkingPlane ( )
2003-05-12 21:24:23 +06:00
{
2004-12-01 15:39:14 +05:00
gp_Dir DZ = myWorkingPlane . Direction ( ) ;
gp_Dir DY = myWorkingPlane . YDirection ( ) ;
2003-05-12 21:24:23 +06:00
2005-06-02 13:17:09 +06:00
SUIT_ViewWindow * window = application ( ) - > desktop ( ) - > activeWindow ( ) ;
bool ViewOCC = ( window & & window - > getViewManager ( ) - > getType ( ) = = OCCViewer_Viewer : : Type ( ) ) ;
2005-10-05 12:28:23 +06:00
bool ViewVTK = ( window & & window - > getViewManager ( ) - > getType ( ) = = SVTK_Viewer : : Type ( ) ) ;
2005-06-02 13:17:09 +06:00
2012-12-13 14:40:36 +06:00
if ( ViewOCC ) {
2005-06-02 13:17:09 +06:00
OCCViewer_ViewWindow * vw = dynamic_cast < OCCViewer_ViewWindow * > ( window ) ;
if ( vw ) {
Handle ( V3d_View ) view3d = vw - > getViewPort ( ) - > getView ( ) ;
2003-05-12 21:24:23 +06:00
2005-06-02 13:17:09 +06:00
view3d - > SetProj ( DZ . X ( ) , DZ . Y ( ) , DZ . Z ( ) ) ;
view3d - > SetUp ( DY . X ( ) , DY . Y ( ) , DY . Z ( ) ) ;
2012-12-13 14:40:36 +06:00
vw - > onViewFitAll ( ) ;
2005-06-02 13:17:09 +06:00
}
2004-12-01 15:39:14 +05:00
}
2012-12-13 14:40:36 +06:00
else if ( ViewVTK ) {
2005-10-05 12:28:23 +06:00
SVTK_ViewWindow * vw = dynamic_cast < SVTK_ViewWindow * > ( window ) ;
2005-06-02 13:17:09 +06:00
if ( vw ) {
vtkCamera * camera = vw - > getRenderer ( ) - > GetActiveCamera ( ) ;
2003-05-12 21:24:23 +06:00
2005-06-02 13:17:09 +06:00
camera - > SetPosition ( DZ . X ( ) , DZ . Y ( ) , DZ . Z ( ) ) ;
camera - > SetViewUp ( DY . X ( ) , DY . Y ( ) , DY . Z ( ) ) ;
camera - > SetFocalPoint ( 0 , 0 , 0 ) ;
2004-01-07 20:46:21 +05:00
2005-06-02 13:17:09 +06:00
vw - > onFitAll ( ) ;
}
2004-06-16 21:24:55 +06:00
}
2004-12-01 15:39:14 +05:00
}
//=======================================================================
// function : GeometryGUI::SetActiveDialogBox()
// purpose : Set active dialog box
//=======================================================================
void GeometryGUI : : SetActiveDialogBox ( QDialog * aDlg )
{
myActiveDialogBox = ( QDialog * ) aDlg ;
}
//=======================================================================
// function : GeometryGUI::EmitSignalDeactivateDialog()
// purpose : Emit a signal to deactivate the active dialog Box
//=======================================================================
void GeometryGUI : : EmitSignalDeactivateDialog ( )
{
emit SignalDeactivateActiveDialog ( ) ;
}
//=======================================================================
// function : GeometryGUI::EmitSignalCloseAllDialogs()
// purpose : Emit a signal to close all non modal dialogs box
//=======================================================================
void GeometryGUI : : EmitSignalCloseAllDialogs ( )
{
emit SignalCloseAllDialogs ( ) ;
}
//=======================================================================
// function : GeometryGUI::EmitSignalDefaultStepValueChanged()
// purpose : Emit a signal to inform that default real spin box step has
// been changed
//=======================================================================
void GeometryGUI : : EmitSignalDefaultStepValueChanged ( double newVal )
{
emit SignalDefaultStepValueChanged ( newVal ) ;
}
//=======================================================================
// function : GeometryGUI::OnGUIEvent()
2005-06-02 13:17:09 +06:00
// purpose : common slot for all menu/toolbar actions
2004-12-01 15:39:14 +05:00
//=======================================================================
2005-06-02 13:17:09 +06:00
void GeometryGUI : : OnGUIEvent ( )
2004-12-01 15:39:14 +05:00
{
2005-06-02 13:17:09 +06:00
const QObject * obj = sender ( ) ;
if ( ! obj | | ! obj - > inherits ( " QAction " ) )
return ;
int id = actionId ( ( QAction * ) obj ) ;
if ( id ! = - 1 )
OnGUIEvent ( id ) ;
}
2004-12-01 15:39:14 +05:00
2005-06-02 13:17:09 +06:00
//=======================================================================
// function : GeometryGUI::OnGUIEvent()
// purpose : manage all events on GUI [static]
//=======================================================================
2013-02-12 17:35:16 +06:00
void GeometryGUI : : OnGUIEvent ( int id , const QVariant & theParam )
2005-06-02 13:17:09 +06:00
{
2006-06-01 17:32:40 +06:00
SUIT_Application * anApp = application ( ) ;
if ( ! anApp ) return ;
SUIT_Desktop * desk = anApp - > desktop ( ) ;
2005-06-17 12:05:05 +06:00
// check type of the active viewframe
2005-06-02 13:17:09 +06:00
SUIT_ViewWindow * window = desk - > activeWindow ( ) ;
bool ViewOCC = ( window & & window - > getViewManager ( ) - > getType ( ) = = OCCViewer_Viewer : : Type ( ) ) ;
2005-10-05 12:28:23 +06:00
bool ViewVTK = ( window & & window - > getViewManager ( ) - > getType ( ) = = SVTK_Viewer : : Type ( ) ) ;
2004-12-01 15:39:14 +05:00
// if current viewframe is not of OCC and not of VTK type - return immediately
2005-06-17 12:05:05 +06:00
// fix for IPAL8958 - allow some commands to execute even when NO viewer is active (rename for example)
2012-08-09 13:58:02 +06:00
QList < int > NotViewerDependentCommands ;
NotViewerDependentCommands < < GEOMOp : : OpDelete
< < GEOMOp : : OpShow
< < GEOMOp : : OpShowOnly
2012-10-08 17:16:36 +06:00
< < GEOMOp : : OpShowOnlyChildren
< < GEOMOp : : OpDiscloseChildren
< < GEOMOp : : OpConcealChildren
2012-08-09 13:58:02 +06:00
< < GEOMOp : : OpUnpublishObject
< < GEOMOp : : OpPublishObject
< < GEOMOp : : OpPointMarker ;
if ( ! ViewOCC & & ! ViewVTK & & ! NotViewerDependentCommands . contains ( id ) )
2005-06-02 13:17:09 +06:00
return ;
2004-12-01 15:39:14 +05:00
2005-06-09 18:34:59 +06:00
// fix for IPAL9103, point 2
if ( CORBA : : is_nil ( GetGeomGen ( ) ) ) {
2009-02-13 17:16:39 +05:00
SUIT_MessageBox : : critical ( desk , tr ( " GEOM_ERROR " ) , tr ( " GEOM_ERR_GET_ENGINE " ) , tr ( " GEOM_BUT_OK " ) ) ;
2005-06-09 18:34:59 +06:00
return ;
}
2012-08-09 13:58:02 +06:00
QString libName ;
// find corresponding GUI library
switch ( id ) {
case GEOMOp : : OpOriginAndVectors : // MENU BASIC - ORIGIN AND BASE VECTORS
createOriginAndBaseVectors ( ) ; // internal operation
return ;
case GEOMOp : : OpImport : // MENU FILE - IMPORT
case GEOMOp : : OpExport : // MENU FILE - EXPORT
case GEOMOp : : OpSelectVertex : // POPUP MENU - SELECT ONLY - VERTEX
case GEOMOp : : OpSelectEdge : // POPUP MENU - SELECT ONLY - EDGE
case GEOMOp : : OpSelectWire : // POPUP MENU - SELECT ONLY - WIRE
case GEOMOp : : OpSelectFace : // POPUP MENU - SELECT ONLY - FACE
case GEOMOp : : OpSelectShell : // POPUP MENU - SELECT ONLY - SHELL
case GEOMOp : : OpSelectSolid : // POPUP MENU - SELECT ONLY - SOLID
case GEOMOp : : OpSelectCompound : // POPUP MENU - SELECT ONLY - COMPOUND
case GEOMOp : : OpSelectAll : // POPUP MENU - SELECT ONLY - SELECT ALL
case GEOMOp : : OpDelete : // MENU EDIT - DELETE
case GEOMOp : : OpCheckGeom : // MENU TOOLS - CHECK GEOMETRY
2013-02-12 17:35:16 +06:00
case GEOMOp : : OpMaterialsLibrary : // MENU TOOLS - MATERIALS LIBRARY
2012-08-09 13:58:02 +06:00
case GEOMOp : : OpDeflection : // POPUP MENU - DEFLECTION COEFFICIENT
case GEOMOp : : OpColor : // POPUP MENU - COLOR
case GEOMOp : : OpSetTexture : // POPUP MENU - SETTEXTURE
case GEOMOp : : OpTransparency : // POPUP MENU - TRANSPARENCY
case GEOMOp : : OpIncrTransparency : // SHORTCUT - INCREASE TRANSPARENCY
case GEOMOp : : OpDecrTransparency : // SHORTCUT - DECREASE TRANSPARENCY
case GEOMOp : : OpIsos : // POPUP MENU - ISOS
case GEOMOp : : OpIncrNbIsos : // SHORTCUT - INCREASE NB ISOS
case GEOMOp : : OpDecrNbIsos : // SHORTCUT - DECREASE NB ISOS
case GEOMOp : : OpAutoColor : // POPUP MENU - AUTO COLOR
case GEOMOp : : OpNoAutoColor : // POPUP MENU - DISABLE AUTO COLOR
2012-10-08 17:16:36 +06:00
case GEOMOp : : OpDiscloseChildren : // POPUP MENU - DISCLOSE CHILD ITEMS
case GEOMOp : : OpConcealChildren : // POPUP MENU - CONCEAL CHILD ITEMS
2012-08-09 13:58:02 +06:00
case GEOMOp : : OpUnpublishObject : // POPUP MENU - UNPUBLISH
case GEOMOp : : OpPublishObject : // ROOT GEOM OBJECT - POPUP MENU - PUBLISH
case GEOMOp : : OpPointMarker : // POPUP MENU - POINT MARKER
case GEOMOp : : OpMaterialProperties : // POPUP MENU - MATERIAL PROPERTIES
2013-02-12 17:35:16 +06:00
case GEOMOp : : OpPredefMaterial : // POPUP MENU - <SOME MATERIAL>
case GEOMOp : : OpPredefMaterCustom : // POPUP MENU - MATERIAL PROPERTIES - CUSTOM...
2012-08-09 13:58:02 +06:00
case GEOMOp : : OpEdgeWidth : // POPUP MENU - LINE WIDTH - EDGE WIDTH
case GEOMOp : : OpIsosWidth : // POPUP MENU - LINE WIDTH - ISOS WIDTH
case GEOMOp : : OpBringToFront : // POPUP MENU - BRING TO FRONT
case GEOMOp : : OpClsBringToFront : //
libName = " GEOMToolsGUI " ;
break ;
case GEOMOp : : OpDMWireframe : // MENU VIEW - WIREFRAME
case GEOMOp : : OpDMShading : // MENU VIEW - SHADING
case GEOMOp : : OpDMShadingWithEdges : // MENU VIEW - SHADING
case GEOMOp : : OpShowAll : // MENU VIEW - SHOW ALL
case GEOMOp : : OpShowOnly : // MENU VIEW - DISPLAY ONLY
2012-10-08 17:16:36 +06:00
case GEOMOp : : OpShowOnlyChildren : // MENU VIEW - SHOW ONLY CHILDREN
2012-08-09 13:58:02 +06:00
case GEOMOp : : OpHideAll : // MENU VIEW - ERASE ALL
case GEOMOp : : OpHide : // MENU VIEW - ERASE
case GEOMOp : : OpShow : // MENU VIEW - DISPLAY
case GEOMOp : : OpSwitchVectors : // MENU VIEW - VECTOR MODE
case GEOMOp : : OpWireframe : // POPUP MENU - WIREFRAME
case GEOMOp : : OpShading : // POPUP MENU - SHADING
case GEOMOp : : OpShadingWithEdges : // POPUP MENU - SHADING WITH EDGES
case GEOMOp : : OpTexture : // POPUP MENU - TEXTURE
case GEOMOp : : OpVectors : // POPUP MENU - VECTORS
libName = " DisplayGUI " ;
break ;
case GEOMOp : : OpPoint : // MENU BASIC - POINT
case GEOMOp : : OpLine : // MENU BASIC - LINE
case GEOMOp : : OpCircle : // MENU BASIC - CIRCLE
case GEOMOp : : OpEllipse : // MENU BASIC - ELLIPSE
case GEOMOp : : OpArc : // MENU BASIC - ARC
case GEOMOp : : OpVector : // MENU BASIC - VECTOR
case GEOMOp : : OpPlane : // MENU BASIC - PLANE
case GEOMOp : : OpCurve : // MENU BASIC - CURVE
case GEOMOp : : OpLCS : // MENU BASIC - LOCAL COORDINATE SYSTEM
libName = " BasicGUI " ;
break ;
case GEOMOp : : OpBox : // MENU PRIMITIVE - BOX
case GEOMOp : : OpCylinder : // MENU PRIMITIVE - CYLINDER
case GEOMOp : : OpSphere : // MENU PRIMITIVE - SPHERE
case GEOMOp : : OpTorus : // MENU PRIMITIVE - TORUS
case GEOMOp : : OpCone : // MENU PRIMITIVE - CONE
case GEOMOp : : OpRectangle : // MENU PRIMITIVE - FACE
case GEOMOp : : OpDisk : // MENU PRIMITIVE - DISK
libName = " PrimitiveGUI " ;
break ;
case GEOMOp : : OpPrism : // MENU GENERATION - PRISM
case GEOMOp : : OpRevolution : // MENU GENERATION - REVOLUTION
case GEOMOp : : OpFilling : // MENU GENERATION - FILLING
case GEOMOp : : OpPipe : // MENU GENERATION - PIPE
2012-12-13 14:40:36 +06:00
case GEOMOp : : OpPipePath : // MENU GENERATION - RESTORE PATH
2012-08-09 13:58:02 +06:00
libName = " GenerationGUI " ;
break ;
case GEOMOp : : Op2dSketcher : // MENU ENTITY - SKETCHER
case GEOMOp : : Op3dSketcher : // MENU ENTITY - 3D SKETCHER
case GEOMOp : : OpExplode : // MENU ENTITY - EXPLODE
# ifdef WITH_OPENCV
case GEOMOp : : OpFeatureDetect : // MENU ENTITY - FEATURE DETECTION
2005-08-29 12:03:08 +06:00
# endif
2012-08-09 13:58:02 +06:00
case GEOMOp : : OpPictureImport : // MENU ENTITY - IMPORT PICTURE IN VIEWER
libName = " EntityGUI " ;
break ;
case GEOMOp : : OpEdge : // MENU BUILD - EDGE
case GEOMOp : : OpWire : // MENU BUILD - WIRE
case GEOMOp : : OpFace : // MENU BUILD - FACE
case GEOMOp : : OpShell : // MENU BUILD - SHELL
case GEOMOp : : OpSolid : // MENU BUILD - SOLID
case GEOMOp : : OpCompound : // MENU BUILD - COMPUND
libName = " BuildGUI " ;
break ;
case GEOMOp : : OpFuse : // MENU BOOLEAN - FUSE
case GEOMOp : : OpCommon : // MENU BOOLEAN - COMMON
case GEOMOp : : OpCut : // MENU BOOLEAN - CUT
case GEOMOp : : OpSection : // MENU BOOLEAN - SECTION
libName = " BooleanGUI " ;
break ;
case GEOMOp : : OpTranslate : // MENU TRANSFORMATION - TRANSLATION
case GEOMOp : : OpRotate : // MENU TRANSFORMATION - ROTATION
case GEOMOp : : OpChangeLoc : // MENU TRANSFORMATION - LOCATION
case GEOMOp : : OpMirror : // MENU TRANSFORMATION - MIRROR
case GEOMOp : : OpScale : // MENU TRANSFORMATION - SCALE
case GEOMOp : : OpOffset : // MENU TRANSFORMATION - OFFSET
case GEOMOp : : OpProjection : // MENU TRANSFORMATION - PROJECTION
case GEOMOp : : OpMultiTranslate : // MENU TRANSFORMATION - MULTI-TRANSLATION
case GEOMOp : : OpMultiRotate : // MENU TRANSFORMATION - MULTI-ROTATION
case GEOMOp : : OpReimport : // CONTEXT(POPUP) MENU - RELOAD_IMPORTED
libName = " TransformationGUI " ;
break ;
case GEOMOp : : OpPartition : // MENU OPERATION - PARTITION
case GEOMOp : : OpArchimede : // MENU OPERATION - ARCHIMEDE
case GEOMOp : : OpFillet3d : // MENU OPERATION - FILLET
case GEOMOp : : OpChamfer : // MENU OPERATION - CHAMFER
case GEOMOp : : OpClipping : // MENU OPERATION - CLIPPING RANGE
case GEOMOp : : OpShapesOnShape : // MENU OPERATION - GET SHAPES ON SHAPE
case GEOMOp : : OpFillet2d : // MENU OPERATION - FILLET 2D
case GEOMOp : : OpFillet1d : // MENU OPERATION - FILLET 1D
case GEOMOp : : OpSharedShapes : // MENU OPERATION - GET SHARED SHAPES
case GEOMOp : : OpExtrudedBoss : // MENU OPERATION - EXTRUDED BOSS
case GEOMOp : : OpExtrudedCut : // MENU OPERATION - EXTRUDED CUT
libName = " OperationGUI " ;
break ;
case GEOMOp : : OpSewing : // MENU REPAIR - SEWING
case GEOMOp : : OpSuppressFaces : // MENU REPAIR - SUPPRESS FACES
case GEOMOp : : OpSuppressHoles : // MENU REPAIR - SUPPRESS HOLE
case GEOMOp : : OpShapeProcess : // MENU REPAIR - SHAPE PROCESSING
case GEOMOp : : OpCloseContour : // MENU REPAIR - CLOSE CONTOUR
case GEOMOp : : OpRemoveIntWires : // MENU REPAIR - REMOVE INTERNAL WIRES
case GEOMOp : : OpAddPointOnEdge : // MENU REPAIR - ADD POINT ON EDGE
case GEOMOp : : OpFreeBoundaries : // MENU MEASURE - FREE BOUNDARIES
case GEOMOp : : OpFreeFaces : // MENU MEASURE - FREE FACES
case GEOMOp : : OpOrientation : // MENU REPAIR - CHANGE ORIENTATION
case GEOMOp : : OpGlueFaces : // MENU REPAIR - GLUE FACES
case GEOMOp : : OpGlueEdges : // MENU REPAIR - GLUE EDGES
case GEOMOp : : OpLimitTolerance : // MENU REPAIR - LIMIT TOLERANCE
2013-06-14 18:20:21 +06:00
case GEOMOp : : OpRemoveWebs : // MENU REPAIR - REMOVE INTERNAL FACES
2012-08-09 13:58:02 +06:00
case GEOMOp : : OpRemoveExtraEdges : // MENU REPAIR - REMOVE EXTRA EDGES
case GEOMOp : : OpFuseEdges : // MENU REPAIR - FUSE COLLINEAR EDGES
2013-05-24 14:52:30 +06:00
case GEOMOp : : OpUnionFaces : // MENU REPAIR - UNION FACES
2012-08-09 13:58:02 +06:00
libName = " RepairGUI " ;
break ;
case GEOMOp : : OpProperties : // MENU MEASURE - PROPERTIES
case GEOMOp : : OpCenterMass : // MENU MEASURE - CDG
case GEOMOp : : OpInertia : // MENU MEASURE - INERTIA
case GEOMOp : : OpNormale : // MENU MEASURE - NORMALE
case GEOMOp : : OpBoundingBox : // MENU MEASURE - BOUNDING BOX
case GEOMOp : : OpMinDistance : // MENU MEASURE - MIN DISTANCE
case GEOMOp : : OpAngle : // MENU MEASURE - ANGLE
case GEOMOp : : OpTolerance : // MENU MEASURE - TOLERANCE
case GEOMOp : : OpWhatIs : // MENU MEASURE - WHATIS
case GEOMOp : : OpCheckShape : // MENU MEASURE - CHECK
case GEOMOp : : OpCheckCompound : // MENU MEASURE - CHECK COMPOUND OF BLOCKS
2012-10-08 17:16:36 +06:00
case GEOMOp : : OpGetNonBlocks : // MENU MEASURE - Get NON BLOCKS
2012-08-09 13:58:02 +06:00
case GEOMOp : : OpPointCoordinates : // MENU MEASURE - POINT COORDINATES
case GEOMOp : : OpCheckSelfInters : // MENU MEASURE - CHECK SELF INTERSECTIONS
libName = " MeasureGUI " ;
break ;
case GEOMOp : : OpGroupCreate : // MENU GROUP - CREATE
case GEOMOp : : OpGroupCreatePopup : // POPUP MENU - CREATE GROUP
case GEOMOp : : OpGroupEdit : // MENU GROUP - EDIT
2012-10-08 17:16:36 +06:00
case GEOMOp : : OpGroupUnion : // MENU GROUP - UNION
case GEOMOp : : OpGroupIntersect : // MENU GROUP - INTERSECT
case GEOMOp : : OpGroupCut : // MENU GROUP - CUT
2012-08-09 13:58:02 +06:00
libName = " GroupGUI " ;
break ;
case GEOMOp : : OpHexaSolid : // MENU BLOCKS - HEXAHEDRAL SOLID
case GEOMOp : : OpMultiTransform : // MENU BLOCKS - MULTI-TRANSFORMATION
case GEOMOp : : OpQuadFace : // MENU BLOCKS - QUADRANGLE FACE
case GEOMOp : : OpPropagate : // MENU BLOCKS - PROPAGATE
case GEOMOp : : OpExplodeBlock : // MENU BLOCKS - EXPLODE ON BLOCKS
libName = " BlocksGUI " ;
break ;
case GEOMOp : : OpAdvancedNoOp : // NO OPERATION (advanced operations base)
case GEOMOp : : OpPipeTShape : // MENU NEW ENTITY - ADVANCED - PIPE TSHAPE
// case GEOMOp::OpPipeTShapeGroups: // MENU NEW ENTITY - ADVANCED - PIPE TSHAPE GROUPS
case GEOMOp : : OpDividedDisk : // MENU NEW ENTITY - ADVANCED - DIVIDEDDISK
case GEOMOp : : OpDividedCylinder : // MENU NEW ENTITY - ADVANCED - DIVIDEDCYLINDER
2013-06-10 14:28:09 +06:00
case GEOMOp : : OpSmoothingSurface : // MENU NEW ENTITY - ADVANCED - SMOOTHINGSURFACE
2012-08-09 13:58:02 +06:00
//@@ insert new functions before this line @@ do not remove this line @@ do not remove this line @@ do not remove this line @@ do not remove this line @@//
libName = " AdvancedGUI " ;
break ;
default :
break ;
2005-06-02 13:17:09 +06:00
}
2012-08-09 13:58:02 +06:00
GEOMGUI * library = 0 ;
if ( ! libName . isEmpty ( ) ) {
2005-08-29 12:03:08 +06:00
# ifndef WNT
2012-08-09 13:58:02 +06:00
libName = QString ( " lib " ) + libName + " .so " ;
2005-08-29 12:03:08 +06:00
# else
2012-08-09 13:58:02 +06:00
libName = libName + " .dll " ;
2005-08-29 12:03:08 +06:00
# endif
2012-08-09 13:58:02 +06:00
library = getLibrary ( libName ) ;
2005-06-02 13:17:09 +06:00
}
// call method of corresponding GUI library
2012-08-09 13:58:02 +06:00
if ( library ) {
2013-02-12 17:35:16 +06:00
if ( ! theParam . isValid ( ) )
library - > OnGUIEvent ( id , desk ) ;
else
library - > OnGUIEvent ( id , desk , theParam ) ;
2012-08-09 13:58:02 +06:00
}
2008-03-07 12:45:34 +05:00
else
2009-02-13 17:16:39 +05:00
SUIT_MessageBox : : critical ( desk , tr ( " GEOM_ERROR " ) , tr ( " GEOM_ERR_LIB_NOT_FOUND " ) , tr ( " GEOM_BUT_OK " ) ) ;
2013-06-17 18:39:23 +06:00
updateCreationInfo ( ) ;
2003-05-12 21:24:23 +06:00
}
//=================================================================================
2004-12-01 15:39:14 +05:00
// function : GeometryGUI::OnKeyPress()
// purpose : Called when any key is pressed by user [static]
2003-05-12 21:24:23 +06:00
//=================================================================================
2012-08-09 13:58:02 +06:00
void GeometryGUI : : OnKeyPress ( SUIT_ViewWindow * w , QKeyEvent * e )
2003-05-12 21:24:23 +06:00
{
2012-08-09 13:58:02 +06:00
if ( ! application ( ) )
return ;
foreach ( GEOMGUI * lib , myGUIMap )
lib - > OnKeyPress ( e , application ( ) - > desktop ( ) , w ) ;
2003-05-12 21:24:23 +06:00
}
//=================================================================================
2004-12-01 15:39:14 +05:00
// function : GeometryGUI::OnMouseMove()
// purpose : Manages mouse move events [static]
2003-05-12 21:24:23 +06:00
//=================================================================================
2012-08-09 13:58:02 +06:00
void GeometryGUI : : OnMouseMove ( SUIT_ViewWindow * w , QMouseEvent * e )
2008-03-07 12:45:34 +05:00
{
2012-08-09 13:58:02 +06:00
if ( ! application ( ) )
return ;
foreach ( GEOMGUI * lib , myGUIMap )
lib - > OnMouseMove ( e , application ( ) - > desktop ( ) , w ) ;
2003-05-12 21:24:23 +06:00
}
//=================================================================================
2012-08-09 13:58:02 +06:00
// function : GeometryGUI::OnMouseRelease()
// purpose : Manages mouse release events [static]
2003-05-12 21:24:23 +06:00
//=================================================================================
2012-08-09 13:58:02 +06:00
void GeometryGUI : : OnMouseRelease ( SUIT_ViewWindow * w , QMouseEvent * e )
2004-06-16 21:24:55 +06:00
{
2012-08-09 13:58:02 +06:00
if ( ! application ( ) )
return ;
foreach ( GEOMGUI * lib , myGUIMap )
lib - > OnMouseRelease ( e , application ( ) - > desktop ( ) , w ) ;
2004-06-16 21:24:55 +06:00
}
2004-01-07 20:46:21 +05:00
//=================================================================================
2012-08-09 13:58:02 +06:00
// function : GeometryGUI::OnMousePress()
// purpose : Manage mouse press events [static]
2004-01-07 20:46:21 +05:00
//=================================================================================
2012-08-09 13:58:02 +06:00
void GeometryGUI : : OnMousePress ( SUIT_ViewWindow * w , QMouseEvent * e )
2003-05-12 21:24:23 +06:00
{
2012-08-09 13:58:02 +06:00
if ( ! application ( ) )
return ;
foreach ( GEOMGUI * lib , myGUIMap )
lib - > OnMousePress ( e , application ( ) - > desktop ( ) , w ) ;
2003-05-12 21:24:23 +06:00
}
2005-06-02 13:17:09 +06:00
//=======================================================================
// function : createGeomAction
2008-03-07 12:45:34 +05:00
// purpose :
2005-06-02 13:17:09 +06:00
//=======================================================================
2012-08-09 13:58:02 +06:00
void GeometryGUI : : createGeomAction ( const int id , const QString & label , const QString & icolabel ,
const int accel , const bool toggle , const QString & shortcutAction )
2005-06-02 13:17:09 +06:00
{
SUIT_ResourceMgr * resMgr = SUIT_Session : : session ( ) - > resourceMgr ( ) ;
2012-08-09 13:58:02 +06:00
QPixmap icon = icolabel . isEmpty ( ) ? resMgr - > loadPixmap ( " GEOM " , tr ( ( QString ( " ICO_ " ) + label ) . toLatin1 ( ) . constData ( ) ) , false )
: resMgr - > loadPixmap ( " GEOM " , tr ( icolabel . toLatin1 ( ) . constData ( ) ) ) ;
createAction ( id ,
tr ( QString ( " TOP_%1 " ) . arg ( label ) . toLatin1 ( ) . constData ( ) ) ,
icon ,
tr ( QString ( " MEN_%1 " ) . arg ( label ) . toLatin1 ( ) . constData ( ) ) ,
tr ( QString ( " STB_%1 " ) . arg ( label ) . toLatin1 ( ) . constData ( ) ) ,
accel ,
application ( ) - > desktop ( ) ,
toggle ,
this , SLOT ( OnGUIEvent ( ) ) ,
shortcutAction ) ;
2005-06-02 13:17:09 +06:00
}
2012-08-09 13:58:02 +06:00
//=======================================================================
// function : createOriginAndBaseVectors
// purpose :
//=======================================================================
void GeometryGUI : : createOriginAndBaseVectors ( )
{
SalomeApp_Study * appStudy = dynamic_cast < SalomeApp_Study * > ( application ( ) - > activeStudy ( ) ) ;
2012-12-13 14:40:36 +06:00
if ( appStudy ) {
2012-08-09 13:58:02 +06:00
_PTR ( Study ) studyDS = appStudy - > studyDS ( ) ;
2012-12-13 14:40:36 +06:00
if ( studyDS & & ! CORBA : : is_nil ( GetGeomGen ( ) ) ) {
2012-08-09 13:58:02 +06:00
GEOM : : GEOM_IBasicOperations_var aBasicOperations = GetGeomGen ( ) - > GetIBasicOperations ( studyDS - > StudyId ( ) ) ;
2012-12-13 14:40:36 +06:00
if ( ! aBasicOperations - > _is_nil ( ) ) {
2012-08-09 13:58:02 +06:00
SUIT_ResourceMgr * aResourceMgr = SUIT_Session : : session ( ) - > resourceMgr ( ) ;
double aLength = aResourceMgr - > doubleValue ( " Geometry " , " base_vectors_length " , 1.0 ) ;
GEOM : : GEOM_Object_var anOrigin = aBasicOperations - > MakePointXYZ ( 0.0 , 0.0 , 0.0 ) ;
GEOM : : GEOM_Object_var anOX = aBasicOperations - > MakeVectorDXDYDZ ( aLength , 0.0 , 0.0 ) ;
GEOM : : GEOM_Object_var anOY = aBasicOperations - > MakeVectorDXDYDZ ( 0.0 , aLength , 0.0 ) ;
GEOM : : GEOM_Object_var anOZ = aBasicOperations - > MakeVectorDXDYDZ ( 0.0 , 0.0 , aLength ) ;
SALOMEDS : : Study_var aDSStudy = ClientStudyToStudy ( studyDS ) ;
GetGeomGen ( ) - > PublishInStudy ( aDSStudy , SALOMEDS : : SObject : : _nil ( ) , anOrigin , " O " ) ;
GetGeomGen ( ) - > PublishInStudy ( aDSStudy , SALOMEDS : : SObject : : _nil ( ) , anOX , " OX " ) ;
GetGeomGen ( ) - > PublishInStudy ( aDSStudy , SALOMEDS : : SObject : : _nil ( ) , anOY , " OY " ) ;
GetGeomGen ( ) - > PublishInStudy ( aDSStudy , SALOMEDS : : SObject : : _nil ( ) , anOZ , " OZ " ) ;
2013-06-14 17:46:28 +06:00
getApp ( ) - > updateObjectBrowser ( true ) ;
2012-08-09 13:58:02 +06:00
}
}
}
}
2003-05-12 21:24:23 +06:00
2004-12-01 15:39:14 +05:00
//=======================================================================
2006-05-10 20:27:12 +06:00
// function : GeometryGUI::initialize()
// purpose : Called when GEOM module is created
2004-12-01 15:39:14 +05:00
//=======================================================================
2005-06-02 13:17:09 +06:00
void GeometryGUI : : initialize ( CAM_Application * app )
2004-12-01 15:39:14 +05:00
{
2005-06-02 13:17:09 +06:00
SalomeApp_Module : : initialize ( app ) ;
// ----- create actions --------------
2012-08-09 13:58:02 +06:00
createGeomAction ( GEOMOp : : OpImport , " IMPORT " , " " , Qt : : ControlModifier + Qt : : Key_I ) ;
createGeomAction ( GEOMOp : : OpExport , " EXPORT " , " " , Qt : : ControlModifier + Qt : : Key_E ) ;
createGeomAction ( GEOMOp : : OpDelete , " DELETE " , " " , Qt : : Key_Delete ) ;
createGeomAction ( GEOMOp : : OpPoint , " POINT " ) ;
createGeomAction ( GEOMOp : : OpLine , " LINE " ) ;
createGeomAction ( GEOMOp : : OpCircle , " CIRCLE " ) ;
createGeomAction ( GEOMOp : : OpEllipse , " ELLIPSE " ) ;
createGeomAction ( GEOMOp : : OpArc , " ARC " ) ;
createGeomAction ( GEOMOp : : OpCurve , " CURVE " ) ;
createGeomAction ( GEOMOp : : OpVector , " VECTOR " ) ;
createGeomAction ( GEOMOp : : OpPlane , " PLANE " ) ;
createGeomAction ( GEOMOp : : OpLCS , " LOCAL_CS " ) ;
createGeomAction ( GEOMOp : : OpOriginAndVectors , " ORIGIN_AND_VECTORS " ) ;
createGeomAction ( GEOMOp : : OpBox , " BOX " ) ;
createGeomAction ( GEOMOp : : OpCylinder , " CYLINDER " ) ;
createGeomAction ( GEOMOp : : OpSphere , " SPHERE " ) ;
createGeomAction ( GEOMOp : : OpTorus , " TORUS " ) ;
createGeomAction ( GEOMOp : : OpCone , " CONE " ) ;
createGeomAction ( GEOMOp : : OpRectangle , " RECTANGLE " ) ;
createGeomAction ( GEOMOp : : OpDisk , " DISK " ) ;
createGeomAction ( GEOMOp : : OpPrism , " EXTRUSION " ) ;
createGeomAction ( GEOMOp : : OpRevolution , " REVOLUTION " ) ;
createGeomAction ( GEOMOp : : OpFilling , " FILLING " ) ;
createGeomAction ( GEOMOp : : OpPipe , " PIPE " ) ;
2012-12-13 14:40:36 +06:00
createGeomAction ( GEOMOp : : OpPipePath , " PIPE_PATH " ) ;
2012-08-09 13:58:02 +06:00
createGeomAction ( GEOMOp : : OpGroupCreate , " GROUP_CREATE " ) ;
createGeomAction ( GEOMOp : : OpGroupEdit , " GROUP_EDIT " ) ;
2012-10-08 17:16:36 +06:00
createGeomAction ( GEOMOp : : OpGroupUnion , " GROUP_UNION " ) ;
createGeomAction ( GEOMOp : : OpGroupIntersect , " GROUP_INTERSECT " ) ;
createGeomAction ( GEOMOp : : OpGroupCut , " GROUP_CUT " ) ;
2012-08-09 13:58:02 +06:00
createGeomAction ( GEOMOp : : OpReimport , " RELOAD_IMPORTED " ) ;
createGeomAction ( GEOMOp : : OpQuadFace , " Q_FACE " ) ;
createGeomAction ( GEOMOp : : OpHexaSolid , " HEX_SOLID " ) ;
createGeomAction ( GEOMOp : : Op2dSketcher , " SKETCH " ) ;
createGeomAction ( GEOMOp : : Op3dSketcher , " 3DSKETCH " ) ;
createGeomAction ( GEOMOp : : OpExplode , " EXPLODE " ) ;
# ifdef WITH_OPENCV
createGeomAction ( GEOMOp : : OpFeatureDetect , " FEATURE_DETECTION " ) ;
# endif
createGeomAction ( GEOMOp : : OpPictureImport , " PICTURE_IMPORT " ) ;
createGeomAction ( GEOMOp : : OpEdge , " EDGE " ) ;
createGeomAction ( GEOMOp : : OpWire , " WIRE " ) ;
createGeomAction ( GEOMOp : : OpFace , " FACE " ) ;
createGeomAction ( GEOMOp : : OpShell , " SHELL " ) ;
createGeomAction ( GEOMOp : : OpSolid , " SOLID " ) ;
createGeomAction ( GEOMOp : : OpCompound , " COMPOUND " ) ;
createGeomAction ( GEOMOp : : OpFuse , " FUSE " ) ;
createGeomAction ( GEOMOp : : OpCommon , " COMMON " ) ;
createGeomAction ( GEOMOp : : OpCut , " CUT " ) ;
createGeomAction ( GEOMOp : : OpSection , " SECTION " ) ;
createGeomAction ( GEOMOp : : OpTranslate , " TRANSLATION " ) ;
createGeomAction ( GEOMOp : : OpRotate , " ROTATION " ) ;
createGeomAction ( GEOMOp : : OpChangeLoc , " MODIFY_LOCATION " ) ;
createGeomAction ( GEOMOp : : OpMirror , " MIRROR " ) ;
createGeomAction ( GEOMOp : : OpScale , " SCALE " ) ;
createGeomAction ( GEOMOp : : OpOffset , " OFFSET " ) ;
createGeomAction ( GEOMOp : : OpProjection , " PROJECTION " ) ;
createGeomAction ( GEOMOp : : OpMultiTranslate , " MUL_TRANSLATION " ) ;
createGeomAction ( GEOMOp : : OpMultiRotate , " MUL_ROTATION " ) ;
createGeomAction ( GEOMOp : : OpPartition , " PARTITION " ) ;
createGeomAction ( GEOMOp : : OpArchimede , " ARCHIMEDE " ) ;
createGeomAction ( GEOMOp : : OpFillet3d , " FILLET " ) ;
createGeomAction ( GEOMOp : : OpChamfer , " CHAMFER " ) ;
//createGeomAction( GEOMOp::OpClipping, "CLIPPING" );
createGeomAction ( GEOMOp : : OpShapesOnShape , " GET_SHAPES_ON_SHAPE " ) ;
createGeomAction ( GEOMOp : : OpSharedShapes , " GET_SHARED_SHAPES " ) ;
createGeomAction ( GEOMOp : : OpExtrudedCut , " EXTRUDED_CUT " ) ;
createGeomAction ( GEOMOp : : OpExtrudedBoss , " EXTRUDED_BOSS " ) ;
createGeomAction ( GEOMOp : : OpFillet1d , " FILLET_1D " ) ;
createGeomAction ( GEOMOp : : OpFillet2d , " FILLET_2D " ) ;
createGeomAction ( GEOMOp : : OpMultiTransform , " MUL_TRANSFORM " ) ;
createGeomAction ( GEOMOp : : OpExplodeBlock , " EXPLODE_BLOCKS " ) ;
createGeomAction ( GEOMOp : : OpPropagate , " PROPAGATE " ) ;
createGeomAction ( GEOMOp : : OpSewing , " SEWING " ) ;
createGeomAction ( GEOMOp : : OpGlueFaces , " GLUE_FACES " ) ;
createGeomAction ( GEOMOp : : OpGlueEdges , " GLUE_EDGES " ) ;
createGeomAction ( GEOMOp : : OpLimitTolerance , " LIMIT_TOLERANCE " ) ;
createGeomAction ( GEOMOp : : OpSuppressFaces , " SUPPRESS_FACES " ) ;
createGeomAction ( GEOMOp : : OpSuppressHoles , " SUPPERSS_HOLES " ) ;
createGeomAction ( GEOMOp : : OpShapeProcess , " SHAPE_PROCESS " ) ;
createGeomAction ( GEOMOp : : OpCloseContour , " CLOSE_CONTOUR " ) ;
createGeomAction ( GEOMOp : : OpRemoveIntWires , " SUPPRESS_INT_WIRES " ) ;
createGeomAction ( GEOMOp : : OpAddPointOnEdge , " POINT_ON_EDGE " ) ;
createGeomAction ( GEOMOp : : OpFreeBoundaries , " CHECK_FREE_BNDS " ) ;
createGeomAction ( GEOMOp : : OpFreeFaces , " CHECK_FREE_FACES " ) ;
createGeomAction ( GEOMOp : : OpOrientation , " CHANGE_ORIENTATION " ) ;
2013-06-14 18:20:21 +06:00
createGeomAction ( GEOMOp : : OpRemoveWebs , " REMOVE_WEBS " ) ;
2012-08-09 13:58:02 +06:00
createGeomAction ( GEOMOp : : OpRemoveExtraEdges , " REMOVE_EXTRA_EDGES " ) ;
createGeomAction ( GEOMOp : : OpFuseEdges , " FUSE_EDGES " ) ;
2013-05-24 14:52:30 +06:00
createGeomAction ( GEOMOp : : OpUnionFaces , " UNION_FACES " ) ;
2012-08-09 13:58:02 +06:00
createGeomAction ( GEOMOp : : OpPointCoordinates , " POINT_COORDS " ) ;
createGeomAction ( GEOMOp : : OpProperties , " BASIC_PROPS " ) ;
createGeomAction ( GEOMOp : : OpCenterMass , " MASS_CENTER " ) ;
createGeomAction ( GEOMOp : : OpInertia , " INERTIA " ) ;
createGeomAction ( GEOMOp : : OpNormale , " NORMALE " ) ;
createGeomAction ( GEOMOp : : OpBoundingBox , " BND_BOX " ) ;
createGeomAction ( GEOMOp : : OpMinDistance , " MIN_DIST " ) ;
createGeomAction ( GEOMOp : : OpAngle , " MEASURE_ANGLE " ) ;
createGeomAction ( GEOMOp : : OpTolerance , " TOLERANCE " ) ;
createGeomAction ( GEOMOp : : OpWhatIs , " WHAT_IS " ) ;
createGeomAction ( GEOMOp : : OpCheckShape , " CHECK " ) ;
createGeomAction ( GEOMOp : : OpCheckCompound , " CHECK_COMPOUND " ) ;
2012-10-08 17:16:36 +06:00
createGeomAction ( GEOMOp : : OpGetNonBlocks , " GET_NON_BLOCKS " ) ;
2012-08-09 13:58:02 +06:00
createGeomAction ( GEOMOp : : OpCheckSelfInters , " CHECK_SELF_INTERSECTIONS " ) ;
2005-06-02 13:17:09 +06:00
2008-03-07 12:45:34 +05:00
# ifdef _DEBUG_ // PAL16821
2012-08-09 13:58:02 +06:00
createGeomAction ( GEOMOp : : OpCheckGeom , " CHECK_GEOMETRY " ) ;
2008-03-07 12:45:34 +05:00
# endif
2012-08-09 13:58:02 +06:00
2013-02-12 17:35:16 +06:00
createGeomAction ( GEOMOp : : OpMaterialsLibrary , " MATERIALS_LIBRARY " ) ;
2012-08-09 13:58:02 +06:00
createGeomAction ( GEOMOp : : OpDMWireframe , " WIREFRAME " ) ;
createGeomAction ( GEOMOp : : OpDMShading , " SHADING " ) ;
createGeomAction ( GEOMOp : : OpDMShadingWithEdges , " SHADING_WITH_EDGES " ) ;
createGeomAction ( GEOMOp : : OpShowAll , " DISPLAY_ALL " ) ;
createGeomAction ( GEOMOp : : OpHideAll , " ERASE_ALL " ) ;
createGeomAction ( GEOMOp : : OpShow , " DISPLAY " ) ;
createGeomAction ( GEOMOp : : OpSwitchVectors , " VECTOR_MODE " ) ;
createGeomAction ( GEOMOp : : OpSelectVertex , " VERTEX_SEL_ONLY " , " " , 0 , true ) ;
createGeomAction ( GEOMOp : : OpSelectEdge , " EDGE_SEL_ONLY " , " " , 0 , true ) ;
createGeomAction ( GEOMOp : : OpSelectWire , " WIRE_SEL_ONLY " , " " , 0 , true ) ;
createGeomAction ( GEOMOp : : OpSelectFace , " FACE_SEL_ONLY " , " " , 0 , true ) ;
createGeomAction ( GEOMOp : : OpSelectShell , " SHELL_SEL_ONLY " , " " , 0 , true ) ;
createGeomAction ( GEOMOp : : OpSelectSolid , " SOLID_SEL_ONLY " , " " , 0 , true ) ;
createGeomAction ( GEOMOp : : OpSelectCompound , " COMPOUND_SEL_ONLY " , " " , 0 , true ) ;
createGeomAction ( GEOMOp : : OpSelectAll , " ALL_SEL_ONLY " , " " , 0 , true ) ;
createGeomAction ( GEOMOp : : OpShowOnly , " DISPLAY_ONLY " ) ;
2012-10-08 17:16:36 +06:00
createGeomAction ( GEOMOp : : OpShowOnlyChildren , " SHOW_ONLY_CHILDREN " ) ;
2012-08-09 13:58:02 +06:00
createGeomAction ( GEOMOp : : OpBringToFront , " BRING_TO_FRONT " , " " , 0 , true ) ;
createGeomAction ( GEOMOp : : OpClsBringToFront , " CLS_BRING_TO_FRONT " ) ;
createGeomAction ( GEOMOp : : OpHide , " ERASE " ) ;
createGeomAction ( GEOMOp : : OpWireframe , " POP_WIREFRAME " , " " , 0 , true ) ;
createGeomAction ( GEOMOp : : OpShading , " POP_SHADING " , " " , 0 , true ) ;
createGeomAction ( GEOMOp : : OpShadingWithEdges , " POP_SHADING_WITH_EDGES " , " " , 0 , true ) ;
createGeomAction ( GEOMOp : : OpTexture , " POP_TEXTURE " , " " , 0 , true ) ;
createGeomAction ( GEOMOp : : OpEdgeWidth , " EDGE_WIDTH " ) ;
createGeomAction ( GEOMOp : : OpIsosWidth , " ISOS_WIDTH " ) ;
createGeomAction ( GEOMOp : : OpVectors , " POP_VECTORS " , " " , 0 , true ) ;
createGeomAction ( GEOMOp : : OpDeflection , " POP_DEFLECTION " ) ;
createGeomAction ( GEOMOp : : OpColor , " POP_COLOR " ) ;
createGeomAction ( GEOMOp : : OpSetTexture , " POP_SETTEXTURE " ) ;
createGeomAction ( GEOMOp : : OpTransparency , " POP_TRANSPARENCY " ) ;
createGeomAction ( GEOMOp : : OpIsos , " POP_ISOS " ) ;
createGeomAction ( GEOMOp : : OpAutoColor , " POP_AUTO_COLOR " ) ;
createGeomAction ( GEOMOp : : OpNoAutoColor , " POP_DISABLE_AUTO_COLOR " ) ;
createGeomAction ( GEOMOp : : OpGroupCreatePopup , " POP_CREATE_GROUP " ) ;
2012-10-08 17:16:36 +06:00
createGeomAction ( GEOMOp : : OpDiscloseChildren , " POP_DISCLOSE_CHILDREN " ) ;
createGeomAction ( GEOMOp : : OpConcealChildren , " POP_CONCEAL_CHILDREN " ) ;
2012-08-09 13:58:02 +06:00
createGeomAction ( GEOMOp : : OpUnpublishObject , " POP_UNPUBLISH_OBJ " ) ;
createGeomAction ( GEOMOp : : OpPublishObject , " POP_PUBLISH_OBJ " ) ;
createGeomAction ( GEOMOp : : OpPointMarker , " POP_POINT_MARKER " ) ;
2013-02-12 17:35:16 +06:00
createGeomAction ( GEOMOp : : OpMaterialProperties , " POP_MATERIAL_PROPERTIES " ) ;
createGeomAction ( GEOMOp : : OpPredefMaterCustom , " POP_PREDEF_MATER_CUSTOM " ) ;
2012-08-09 13:58:02 +06:00
createGeomAction ( GEOMOp : : OpPipeTShape , " PIPETSHAPE " ) ;
// Create actions for increase/decrease transparency shortcuts
createGeomAction ( GEOMOp : : OpIncrTransparency , " " , " " , 0 , false ,
" Geometry:Increase transparency " ) ;
createGeomAction ( GEOMOp : : OpDecrTransparency , " " , " " , 0 , false ,
" Geometry:Decrease transparency " ) ;
// Create actions for increase/decrease number of isolines
createGeomAction ( GEOMOp : : OpIncrNbIsos , " " , " " , 0 , false ,
" Geometry:Increase number of isolines " ) ;
createGeomAction ( GEOMOp : : OpDecrNbIsos , " " , " " , 0 , false ,
" Geometry:Decrease number of isolines " ) ;
// createGeomAction( GEOMOp::OpPipeTShapeGroups, "PIPETSHAPEGROUPS" );
createGeomAction ( GEOMOp : : OpDividedDisk , " DIVIDEDDISK " ) ;
createGeomAction ( GEOMOp : : OpDividedCylinder , " DIVIDEDCYLINDER " ) ;
2013-06-10 14:28:09 +06:00
createGeomAction ( GEOMOp : : OpSmoothingSurface , " SMOOTHINGSURFACE " ) ;
2012-08-09 13:58:02 +06:00
//@@ insert new functions before this line @@ do not remove this line @@ do not remove this line @@ do not remove this line @@ do not remove this line @@//
// ---- create menus --------------------------
2005-06-02 13:17:09 +06:00
int fileId = createMenu ( tr ( " MEN_FILE " ) , - 1 , - 1 ) ;
2012-08-09 13:58:02 +06:00
createMenu ( separator ( ) , fileId , 10 ) ;
createMenu ( GEOMOp : : OpImport , fileId , 10 ) ;
createMenu ( GEOMOp : : OpExport , fileId , 10 ) ;
createMenu ( separator ( ) , fileId , - 1 ) ;
2005-06-02 13:17:09 +06:00
int editId = createMenu ( tr ( " MEN_EDIT " ) , - 1 , - 1 ) ;
2012-08-09 13:58:02 +06:00
createMenu ( GEOMOp : : OpDelete , editId , - 1 ) ;
2005-06-02 13:17:09 +06:00
int newEntId = createMenu ( tr ( " MEN_NEW_ENTITY " ) , - 1 , - 1 , 10 ) ;
int basicId = createMenu ( tr ( " MEN_BASIC " ) , newEntId , - 1 ) ;
2012-08-09 13:58:02 +06:00
createMenu ( GEOMOp : : OpPoint , basicId , - 1 ) ;
createMenu ( GEOMOp : : OpLine , basicId , - 1 ) ;
createMenu ( GEOMOp : : OpCircle , basicId , - 1 ) ;
createMenu ( GEOMOp : : OpEllipse , basicId , - 1 ) ;
createMenu ( GEOMOp : : OpArc , basicId , - 1 ) ;
createMenu ( GEOMOp : : OpCurve , basicId , - 1 ) ;
createMenu ( GEOMOp : : Op2dSketcher , basicId , - 1 ) ;
createMenu ( GEOMOp : : Op3dSketcher , basicId , - 1 ) ;
createMenu ( separator ( ) , basicId , - 1 ) ;
createMenu ( GEOMOp : : OpVector , basicId , - 1 ) ;
createMenu ( GEOMOp : : OpPlane , basicId , - 1 ) ;
createMenu ( GEOMOp : : OpLCS , basicId , - 1 ) ;
createMenu ( GEOMOp : : OpOriginAndVectors , basicId , - 1 ) ;
2005-06-02 13:17:09 +06:00
int primId = createMenu ( tr ( " MEN_PRIMITIVES " ) , newEntId , - 1 ) ;
2012-08-09 13:58:02 +06:00
createMenu ( GEOMOp : : OpBox , primId , - 1 ) ;
createMenu ( GEOMOp : : OpCylinder , primId , - 1 ) ;
createMenu ( GEOMOp : : OpSphere , primId , - 1 ) ;
createMenu ( GEOMOp : : OpTorus , primId , - 1 ) ;
createMenu ( GEOMOp : : OpCone , primId , - 1 ) ;
createMenu ( GEOMOp : : OpRectangle , primId , - 1 ) ;
createMenu ( GEOMOp : : OpDisk , primId , - 1 ) ;
createMenu ( GEOMOp : : OpPipeTShape , primId , - 1 ) ;
2005-06-02 13:17:09 +06:00
int genId = createMenu ( tr ( " MEN_GENERATION " ) , newEntId , - 1 ) ;
2012-08-09 13:58:02 +06:00
createMenu ( GEOMOp : : OpPrism , genId , - 1 ) ;
createMenu ( GEOMOp : : OpRevolution , genId , - 1 ) ;
createMenu ( GEOMOp : : OpFilling , genId , - 1 ) ;
createMenu ( GEOMOp : : OpPipe , genId , - 1 ) ;
2012-12-13 14:40:36 +06:00
# if OCC_VERSION_LARGE > 0x06050300
createMenu ( GEOMOp : : OpPipePath , genId , - 1 ) ;
# endif
2012-08-09 13:58:02 +06:00
2013-06-10 14:28:09 +06:00
int advId = createMenu ( tr ( " MEN_ADVANCED " ) , newEntId , - 1 ) ;
createMenu ( GEOMOp : : OpSmoothingSurface , advId , - 1 ) ;
//@@ insert new functions before this line @@ do not remove this line @@ do not remove this line @@ do not remove this line @@ do not remove this line @@//
2012-08-09 13:58:02 +06:00
2005-06-02 13:17:09 +06:00
createMenu ( separator ( ) , newEntId , - 1 ) ;
int groupId = createMenu ( tr ( " MEN_GROUP " ) , newEntId , - 1 ) ;
2012-10-08 17:16:36 +06:00
createMenu ( GEOMOp : : OpGroupCreate , groupId , - 1 ) ;
createMenu ( GEOMOp : : OpGroupEdit , groupId , - 1 ) ;
createMenu ( GEOMOp : : OpGroupUnion , groupId , - 1 ) ;
createMenu ( GEOMOp : : OpGroupIntersect , groupId , - 1 ) ;
createMenu ( GEOMOp : : OpGroupCut , groupId , - 1 ) ;
2012-08-09 13:58:02 +06:00
2005-06-02 13:17:09 +06:00
createMenu ( separator ( ) , newEntId , - 1 ) ;
int blocksId = createMenu ( tr ( " MEN_BLOCKS " ) , newEntId , - 1 ) ;
2012-08-09 13:58:02 +06:00
createMenu ( GEOMOp : : OpQuadFace , blocksId , - 1 ) ;
createMenu ( GEOMOp : : OpHexaSolid , blocksId , - 1 ) ;
createMenu ( GEOMOp : : OpDividedDisk , blocksId , - 1 ) ;
createMenu ( GEOMOp : : OpDividedCylinder , blocksId , - 1 ) ;
2005-06-02 13:17:09 +06:00
2012-08-09 13:58:02 +06:00
createMenu ( separator ( ) , newEntId , - 1 ) ;
createMenu ( GEOMOp : : OpExplode , newEntId , - 1 ) ;
2005-06-02 13:17:09 +06:00
int buildId = createMenu ( tr ( " MEN_BUILD " ) , newEntId , - 1 ) ;
2012-08-09 13:58:02 +06:00
createMenu ( GEOMOp : : OpEdge , buildId , - 1 ) ;
createMenu ( GEOMOp : : OpWire , buildId , - 1 ) ;
createMenu ( GEOMOp : : OpFace , buildId , - 1 ) ;
createMenu ( GEOMOp : : OpShell , buildId , - 1 ) ;
createMenu ( GEOMOp : : OpSolid , buildId , - 1 ) ;
createMenu ( GEOMOp : : OpCompound , buildId , - 1 ) ;
2012-12-13 14:40:36 +06:00
2012-08-09 13:58:02 +06:00
createMenu ( separator ( ) , newEntId , - 1 ) ;
2012-12-13 14:40:36 +06:00
2012-08-09 13:58:02 +06:00
createMenu ( GEOMOp : : OpPictureImport , newEntId , - 1 ) ;
# ifdef WITH_OPENCV
createMenu ( GEOMOp : : OpFeatureDetect , newEntId , - 1 ) ;
# endif
2005-06-02 13:17:09 +06:00
int operId = createMenu ( tr ( " MEN_OPERATIONS " ) , - 1 , - 1 , 10 ) ;
int boolId = createMenu ( tr ( " MEN_BOOLEAN " ) , operId , - 1 ) ;
2012-08-09 13:58:02 +06:00
createMenu ( GEOMOp : : OpFuse , boolId , - 1 ) ;
createMenu ( GEOMOp : : OpCommon , boolId , - 1 ) ;
createMenu ( GEOMOp : : OpCut , boolId , - 1 ) ;
createMenu ( GEOMOp : : OpSection , boolId , - 1 ) ;
2005-06-02 13:17:09 +06:00
int transId = createMenu ( tr ( " MEN_TRANSFORMATION " ) , operId , - 1 ) ;
2012-08-09 13:58:02 +06:00
createMenu ( GEOMOp : : OpTranslate , transId , - 1 ) ;
createMenu ( GEOMOp : : OpRotate , transId , - 1 ) ;
createMenu ( GEOMOp : : OpChangeLoc , transId , - 1 ) ;
createMenu ( GEOMOp : : OpMirror , transId , - 1 ) ;
createMenu ( GEOMOp : : OpScale , transId , - 1 ) ;
createMenu ( GEOMOp : : OpOffset , transId , - 1 ) ;
createMenu ( GEOMOp : : OpProjection , transId , - 1 ) ;
createMenu ( separator ( ) , transId , - 1 ) ;
createMenu ( GEOMOp : : OpMultiTranslate , transId , - 1 ) ;
createMenu ( GEOMOp : : OpMultiRotate , transId , - 1 ) ;
2005-06-02 13:17:09 +06:00
int blockId = createMenu ( tr ( " MEN_BLOCKS " ) , operId , - 1 ) ;
2012-08-09 13:58:02 +06:00
createMenu ( GEOMOp : : OpMultiTransform , blockId , - 1 ) ;
createMenu ( GEOMOp : : OpExplodeBlock , blockId , - 1 ) ;
createMenu ( GEOMOp : : OpPropagate , blockId , - 1 ) ;
createMenu ( separator ( ) , operId , - 1 ) ;
createMenu ( GEOMOp : : OpPartition , operId , - 1 ) ;
createMenu ( GEOMOp : : OpArchimede , operId , - 1 ) ;
createMenu ( GEOMOp : : OpShapesOnShape , operId , - 1 ) ;
createMenu ( GEOMOp : : OpSharedShapes , operId , - 1 ) ;
createMenu ( separator ( ) , operId , - 1 ) ;
createMenu ( GEOMOp : : OpFillet1d , operId , - 1 ) ;
createMenu ( GEOMOp : : OpFillet2d , operId , - 1 ) ;
createMenu ( GEOMOp : : OpFillet3d , operId , - 1 ) ;
createMenu ( GEOMOp : : OpChamfer , operId , - 1 ) ;
createMenu ( GEOMOp : : OpExtrudedBoss , operId , - 1 ) ;
createMenu ( GEOMOp : : OpExtrudedCut , operId , - 1 ) ;
//createMenu( GEOMOp::OpClipping, operId, -1 );
2005-06-02 13:17:09 +06:00
int repairId = createMenu ( tr ( " MEN_REPAIR " ) , - 1 , - 1 , 10 ) ;
2012-08-09 13:58:02 +06:00
createMenu ( GEOMOp : : OpShapeProcess , repairId , - 1 ) ;
createMenu ( GEOMOp : : OpSuppressFaces , repairId , - 1 ) ;
createMenu ( GEOMOp : : OpCloseContour , repairId , - 1 ) ;
createMenu ( GEOMOp : : OpRemoveIntWires , repairId , - 1 ) ;
createMenu ( GEOMOp : : OpSuppressHoles , repairId , - 1 ) ;
createMenu ( GEOMOp : : OpSewing , repairId , - 1 ) ;
createMenu ( GEOMOp : : OpGlueFaces , repairId , - 1 ) ;
createMenu ( GEOMOp : : OpGlueEdges , repairId , - 1 ) ;
createMenu ( GEOMOp : : OpLimitTolerance , repairId , - 1 ) ;
createMenu ( GEOMOp : : OpAddPointOnEdge , repairId , - 1 ) ;
//createMenu( GEOMOp::OpFreeBoundaries, repairId, -1 );
//createMenu( GEOMOp::OpFreeFaces, repairId, -1 );
createMenu ( GEOMOp : : OpOrientation , repairId , - 1 ) ;
2013-06-14 18:20:21 +06:00
createMenu ( GEOMOp : : OpRemoveWebs , repairId , - 1 ) ;
2012-08-09 13:58:02 +06:00
createMenu ( GEOMOp : : OpRemoveExtraEdges , repairId , - 1 ) ;
createMenu ( GEOMOp : : OpFuseEdges , repairId , - 1 ) ;
2013-05-24 14:52:30 +06:00
createMenu ( GEOMOp : : OpUnionFaces , repairId , - 1 ) ;
2005-06-02 13:17:09 +06:00
int measurId = createMenu ( tr ( " MEN_MEASURES " ) , - 1 , - 1 , 10 ) ;
2012-08-09 13:58:02 +06:00
createMenu ( GEOMOp : : OpPointCoordinates , measurId , - 1 ) ;
createMenu ( GEOMOp : : OpProperties , measurId , - 1 ) ;
createMenu ( separator ( ) , measurId , - 1 ) ;
createMenu ( GEOMOp : : OpCenterMass , measurId , - 1 ) ;
createMenu ( GEOMOp : : OpInertia , measurId , - 1 ) ;
createMenu ( GEOMOp : : OpNormale , measurId , - 1 ) ;
createMenu ( separator ( ) , measurId , - 1 ) ;
createMenu ( GEOMOp : : OpFreeBoundaries , measurId , - 1 ) ;
createMenu ( GEOMOp : : OpFreeFaces , measurId , - 1 ) ;
createMenu ( separator ( ) , measurId , - 1 ) ;
2005-06-02 13:17:09 +06:00
int dimId = createMenu ( tr ( " MEN_DIMENSIONS " ) , measurId , - 1 ) ;
2012-08-09 13:58:02 +06:00
createMenu ( GEOMOp : : OpBoundingBox , dimId , - 1 ) ;
createMenu ( GEOMOp : : OpMinDistance , dimId , - 1 ) ;
createMenu ( GEOMOp : : OpAngle , dimId , - 1 ) ;
createMenu ( separator ( ) , measurId , - 1 ) ;
createMenu ( GEOMOp : : OpTolerance , measurId , - 1 ) ;
createMenu ( separator ( ) , measurId , - 1 ) ;
createMenu ( GEOMOp : : OpWhatIs , measurId , - 1 ) ;
createMenu ( GEOMOp : : OpCheckShape , measurId , - 1 ) ;
createMenu ( GEOMOp : : OpCheckCompound , measurId , - 1 ) ;
2012-10-08 17:16:36 +06:00
createMenu ( GEOMOp : : OpGetNonBlocks , measurId , - 1 ) ;
2012-08-09 13:58:02 +06:00
createMenu ( GEOMOp : : OpCheckSelfInters , measurId , - 1 ) ;
2005-06-02 13:17:09 +06:00
2005-08-02 18:43:40 +06:00
int toolsId = createMenu ( tr ( " MEN_TOOLS " ) , - 1 , - 1 , 50 ) ;
2013-02-12 17:35:16 +06:00
# if defined(_DEBUG_) || defined(_DEBUG) // PAL16821
2012-08-09 13:58:02 +06:00
createMenu ( separator ( ) , toolsId , - 1 ) ;
createMenu ( GEOMOp : : OpCheckGeom , toolsId , - 1 ) ;
2008-03-07 12:45:34 +05:00
# endif
2013-02-12 17:35:16 +06:00
createMenu ( separator ( ) , toolsId , - 1 ) ;
createMenu ( GEOMOp : : OpMaterialsLibrary , toolsId , - 1 ) ;
createMenu ( separator ( ) , toolsId , - 1 ) ;
2005-06-02 13:17:09 +06:00
int viewId = createMenu ( tr ( " MEN_VIEW " ) , - 1 , - 1 ) ;
2012-08-09 13:58:02 +06:00
createMenu ( separator ( ) , viewId , - 1 ) ;
2005-06-02 13:17:09 +06:00
int dispmodeId = createMenu ( tr ( " MEN_DISPLAY_MODE " ) , viewId , - 1 ) ;
2012-08-09 13:58:02 +06:00
createMenu ( GEOMOp : : OpDMWireframe , dispmodeId , - 1 ) ;
createMenu ( GEOMOp : : OpDMShading , dispmodeId , - 1 ) ;
createMenu ( GEOMOp : : OpDMShadingWithEdges , dispmodeId , - 1 ) ;
createMenu ( separator ( ) , dispmodeId , - 1 ) ;
createMenu ( GEOMOp : : OpSwitchVectors , dispmodeId , - 1 ) ;
createMenu ( separator ( ) , viewId , - 1 ) ;
createMenu ( GEOMOp : : OpShowAll , viewId , - 1 ) ;
createMenu ( GEOMOp : : OpHideAll , viewId , - 1 ) ;
createMenu ( separator ( ) , viewId , - 1 ) ;
createMenu ( GEOMOp : : OpPublishObject , viewId , - 1 ) ;
createMenu ( separator ( ) , viewId , - 1 ) ;
2005-12-01 15:05:15 +05:00
/*
PAL9111 :
because of these items are accessible through object browser and viewers
we have removed they from main menu
2012-08-09 13:58:02 +06:00
createMenu ( GEOMOp : : OpShow , viewId , - 1 ) ;
createMenu ( GEOMOp : : OpShowOnly , viewId , - 1 ) ;
createMenu ( GEOMOp : : OpHide , viewId , - 1 ) ;
2005-12-01 15:05:15 +05:00
*/
2005-06-02 13:17:09 +06:00
// ---- create toolbars --------------------------
2012-12-13 14:40:36 +06:00
2005-06-02 13:17:09 +06:00
int basicTbId = createTool ( tr ( " TOOL_BASIC " ) ) ;
2012-08-09 13:58:02 +06:00
createTool ( GEOMOp : : OpPoint , basicTbId ) ;
createTool ( GEOMOp : : OpLine , basicTbId ) ;
createTool ( GEOMOp : : OpCircle , basicTbId ) ;
createTool ( GEOMOp : : OpEllipse , basicTbId ) ;
createTool ( GEOMOp : : OpArc , basicTbId ) ;
createTool ( GEOMOp : : OpCurve , basicTbId ) ;
createTool ( GEOMOp : : OpVector , basicTbId ) ;
createTool ( GEOMOp : : Op2dSketcher , basicTbId ) ; //rnc
createTool ( GEOMOp : : Op3dSketcher , basicTbId ) ; //rnc
createTool ( GEOMOp : : OpPlane , basicTbId ) ;
createTool ( GEOMOp : : OpLCS , basicTbId ) ;
createTool ( GEOMOp : : OpOriginAndVectors , basicTbId ) ;
2012-12-13 14:40:36 +06:00
2012-08-09 13:58:02 +06:00
// int sketchTbId = createTool( tr( "TOOL_SKETCH" ) );
// createTool( GEOMOp::Op2dSketcher, sketchTbId );
// createTool( GEOMOp::Op3dSketcher, sketchTbId );
2012-12-13 14:40:36 +06:00
2005-06-02 13:17:09 +06:00
int primTbId = createTool ( tr ( " TOOL_PRIMITIVES " ) ) ;
2012-08-09 13:58:02 +06:00
createTool ( GEOMOp : : OpBox , primTbId ) ;
createTool ( GEOMOp : : OpCylinder , primTbId ) ;
createTool ( GEOMOp : : OpSphere , primTbId ) ;
createTool ( GEOMOp : : OpTorus , primTbId ) ;
createTool ( GEOMOp : : OpCone , primTbId ) ;
createTool ( GEOMOp : : OpRectangle , primTbId ) ;
createTool ( GEOMOp : : OpDisk , primTbId ) ;
createTool ( GEOMOp : : OpPipeTShape , primTbId ) ; //rnc
2012-12-13 14:40:36 +06:00
2012-08-09 13:58:02 +06:00
int blocksTbId = createTool ( tr ( " TOOL_BLOCKS " ) ) ;
createTool ( GEOMOp : : OpDividedDisk , blocksTbId ) ;
createTool ( GEOMOp : : OpDividedCylinder , blocksTbId ) ;
2012-12-13 14:40:36 +06:00
2012-08-09 13:58:02 +06:00
// int advancedTbId = createTool( tr( "TOOL_ADVANCED" ) ); //rnc
// createTool( GEOMOp::OpPipeTShape, advancedTbId );
2012-12-13 14:40:36 +06:00
2005-06-02 13:17:09 +06:00
int boolTbId = createTool ( tr ( " TOOL_BOOLEAN " ) ) ;
2012-08-09 13:58:02 +06:00
createTool ( GEOMOp : : OpFuse , boolTbId ) ;
createTool ( GEOMOp : : OpCommon , boolTbId ) ;
createTool ( GEOMOp : : OpCut , boolTbId ) ;
createTool ( GEOMOp : : OpSection , boolTbId ) ;
2012-12-13 14:40:36 +06:00
int genTbId = createTool ( tr ( " TOOL_GENERATION " ) ) ;
2012-08-09 13:58:02 +06:00
createTool ( GEOMOp : : OpPrism , genTbId ) ;
createTool ( GEOMOp : : OpRevolution , genTbId ) ;
createTool ( GEOMOp : : OpFilling , genTbId ) ;
createTool ( GEOMOp : : OpPipe , genTbId ) ;
2012-12-13 14:40:36 +06:00
# if OCC_VERSION_LARGE > 0x06050300
createTool ( GEOMOp : : OpPipePath , genTbId ) ;
# endif
2005-06-02 13:17:09 +06:00
int transTbId = createTool ( tr ( " TOOL_TRANSFORMATION " ) ) ;
2012-08-09 13:58:02 +06:00
createTool ( GEOMOp : : OpTranslate , transTbId ) ;
createTool ( GEOMOp : : OpRotate , transTbId ) ;
createTool ( GEOMOp : : OpChangeLoc , transTbId ) ;
createTool ( GEOMOp : : OpMirror , transTbId ) ;
createTool ( GEOMOp : : OpScale , transTbId ) ;
createTool ( GEOMOp : : OpOffset , transTbId ) ;
createTool ( GEOMOp : : OpProjection , transTbId ) ;
createTool ( separator ( ) , transTbId ) ;
createTool ( GEOMOp : : OpMultiTranslate , transTbId ) ;
createTool ( GEOMOp : : OpMultiRotate , transTbId ) ;
2012-12-13 14:40:36 +06:00
2012-08-09 13:58:02 +06:00
int operTbId = createTool ( tr ( " TOOL_OPERATIONS " ) ) ;
createTool ( GEOMOp : : OpExplode , operTbId ) ;
createTool ( GEOMOp : : OpPartition , operTbId ) ;
createTool ( GEOMOp : : OpArchimede , operTbId ) ;
createTool ( GEOMOp : : OpShapesOnShape , operTbId ) ;
createTool ( GEOMOp : : OpSharedShapes , operTbId ) ;
2012-12-13 14:40:36 +06:00
2012-08-09 13:58:02 +06:00
int featTbId = createTool ( tr ( " TOOL_FEATURES " ) ) ;
createTool ( GEOMOp : : OpFillet1d , featTbId ) ;
createTool ( GEOMOp : : OpFillet2d , featTbId ) ;
createTool ( GEOMOp : : OpFillet3d , featTbId ) ;
createTool ( GEOMOp : : OpChamfer , featTbId ) ;
createTool ( GEOMOp : : OpExtrudedBoss , featTbId ) ;
createTool ( GEOMOp : : OpExtrudedCut , featTbId ) ;
2012-12-13 14:40:36 +06:00
2012-08-09 13:58:02 +06:00
int buildTbId = createTool ( tr ( " TOOL_BUILD " ) ) ;
createTool ( GEOMOp : : OpEdge , buildTbId ) ;
createTool ( GEOMOp : : OpWire , buildTbId ) ;
createTool ( GEOMOp : : OpFace , buildTbId ) ;
createTool ( GEOMOp : : OpShell , buildTbId ) ;
createTool ( GEOMOp : : OpSolid , buildTbId ) ;
createTool ( GEOMOp : : OpCompound , buildTbId ) ;
int measureTbId = createTool ( tr ( " TOOL_MEASURES " ) ) ;
createTool ( GEOMOp : : OpPointCoordinates , measureTbId ) ;
createTool ( GEOMOp : : OpProperties , measureTbId ) ;
createTool ( GEOMOp : : OpCenterMass , measureTbId ) ;
createTool ( GEOMOp : : OpInertia , measureTbId ) ;
createTool ( GEOMOp : : OpNormale , measureTbId ) ;
createTool ( separator ( ) , measureTbId ) ;
createTool ( GEOMOp : : OpBoundingBox , measureTbId ) ;
createTool ( GEOMOp : : OpMinDistance , measureTbId ) ;
createTool ( GEOMOp : : OpAngle , measureTbId ) ;
createTool ( GEOMOp : : OpTolerance , measureTbId ) ;
createTool ( separator ( ) , measureTbId ) ;
createTool ( GEOMOp : : OpFreeBoundaries , measureTbId ) ;
createTool ( GEOMOp : : OpFreeFaces , measureTbId ) ;
createTool ( separator ( ) , measureTbId ) ;
createTool ( GEOMOp : : OpWhatIs , measureTbId ) ;
createTool ( GEOMOp : : OpCheckShape , measureTbId ) ;
createTool ( GEOMOp : : OpCheckCompound , measureTbId ) ;
2012-10-08 17:16:36 +06:00
createTool ( GEOMOp : : OpGetNonBlocks , measureTbId ) ;
2012-08-09 13:58:02 +06:00
createTool ( GEOMOp : : OpCheckSelfInters , measureTbId ) ;
2012-10-08 17:16:36 +06:00
2012-08-09 13:58:02 +06:00
int picturesTbId = createTool ( tr ( " TOOL_PICTURES " ) ) ;
createTool ( GEOMOp : : OpPictureImport , picturesTbId ) ;
# ifdef WITH_OPENCV
createTool ( GEOMOp : : OpFeatureDetect , picturesTbId ) ;
# endif
2012-12-13 14:40:36 +06:00
2013-06-10 14:28:09 +06:00
int advancedTbId = createTool ( tr ( " TOOL_ADVANCED " ) ) ;
createTool ( GEOMOp : : OpSmoothingSurface , advancedTbId ) ;
2012-08-09 13:58:02 +06:00
//@@ insert new functions before this line @@ do not remove this line @@ do not remove this line @@ do not remove this line @@ do not remove this line @@//
2005-06-02 13:17:09 +06:00
2008-03-07 12:45:34 +05:00
// ---- create popup menus --------------------------
QString clientOCCorVTK = " (client='OCCViewer' or client='VTKViewer') " ;
2012-08-09 13:58:02 +06:00
QString clientOCC = " (client='OCCViewer') " ;
2008-03-07 12:45:34 +05:00
QString clientOCCorVTK_AndSomeVisible = clientOCCorVTK + " and selcount>0 and isVisible " ;
2012-08-09 13:58:02 +06:00
QString clientOCC_AndSomeVisible = clientOCC + " and selcount>0 and isVisible " ;
2008-03-07 12:45:34 +05:00
2012-08-09 13:58:02 +06:00
QString clientOCCorOB = " (client='ObjectBrowser' or client='OCCViewer') " ;
2008-03-07 12:45:34 +05:00
QString clientOCCorVTKorOB = " (client='ObjectBrowser' or client='OCCViewer' or client='VTKViewer') " ;
QString clientOCCorVTKorOB_AndSomeVisible = clientOCCorVTKorOB + " and selcount>0 and isVisible " ;
2012-08-09 13:58:02 +06:00
QString clientOCCorOB_AndSomeVisible = clientOCCorOB + " and selcount>0 and isVisible " ;
2008-03-07 12:45:34 +05:00
QString autoColorPrefix =
" (client='ObjectBrowser' or client='OCCViewer') and type='Shape' and selcount=1 and isOCC=true " ;
2005-06-02 13:17:09 +06:00
QtxPopupMgr * mgr = popupMgr ( ) ;
2012-08-09 13:58:02 +06:00
mgr - > insert ( action ( GEOMOp : : OpDelete ) , - 1 , - 1 ) ; // delete
mgr - > setRule ( action ( GEOMOp : : OpDelete ) , QString ( " $type in {'Shape' 'Group'} and selcount>0 " ) , QtxPopupMgr : : VisibleRule ) ;
mgr - > insert ( action ( GEOMOp : : OpGroupCreatePopup ) , - 1 , - 1 ) ; // create group
2013-03-26 15:37:44 +06:00
mgr - > setRule ( action ( GEOMOp : : OpGroupCreatePopup ) , QString ( " type='Shape' and selcount=1 and isOCC=true " ) , QtxPopupMgr : : VisibleRule ) ;
2012-10-08 17:16:36 +06:00
mgr - > insert ( action ( GEOMOp : : OpDiscloseChildren ) , - 1 , - 1 ) ; // disclose child items
mgr - > setRule ( action ( GEOMOp : : OpDiscloseChildren ) , QString ( " client='ObjectBrowser' and type='Shape' and selcount=1 and hasConcealedChildren=true " ) , QtxPopupMgr : : VisibleRule ) ;
2012-08-09 13:58:02 +06:00
2012-10-08 17:16:36 +06:00
mgr - > insert ( action ( GEOMOp : : OpConcealChildren ) , - 1 , - 1 ) ; // conceal shild items
mgr - > setRule ( action ( GEOMOp : : OpConcealChildren ) , QString ( " client='ObjectBrowser' and type='Shape' and selcount=1 and hasDisclosedChildren=true " ) , QtxPopupMgr : : VisibleRule ) ;
2012-08-09 13:58:02 +06:00
mgr - > insert ( action ( GEOMOp : : OpGroupEdit ) , - 1 , - 1 ) ; // edit group
mgr - > setRule ( action ( GEOMOp : : OpGroupEdit ) , QString ( " client='ObjectBrowser' and type='Group' and selcount=1 and isOCC=true " ) , QtxPopupMgr : : VisibleRule ) ;
mgr - > insert ( separator ( ) , - 1 , - 1 ) ; // -----------
# if OCC_VERSION_LARGE > 0x06050200
//QString bringRule = clientOCCorOB + " and ($component={'GEOM'}) and (selcount>0) and isOCC=true and topLevel=false";
QString bringRule = clientOCCorOB + " and ($component={'GEOM'}) and (selcount>0) and isOCC=true " ;
mgr - > insert ( action ( GEOMOp : : OpBringToFront ) , - 1 , - 1 ) ; // bring to front
mgr - > setRule ( action ( GEOMOp : : OpBringToFront ) , bringRule , QtxPopupMgr : : VisibleRule ) ;
mgr - > setRule ( action ( GEOMOp : : OpBringToFront ) , " topLevel=true " , QtxPopupMgr : : ToggleRule ) ;
mgr - > insert ( action ( GEOMOp : : OpClsBringToFront ) , - 1 , - 1 ) ; // clear bring to front
2012-12-13 14:40:36 +06:00
mgr - > setRule ( action ( GEOMOp : : OpClsBringToFront ) , clientOCC , QtxPopupMgr : : VisibleRule ) ;
2012-08-09 13:58:02 +06:00
# endif
2008-03-07 12:45:34 +05:00
mgr - > insert ( separator ( ) , - 1 , - 1 ) ; // -----------
2005-06-02 13:17:09 +06:00
dispmodeId = mgr - > insert ( tr ( " MEN_DISPLAY_MODE " ) , - 1 , - 1 ) ; // display mode menu
2012-08-09 13:58:02 +06:00
mgr - > insert ( action ( GEOMOp : : OpWireframe ) , dispmodeId , - 1 ) ; // wireframe
2013-02-12 17:35:16 +06:00
mgr - > setRule ( action ( GEOMOp : : OpWireframe ) , clientOCCorVTK_AndSomeVisible + " and ($component={'GEOM'}) " , QtxPopupMgr : : VisibleRule ) ;
2012-08-09 13:58:02 +06:00
mgr - > setRule ( action ( GEOMOp : : OpWireframe ) , clientOCCorVTK + " and displaymode='Wireframe' " , QtxPopupMgr : : ToggleRule ) ;
mgr - > insert ( action ( GEOMOp : : OpShading ) , dispmodeId , - 1 ) ; // shading
2013-02-12 17:35:16 +06:00
mgr - > setRule ( action ( GEOMOp : : OpShading ) , clientOCCorVTK_AndSomeVisible + " and ($component={'GEOM'}) " , QtxPopupMgr : : VisibleRule ) ;
2012-08-09 13:58:02 +06:00
mgr - > setRule ( action ( GEOMOp : : OpShading ) , clientOCCorVTK + " and displaymode='Shading' " , QtxPopupMgr : : ToggleRule ) ;
mgr - > insert ( action ( GEOMOp : : OpShadingWithEdges ) , dispmodeId , - 1 ) ; // shading with edges
2013-02-12 17:35:16 +06:00
mgr - > setRule ( action ( GEOMOp : : OpShadingWithEdges ) , clientOCCorVTK_AndSomeVisible + " and ($component={'GEOM'}) " , QtxPopupMgr : : VisibleRule ) ;
2012-08-09 13:58:02 +06:00
mgr - > setRule ( action ( GEOMOp : : OpShadingWithEdges ) , clientOCCorVTK + " and displaymode='ShadingWithEdges' " , QtxPopupMgr : : ToggleRule ) ;
mgr - > insert ( action ( GEOMOp : : OpTexture ) , dispmodeId , - 1 ) ; // wireframe
mgr - > setRule ( action ( GEOMOp : : OpTexture ) , clientOCC_AndSomeVisible , QtxPopupMgr : : VisibleRule ) ;
mgr - > setRule ( action ( GEOMOp : : OpTexture ) , clientOCC + " and displaymode='Texture' " , QtxPopupMgr : : ToggleRule ) ;
mgr - > insert ( separator ( ) , dispmodeId , - 1 ) ;
mgr - > insert ( action ( GEOMOp : : OpVectors ) , dispmodeId , - 1 ) ; // vectors
2013-02-12 17:35:16 +06:00
mgr - > setRule ( action ( GEOMOp : : OpVectors ) , clientOCCorVTK_AndSomeVisible + " and ($component={'GEOM'}) " , QtxPopupMgr : : VisibleRule ) ;
2012-08-09 13:58:02 +06:00
mgr - > setRule ( action ( GEOMOp : : OpVectors ) , clientOCCorVTK + " and isVectorsMode " , QtxPopupMgr : : ToggleRule ) ;
2008-03-07 12:45:34 +05:00
mgr - > insert ( separator ( ) , - 1 , - 1 ) ; // -----------
2013-02-12 17:35:16 +06:00
2012-08-09 13:58:02 +06:00
mgr - > insert ( action ( GEOMOp : : OpColor ) , - 1 , - 1 ) ; // color
mgr - > setRule ( action ( GEOMOp : : OpColor ) , clientOCCorVTKorOB_AndSomeVisible + " and ($component={'GEOM'}) " + " and isPhysicalMaterial=false " , QtxPopupMgr : : VisibleRule ) ;
mgr - > insert ( action ( GEOMOp : : OpTransparency ) , - 1 , - 1 ) ; // transparency
2013-02-12 17:35:16 +06:00
mgr - > setRule ( action ( GEOMOp : : OpTransparency ) , clientOCCorVTK_AndSomeVisible + " and ($component={'GEOM'}) " , QtxPopupMgr : : VisibleRule ) ;
2012-08-09 13:58:02 +06:00
mgr - > insert ( action ( GEOMOp : : OpIsos ) , - 1 , - 1 ) ; // isos
2013-02-12 17:35:16 +06:00
mgr - > setRule ( action ( GEOMOp : : OpIsos ) , clientOCCorVTK_AndSomeVisible + " and selcount>0 and isVisible " + " and ($component={'GEOM'}) " , QtxPopupMgr : : VisibleRule ) ;
2012-08-09 13:58:02 +06:00
mgr - > insert ( action ( GEOMOp : : OpDeflection ) , - 1 , - 1 ) ; // deflection
2013-02-12 17:35:16 +06:00
mgr - > setRule ( action ( GEOMOp : : OpDeflection ) , clientOCCorVTK_AndSomeVisible + " and selcount>0 and isVisible " + " and ($component={'GEOM'}) " , QtxPopupMgr : : VisibleRule ) ;
2012-08-09 13:58:02 +06:00
mgr - > insert ( action ( GEOMOp : : OpPointMarker ) , - 1 , - 1 ) ; // point marker
//mgr->setRule( action( GEOMOp::OpPointMarker ), QString( "selcount>0 and $typeid in {%1}" ).arg(GEOM_POINT ), QtxPopupMgr::VisibleRule );
mgr - > setRule ( action ( GEOMOp : : OpPointMarker ) , QString ( " selcount>0 and ( $typeid in {%1} or compoundOfVertices=true ) " ) . arg ( GEOM : : VERTEX ) . arg ( GEOM : : COMPOUND ) , QtxPopupMgr : : VisibleRule ) ;
2013-02-12 17:35:16 +06:00
// material properties
mgr - > insert ( action ( GEOMOp : : OpMaterialProperties ) , - 1 , - 1 ) ;
mgr - > setRule ( action ( GEOMOp : : OpMaterialProperties ) , clientOCCorVTK_AndSomeVisible + " and ($component={'GEOM'}) " , QtxPopupMgr : : VisibleRule ) ;
// texture
mgr - > insert ( action ( GEOMOp : : OpSetTexture ) , - 1 , - 1 ) ;
2012-08-09 13:58:02 +06:00
mgr - > setRule ( action ( GEOMOp : : OpSetTexture ) , clientOCCorOB_AndSomeVisible + " and ($component={'GEOM'}) " , QtxPopupMgr : : VisibleRule ) ;
int lineW = mgr - > insert ( tr ( " MEN_LINE_WIDTH " ) , - 1 , - 1 ) ; // line width menu
mgr - > insert ( action ( GEOMOp : : OpEdgeWidth ) , lineW , - 1 ) ; // edge width
2013-02-12 17:35:16 +06:00
mgr - > setRule ( action ( GEOMOp : : OpEdgeWidth ) , clientOCCorVTK_AndSomeVisible + " and ($component={'GEOM'}) " , QtxPopupMgr : : VisibleRule ) ;
2012-08-09 13:58:02 +06:00
mgr - > insert ( action ( GEOMOp : : OpIsosWidth ) , lineW , - 1 ) ; // isos width
2013-02-12 17:35:16 +06:00
mgr - > setRule ( action ( GEOMOp : : OpIsosWidth ) , clientOCCorVTK_AndSomeVisible + " and ($component={'GEOM'}) " , QtxPopupMgr : : VisibleRule ) ;
2012-12-13 14:40:36 +06:00
2008-03-07 12:45:34 +05:00
mgr - > insert ( separator ( ) , - 1 , - 1 ) ; // -----------
2012-08-09 13:58:02 +06:00
mgr - > insert ( action ( GEOMOp : : OpAutoColor ) , - 1 , - 1 ) ; // auto color
mgr - > setRule ( action ( GEOMOp : : OpAutoColor ) , autoColorPrefix + " and isAutoColor=false " , QtxPopupMgr : : VisibleRule ) ;
mgr - > insert ( action ( GEOMOp : : OpNoAutoColor ) , - 1 , - 1 ) ; // disable auto color
mgr - > setRule ( action ( GEOMOp : : OpNoAutoColor ) , autoColorPrefix + " and isAutoColor=true " , QtxPopupMgr : : VisibleRule ) ;
2008-03-07 12:45:34 +05:00
mgr - > insert ( separator ( ) , - 1 , - 1 ) ; // -----------
2005-12-01 15:05:15 +05:00
QString canDisplay = " ($component={'GEOM'}) and (selcount>0) and ({true} in $canBeDisplayed) " ,
onlyComponent = " ((type='Component') and selcount=1) " ,
rule = canDisplay + " and ((($type in {%1}) and( %2 )) or " + onlyComponent + " ) " ,
types = " 'Shape' 'Group' " ;
2012-08-09 13:58:02 +06:00
mgr - > insert ( action ( GEOMOp : : OpShow ) , - 1 , - 1 ) ; // display
mgr - > setRule ( action ( GEOMOp : : OpShow ) , rule . arg ( types ) . arg ( " not isVisible " ) , QtxPopupMgr : : VisibleRule ) ;
2005-12-01 15:05:15 +05:00
2012-08-09 13:58:02 +06:00
mgr - > insert ( action ( GEOMOp : : OpHide ) , - 1 , - 1 ) ; // erase
mgr - > setRule ( action ( GEOMOp : : OpHide ) , rule . arg ( types ) . arg ( " isVisible " ) , QtxPopupMgr : : VisibleRule ) ;
2005-12-01 15:05:15 +05:00
2012-08-09 13:58:02 +06:00
mgr - > insert ( action ( GEOMOp : : OpHideAll ) , - 1 , - 1 ) ; // erase All
mgr - > setRule ( action ( GEOMOp : : OpHideAll ) , clientOCCorVTK , QtxPopupMgr : : VisibleRule ) ;
2008-03-07 12:45:34 +05:00
QString selectOnly = " (client='OCCViewer' or client='VTKViewer') and (selcount=0) " ;
2012-08-09 13:58:02 +06:00
int selectonlyId = mgr - > insert ( tr ( " MEN_SELECT_ONLY " ) , - 1 , - 1 ) ; //select only menu
mgr - > insert ( action ( GEOMOp : : OpSelectVertex ) , selectonlyId , - 1 ) ; //Vertex
mgr - > setRule ( action ( GEOMOp : : OpSelectVertex ) , selectOnly , QtxPopupMgr : : VisibleRule ) ;
mgr - > setRule ( action ( GEOMOp : : OpSelectVertex ) , selectOnly + " and selectionmode='VERTEX' " , QtxPopupMgr : : ToggleRule ) ;
mgr - > insert ( action ( GEOMOp : : OpSelectEdge ) , selectonlyId , - 1 ) ; //Edge
mgr - > setRule ( action ( GEOMOp : : OpSelectEdge ) , selectOnly , QtxPopupMgr : : VisibleRule ) ;
mgr - > setRule ( action ( GEOMOp : : OpSelectEdge ) , selectOnly + " and selectionmode='EDGE' " , QtxPopupMgr : : ToggleRule ) ;
mgr - > insert ( action ( GEOMOp : : OpSelectWire ) , selectonlyId , - 1 ) ; //Wire
mgr - > setRule ( action ( GEOMOp : : OpSelectWire ) , selectOnly , QtxPopupMgr : : VisibleRule ) ;
mgr - > setRule ( action ( GEOMOp : : OpSelectWire ) , selectOnly + " and selectionmode='WIRE' " , QtxPopupMgr : : ToggleRule ) ;
mgr - > insert ( action ( GEOMOp : : OpSelectFace ) , selectonlyId , - 1 ) ; //Face
mgr - > setRule ( action ( GEOMOp : : OpSelectFace ) , selectOnly , QtxPopupMgr : : VisibleRule ) ;
mgr - > setRule ( action ( GEOMOp : : OpSelectFace ) , selectOnly + " and selectionmode='FACE' " , QtxPopupMgr : : ToggleRule ) ;
mgr - > insert ( action ( GEOMOp : : OpSelectShell ) , selectonlyId , - 1 ) ; //Shell
mgr - > setRule ( action ( GEOMOp : : OpSelectShell ) , selectOnly , QtxPopupMgr : : VisibleRule ) ;
mgr - > setRule ( action ( GEOMOp : : OpSelectShell ) , selectOnly + " and selectionmode='SHELL' " , QtxPopupMgr : : ToggleRule ) ;
mgr - > insert ( action ( GEOMOp : : OpSelectSolid ) , selectonlyId , - 1 ) ; //Solid
mgr - > setRule ( action ( GEOMOp : : OpSelectSolid ) , selectOnly , QtxPopupMgr : : VisibleRule ) ;
mgr - > setRule ( action ( GEOMOp : : OpSelectSolid ) , selectOnly + " and selectionmode='SOLID' " , QtxPopupMgr : : ToggleRule ) ;
mgr - > insert ( action ( GEOMOp : : OpSelectCompound ) , selectonlyId , - 1 ) ; //Compound
mgr - > setRule ( action ( GEOMOp : : OpSelectCompound ) , selectOnly , QtxPopupMgr : : VisibleRule ) ;
mgr - > setRule ( action ( GEOMOp : : OpSelectCompound ) , selectOnly + " and selectionmode='COMPOUND' " , QtxPopupMgr : : ToggleRule ) ;
mgr - > insert ( separator ( ) , selectonlyId , - 1 ) ;
mgr - > insert ( action ( GEOMOp : : OpSelectAll ) , selectonlyId , - 1 ) ; //Clear selection filter
mgr - > setRule ( action ( GEOMOp : : OpSelectAll ) , selectOnly , QtxPopupMgr : : VisibleRule ) ;
mgr - > setRule ( action ( GEOMOp : : OpSelectAll ) , selectOnly + " and selectionmode='ALL' " , QtxPopupMgr : : ToggleRule ) ;
mgr - > insert ( action ( GEOMOp : : OpShowOnly ) , - 1 , - 1 ) ; // display only
mgr - > setRule ( action ( GEOMOp : : OpShowOnly ) , rule . arg ( types ) . arg ( " true " ) , QtxPopupMgr : : VisibleRule ) ;
2012-10-08 17:16:36 +06:00
mgr - > insert ( action ( GEOMOp : : OpShowOnlyChildren ) , - 1 , - 1 ) ; // display only children
mgr - > setRule ( action ( GEOMOp : : OpShowOnlyChildren ) , ( canDisplay + " and ($type in {%1}) and client='ObjectBrowser' and hasChildren=true " ) . arg ( types ) , QtxPopupMgr : : VisibleRule ) ;
2012-08-09 13:58:02 +06:00
mgr - > insert ( separator ( ) , - 1 , - 1 ) ; // -----------
mgr - > insert ( action ( GEOMOp : : OpUnpublishObject ) , - 1 , - 1 ) ; // Unpublish object
mgr - > setRule ( action ( GEOMOp : : OpUnpublishObject ) , QString ( " client='ObjectBrowser' and $type in {'Shape' 'Group'} and selcount>0 " ) , QtxPopupMgr : : VisibleRule ) ;
mgr - > insert ( action ( GEOMOp : : OpPublishObject ) , - 1 , - 1 ) ; // Publish object
mgr - > setRule ( action ( GEOMOp : : OpPublishObject ) , QString ( " client='ObjectBrowser' and isComponent=true " ) , QtxPopupMgr : : VisibleRule ) ;
mgr - > insert ( action ( GEOMOp : : OpReimport ) , - 1 , - 1 ) ; // delete
mgr - > setRule ( action ( GEOMOp : : OpReimport ) , QString ( " $imported in {'true'} and selcount>0 " ) , QtxPopupMgr : : VisibleRule ) ;
2005-11-09 19:21:30 +05:00
mgr - > hide ( mgr - > actionId ( action ( myEraseAll ) ) ) ;
2012-08-09 13:58:02 +06:00
SUIT_ResourceMgr * resMgr = SUIT_Session : : session ( ) - > resourceMgr ( ) ;
2012-12-13 14:40:36 +06:00
if ( resMgr ) {
2012-08-09 13:58:02 +06:00
GEOM_AISShape : : setTopLevelDisplayMode ( ( GEOM_AISShape : : TopLevelDispMode ) resMgr - > integerValue ( " Geometry " , " toplevel_dm " , 0 ) ) ;
QColor c = resMgr - > colorValue ( " Geometry " , " toplevel_color " , QColor ( 170 , 85 , 0 ) ) ;
GEOM_AISShape : : setTopLevelColor ( SalomeApp_Tools : : color ( c ) ) ;
}
2005-06-02 13:17:09 +06:00
}
//=======================================================================
2006-05-10 20:27:12 +06:00
// function : GeometryGUI::activateModule()
// purpose : Called when GEOM module is activated
2005-06-02 13:17:09 +06:00
//=======================================================================
2005-06-08 18:39:43 +06:00
bool GeometryGUI : : activateModule ( SUIT_Study * study )
2005-06-02 13:17:09 +06:00
{
2005-06-08 18:39:43 +06:00
if ( CORBA : : is_nil ( myComponentGeom ) )
return false ;
bool res = SalomeApp_Module : : activateModule ( study ) ;
if ( ! res )
return false ;
2005-06-02 13:17:09 +06:00
setMenuShown ( true ) ;
setToolShown ( true ) ;
2012-08-09 13:58:02 +06:00
// import Python module that manages GEOM plugins (need to be here because SalomePyQt API uses active module)
PyGILState_STATE gstate = PyGILState_Ensure ( ) ;
2012-12-13 14:40:36 +06:00
PyObject * pluginsmanager = PyImport_ImportModuleNoBlock ( ( char * ) " salome_pluginsmanager " ) ;
if ( pluginsmanager = = NULL )
2012-08-09 13:58:02 +06:00
PyErr_Print ( ) ;
2012-12-13 14:40:36 +06:00
else {
PyObject * result =
PyObject_CallMethod ( pluginsmanager , ( char * ) " initialize " , ( char * ) " isss " , 1 , " geom " ,
tr ( " MEN_NEW_ENTITY " ) . toStdString ( ) . c_str ( ) ,
tr ( " GEOM_PLUGINS_OTHER " ) . toStdString ( ) . c_str ( ) ) ;
if ( result = = NULL )
PyErr_Print ( ) ;
Py_XDECREF ( result ) ;
}
2012-08-09 13:58:02 +06:00
PyGILState_Release ( gstate ) ;
// end of GEOM plugins loading
2006-05-10 20:27:12 +06:00
connect ( application ( ) - > desktop ( ) , SIGNAL ( windowActivated ( SUIT_ViewWindow * ) ) ,
2012-08-09 13:58:02 +06:00
this , SLOT ( onWindowActivated ( SUIT_ViewWindow * ) ) ) ;
2005-06-02 13:17:09 +06:00
2006-05-10 20:27:12 +06:00
// Reset actions accelerator keys
2012-08-09 13:58:02 +06:00
action ( GEOMOp : : OpImport ) - > setEnabled ( true ) ; // Import: CTRL + Key_I
action ( GEOMOp : : OpExport ) - > setEnabled ( true ) ; // Export: CTRL + Key_E
action ( GEOMOp : : OpDelete ) - > setEnabled ( true ) ; // Delete: Key_Delete
2006-05-10 20:27:12 +06:00
2004-12-01 15:39:14 +05:00
GUIMap : : Iterator it ;
2005-06-02 13:17:09 +06:00
for ( it = myGUIMap . begin ( ) ; it ! = myGUIMap . end ( ) ; + + it )
2009-02-13 17:16:39 +05:00
it . value ( ) - > activate ( application ( ) - > desktop ( ) ) ;
2005-06-02 13:17:09 +06:00
2005-11-03 13:30:14 +05:00
LightApp_SelectionMgr * sm = getApp ( ) - > selectionMgr ( ) ;
2009-02-13 17:16:39 +05:00
2013-06-17 18:39:23 +06:00
connect ( sm , SIGNAL ( currentSelectionChanged ( ) ) , this , SLOT ( updateCreationInfo ( ) ) ) ;
if ( ! myCreationInfoWdg )
myCreationInfoWdg = new GEOMGUI_CreationInfoWdg ( getApp ( ) ) ;
getApp ( ) - > insertDockWindow ( myCreationInfoWdg - > getWinID ( ) , myCreationInfoWdg ) ;
getApp ( ) - > placeDockWindow ( myCreationInfoWdg - > getWinID ( ) , Qt : : LeftDockWidgetArea ) ;
2005-06-02 13:17:09 +06:00
SUIT_ViewManager * vm ;
ViewManagerList OCCViewManagers , VTKViewManagers ;
2009-02-13 17:16:39 +05:00
2005-06-02 13:17:09 +06:00
application ( ) - > viewManagers ( OCCViewer_Viewer : : Type ( ) , OCCViewManagers ) ;
2009-02-13 17:16:39 +05:00
QListIterator < SUIT_ViewManager * > itOCC ( OCCViewManagers ) ;
while ( itOCC . hasNext ( ) & & ( vm = itOCC . next ( ) ) )
2005-06-02 13:17:09 +06:00
myOCCSelectors . append ( new GEOMGUI_OCCSelector ( ( ( OCCViewer_ViewManager * ) vm ) - > getOCCViewer ( ) , sm ) ) ;
2009-02-13 17:16:39 +05:00
2005-10-05 12:28:23 +06:00
application ( ) - > viewManagers ( SVTK_Viewer : : Type ( ) , VTKViewManagers ) ;
2009-02-13 17:16:39 +05:00
QListIterator < SUIT_ViewManager * > itVTK ( VTKViewManagers ) ;
while ( itVTK . hasNext ( ) & & ( vm = itVTK . next ( ) ) )
2005-11-03 13:30:14 +05:00
myVTKSelectors . append ( new LightApp_VTKSelector ( dynamic_cast < SVTK_Viewer * > ( vm - > getViewModel ( ) ) , sm ) ) ;
2005-06-02 13:17:09 +06:00
2009-02-13 17:16:39 +05:00
//NPAL 19674
SALOME_ListIO selected ;
sm - > selectedObjects ( selected ) ;
sm - > clearSelected ( ) ;
2012-08-09 13:58:02 +06:00
2005-06-08 15:27:11 +06:00
// disable OCC selectors
2009-02-13 17:16:39 +05:00
getApp ( ) - > selectionMgr ( ) - > setEnabled ( false , OCCViewer_Viewer : : Type ( ) ) ;
QListIterator < GEOMGUI_OCCSelector * > itOCCSel ( myOCCSelectors ) ;
while ( itOCCSel . hasNext ( ) )
if ( GEOMGUI_OCCSelector * sr = itOCCSel . next ( ) )
sr - > setEnabled ( true ) ;
2006-05-10 20:27:12 +06:00
2005-06-08 15:27:11 +06:00
// disable VTK selectors
2009-02-13 17:16:39 +05:00
getApp ( ) - > selectionMgr ( ) - > setEnabled ( false , SVTK_Viewer : : Type ( ) ) ;
QListIterator < LightApp_VTKSelector * > itVTKSel ( myVTKSelectors ) ;
while ( itVTKSel . hasNext ( ) )
if ( LightApp_VTKSelector * sr = itVTKSel . next ( ) )
sr - > setEnabled ( true ) ;
sm - > setSelectedObjects ( selected , true ) ; //NPAL 19674
2006-05-10 20:27:12 +06:00
2012-08-09 13:58:02 +06:00
QMenu * viewMenu = menuMgr ( ) - > findMenu ( STD_Application : : MenuViewId ) ;
if ( viewMenu )
connect ( viewMenu , SIGNAL ( aboutToShow ( ) ) , this , SLOT ( onViewAboutToShow ( ) ) ) ;
// 0020836 (Basic vectors and origin)
SUIT_ResourceMgr * aResourceMgr = SUIT_Session : : session ( ) - > resourceMgr ( ) ;
2012-12-13 14:40:36 +06:00
if ( aResourceMgr - > booleanValue ( " Geometry " , " auto_create_base_objects " , false ) ) {
2012-08-09 13:58:02 +06:00
SalomeApp_Study * appStudy = dynamic_cast < SalomeApp_Study * > ( application ( ) - > activeStudy ( ) ) ;
2012-12-13 14:40:36 +06:00
if ( appStudy ) {
2012-08-09 13:58:02 +06:00
_PTR ( Study ) studyDS = appStudy - > studyDS ( ) ;
2012-12-13 14:40:36 +06:00
if ( studyDS ) {
2012-08-09 13:58:02 +06:00
_PTR ( SComponent ) aSComponent = studyDS - > FindComponent ( " GEOM " ) ;
2012-12-13 14:40:36 +06:00
if ( ! aSComponent ) // create objects automatically only if there is no GEOM component
2012-08-09 13:58:02 +06:00
createOriginAndBaseVectors ( ) ;
}
}
}
2005-06-08 18:39:43 +06:00
return true ;
2005-06-02 13:17:09 +06:00
}
//=======================================================================
2006-05-10 20:27:12 +06:00
// function : GeometryGUI::deactivateModule()
// purpose : Called when GEOM module is deactivated
2005-06-02 13:17:09 +06:00
//=======================================================================
2005-06-08 18:39:43 +06:00
bool GeometryGUI : : deactivateModule ( SUIT_Study * study )
2005-06-02 13:17:09 +06:00
{
2012-08-09 13:58:02 +06:00
QMenu * viewMenu = menuMgr ( ) - > findMenu ( STD_Application : : MenuViewId ) ;
if ( viewMenu )
disconnect ( viewMenu , SIGNAL ( aboutToShow ( ) ) , this , SLOT ( onViewAboutToShow ( ) ) ) ;
2005-06-02 13:17:09 +06:00
setMenuShown ( false ) ;
setToolShown ( false ) ;
2008-03-07 12:45:34 +05:00
disconnect ( application ( ) - > desktop ( ) , SIGNAL ( windowActivated ( SUIT_ViewWindow * ) ) ,
2012-08-09 13:58:02 +06:00
this , SLOT ( onWindowActivated ( SUIT_ViewWindow * ) ) ) ;
2005-06-02 13:17:09 +06:00
2013-06-17 18:39:23 +06:00
LightApp_SelectionMgr * selMrg = getApp ( ) - > selectionMgr ( ) ;
disconnect ( selMrg , SIGNAL ( currentSelectionChanged ( ) ) , this , SLOT ( updateCreationInfo ( ) ) ) ;
getApp ( ) - > removeDockWindow ( myCreationInfoWdg - > getWinID ( ) ) ;
myCreationInfoWdg = 0 ;
2005-06-02 13:17:09 +06:00
EmitSignalCloseAllDialogs ( ) ;
GUIMap : : Iterator it ;
for ( it = myGUIMap . begin ( ) ; it ! = myGUIMap . end ( ) ; + + it )
2009-02-13 17:16:39 +05:00
it . value ( ) - > deactivate ( ) ;
2005-06-02 13:17:09 +06:00
2006-05-10 20:27:12 +06:00
// Unset actions accelerator keys
2012-08-09 13:58:02 +06:00
action ( GEOMOp : : OpImport ) - > setEnabled ( false ) ; // Import: CTRL + Key_I
action ( GEOMOp : : OpExport ) - > setEnabled ( false ) ; // Export: CTRL + Key_E
action ( GEOMOp : : OpDelete ) - > setEnabled ( false ) ; // Delete: Key_Delete
2006-05-10 20:27:12 +06:00
2009-02-13 17:16:39 +05:00
qDeleteAll ( myOCCSelectors ) ;
2005-06-02 13:17:09 +06:00
myOCCSelectors . clear ( ) ;
2013-06-17 18:39:23 +06:00
selMrg - > setEnabled ( true , OCCViewer_Viewer : : Type ( ) ) ;
2005-06-02 13:17:09 +06:00
2009-02-13 17:16:39 +05:00
qDeleteAll ( myVTKSelectors ) ;
2005-06-02 13:17:09 +06:00
myVTKSelectors . clear ( ) ;
2013-06-17 18:39:23 +06:00
selMrg - > setEnabled ( true , SVTK_Viewer : : Type ( ) ) ;
2005-06-02 13:17:09 +06:00
2005-06-08 18:39:43 +06:00
return SalomeApp_Module : : deactivateModule ( study ) ;
2004-12-01 15:39:14 +05:00
}
2003-05-12 21:24:23 +06:00
2005-06-02 13:17:09 +06:00
//=======================================================================
2006-05-10 20:27:12 +06:00
// function : onWindowActivated()
2005-06-02 13:17:09 +06:00
// purpose : update menu items' status - disable non-OCC-viewer-compatible actions
//=======================================================================
void GeometryGUI : : onWindowActivated ( SUIT_ViewWindow * win )
{
if ( ! win )
return ;
2003-05-12 21:24:23 +06:00
2005-06-02 13:17:09 +06:00
const bool ViewOCC = ( win - > getViewManager ( ) - > getType ( ) = = OCCViewer_Viewer : : Type ( ) ) ;
2009-02-13 17:16:39 +05:00
//const bool ViewVTK = ( win->getViewManager()->getType() == SVTK_Viewer::Type() );
2008-03-07 12:45:34 +05:00
2005-06-02 13:17:09 +06:00
// disable non-OCC viewframe menu commands
2012-08-09 13:58:02 +06:00
// action( GEOMOp::Op2dSketcher )->setEnabled( ViewOCC ); // SKETCHER
action ( GEOMOp : : OpSuppressFaces ) - > setEnabled ( ViewOCC ) ; // SuppressFace
action ( GEOMOp : : OpSuppressHoles ) - > setEnabled ( ViewOCC ) ; // SuppressHole
action ( GEOMOp : : OpCloseContour ) - > setEnabled ( ViewOCC ) ; // CloseContour
action ( GEOMOp : : OpRemoveIntWires ) - > setEnabled ( ViewOCC ) ; // RemoveInternalWires
action ( GEOMOp : : OpAddPointOnEdge ) - > setEnabled ( ViewOCC ) ; // AddPointOnEdge
// action( GEOMOp::OpFreeBoundaries )->setEnabled( ViewOCC ); // Free boundaries
action ( GEOMOp : : OpGroupCreate ) - > setEnabled ( ViewOCC ) ; // Create Group
action ( GEOMOp : : OpGroupEdit ) - > setEnabled ( ViewOCC ) ; // Edit Group
action ( GEOMOp : : OpMultiTransform ) - > setEnabled ( ViewOCC ) ; // MENU BLOCKS - MULTI-TRANSFORMATION
2005-06-02 13:17:09 +06:00
}
2004-01-07 20:46:21 +05:00
2005-06-02 13:17:09 +06:00
void GeometryGUI : : windows ( QMap < int , int > & mappa ) const
{
2009-02-13 17:16:39 +05:00
mappa . insert ( SalomeApp_Application : : WT_ObjectBrowser , Qt : : LeftDockWidgetArea ) ;
mappa . insert ( SalomeApp_Application : : WT_PyConsole , Qt : : BottomDockWidgetArea ) ;
2013-06-17 18:39:23 +06:00
if ( myCreationInfoWdg )
mappa . insert ( myCreationInfoWdg - > getWinID ( ) , Qt : : LeftDockWidgetArea ) ;
2005-06-02 13:17:09 +06:00
}
2004-06-16 21:24:55 +06:00
2005-06-02 13:17:09 +06:00
void GeometryGUI : : viewManagers ( QStringList & lst ) const
{
lst . append ( OCCViewer_Viewer : : Type ( ) ) ;
}
2004-06-16 21:24:55 +06:00
2005-06-02 13:17:09 +06:00
void GeometryGUI : : onViewManagerAdded ( SUIT_ViewManager * vm )
{
2012-08-09 13:58:02 +06:00
if ( vm & & vm - > getType ( ) = = OCCViewer_Viewer : : Type ( ) )
2005-06-02 13:17:09 +06:00
{
2006-03-13 20:11:51 +05:00
qDebug ( " connect " ) ;
connect ( vm , SIGNAL ( keyPress ( SUIT_ViewWindow * , QKeyEvent * ) ) ,
2012-08-09 13:58:02 +06:00
this , SLOT ( OnKeyPress ( SUIT_ViewWindow * , QKeyEvent * ) ) ) ;
2006-03-13 20:11:51 +05:00
connect ( vm , SIGNAL ( mousePress ( SUIT_ViewWindow * , QMouseEvent * ) ) ,
2012-08-09 13:58:02 +06:00
this , SLOT ( OnMousePress ( SUIT_ViewWindow * , QMouseEvent * ) ) ) ;
2006-03-13 20:11:51 +05:00
connect ( vm , SIGNAL ( mouseMove ( SUIT_ViewWindow * , QMouseEvent * ) ) ,
2012-08-09 13:58:02 +06:00
this , SLOT ( OnMouseMove ( SUIT_ViewWindow * , QMouseEvent * ) ) ) ;
connect ( vm , SIGNAL ( mouseRelease ( SUIT_ViewWindow * , QMouseEvent * ) ) ,
this , SLOT ( OnMouseRelease ( SUIT_ViewWindow * , QMouseEvent * ) ) ) ;
2012-12-13 14:40:36 +06:00
2005-11-03 13:30:14 +05:00
LightApp_SelectionMgr * sm = getApp ( ) - > selectionMgr ( ) ;
2005-06-02 13:17:09 +06:00
myOCCSelectors . append ( new GEOMGUI_OCCSelector ( ( ( OCCViewer_ViewManager * ) vm ) - > getOCCViewer ( ) , sm ) ) ;
2005-06-08 15:27:11 +06:00
// disable OCC selectors
getApp ( ) - > selectionMgr ( ) - > setEnabled ( false , OCCViewer_Viewer : : Type ( ) ) ;
2009-02-13 17:16:39 +05:00
QListIterator < GEOMGUI_OCCSelector * > itOCCSel ( myOCCSelectors ) ;
while ( itOCCSel . hasNext ( ) )
if ( GEOMGUI_OCCSelector * sr = itOCCSel . next ( ) )
2012-08-09 13:58:02 +06:00
sr - > setEnabled ( true ) ;
2005-06-02 13:17:09 +06:00
}
2005-10-05 12:28:23 +06:00
else if ( vm - > getType ( ) = = SVTK_Viewer : : Type ( ) )
2005-06-02 13:17:09 +06:00
{
2005-11-03 13:30:14 +05:00
LightApp_SelectionMgr * sm = getApp ( ) - > selectionMgr ( ) ;
myVTKSelectors . append ( new LightApp_VTKSelector ( dynamic_cast < SVTK_Viewer * > ( vm - > getViewModel ( ) ) , sm ) ) ;
2005-06-08 15:27:11 +06:00
// disable VTK selectors
2005-10-05 12:28:23 +06:00
getApp ( ) - > selectionMgr ( ) - > setEnabled ( false , SVTK_Viewer : : Type ( ) ) ;
2009-02-13 17:16:39 +05:00
QListIterator < LightApp_VTKSelector * > itVTKSel ( myVTKSelectors ) ;
while ( itVTKSel . hasNext ( ) )
if ( LightApp_VTKSelector * sr = itVTKSel . next ( ) )
2012-08-09 13:58:02 +06:00
sr - > setEnabled ( true ) ;
2005-06-02 13:17:09 +06:00
}
2003-05-12 21:24:23 +06:00
}
2005-06-02 13:17:09 +06:00
void GeometryGUI : : onViewManagerRemoved ( SUIT_ViewManager * vm )
{
SUIT_ViewModel * viewer = vm - > getViewModel ( ) ;
if ( vm - > getType ( ) = = OCCViewer_Viewer : : Type ( ) )
{
2009-02-13 17:16:39 +05:00
QListIterator < GEOMGUI_OCCSelector * > itOCCSel ( myOCCSelectors ) ;
while ( itOCCSel . hasNext ( ) )
if ( GEOMGUI_OCCSelector * sr = itOCCSel . next ( ) )
2012-08-09 13:58:02 +06:00
if ( sr - > viewer ( ) = = viewer )
{
2013-02-12 17:35:16 +06:00
/*delete*/ myOCCSelectors . takeAt ( myOCCSelectors . indexOf ( sr ) ) ;
2012-08-09 13:58:02 +06:00
break ;
}
2005-06-02 13:17:09 +06:00
}
2005-10-05 12:28:23 +06:00
if ( vm - > getType ( ) = = SVTK_Viewer : : Type ( ) )
2005-06-02 13:17:09 +06:00
{
2009-02-13 17:16:39 +05:00
QListIterator < LightApp_VTKSelector * > itVTKSel ( myVTKSelectors ) ;
while ( itVTKSel . hasNext ( ) )
if ( LightApp_VTKSelector * sr = itVTKSel . next ( ) )
2012-08-09 13:58:02 +06:00
if ( sr - > viewer ( ) = = viewer )
{
2013-02-12 17:35:16 +06:00
/*delete*/ myVTKSelectors . takeAt ( myVTKSelectors . indexOf ( sr ) ) ;
2012-08-09 13:58:02 +06:00
break ;
}
2005-06-02 13:17:09 +06:00
}
}
2013-06-17 18:39:23 +06:00
//================================================================================
/*!
* \ brief Slot called when selection changed . Shows creation info of a selected object
*/
//================================================================================
void GeometryGUI : : updateCreationInfo ( )
{
myCreationInfoWdg - > clear ( ) ;
// Code below is commented to have myCreationInfoWdg filled as soon as it is shown again
// if ( !myCreationInfoWdg->isVisible() )
// return;
// look for a sole selected GEOM_Object
GEOM : : GEOM_Object_var geomObj ;
SALOME_ListIO selected ;
getApp ( ) - > selectionMgr ( ) - > selectedObjects ( selected ) ;
_PTR ( Study ) study = dynamic_cast < SalomeApp_Study * > ( getApp ( ) - > activeStudy ( ) ) - > studyDS ( ) ;
SALOME_ListIteratorOfListIO selIt ( selected ) ;
for ( ; selIt . More ( ) ; selIt . Next ( ) )
{
Handle ( SALOME_InteractiveObject ) io = selIt . Value ( ) ;
if ( ! io - > hasEntry ( ) ) continue ;
_PTR ( SObject ) sobj = study - > FindObjectID ( io - > getEntry ( ) ) ;
if ( ! sobj ) continue ;
CORBA : : Object_var obj = GeometryGUI : : ClientSObjectToObject ( sobj ) ;
GEOM : : GEOM_Object_var gobj = GEOM : : GEOM_Object : : _narrow ( obj ) ;
if ( ! gobj - > _is_nil ( ) )
{
if ( ! geomObj - > _is_nil ( ) )
return ; // several GEOM objects selected
geomObj = gobj ;
}
}
if ( geomObj - > _is_nil ( ) ) return ;
// pass creation info of geomObj to myCreationInfoWdg
QPixmap icon ;
QString operationName ;
myCreationInfoWdg - > setOperation ( icon , operationName ) ;
try
{
OCC_CATCH_SIGNALS ;
GEOM : : CreationInformation_var info = geomObj - > GetCreationInformation ( ) ;
if ( & info . in ( ) )
{
SUIT_ResourceMgr * resMgr = SUIT_Session : : session ( ) - > resourceMgr ( ) ;
QString name = info - > operationName . in ( ) ;
if ( ! name . isEmpty ( ) )
{
icon = resMgr - > loadPixmap ( " GEOM " , tr ( ( " ICO_ " + name ) . toLatin1 ( ) . constData ( ) ) , false ) ;
operationName = tr ( ( " MEN_ " + name ) . toLatin1 ( ) . constData ( ) ) ;
if ( operationName . startsWith ( " MEN_ " ) )
operationName = name ; // no translation
myCreationInfoWdg - > setOperation ( icon , operationName ) ;
for ( size_t i = 0 ; i < info - > params . length ( ) ; + + i )
myCreationInfoWdg - > addParam ( info - > params [ i ] . name . in ( ) ,
info - > params [ i ] . value . in ( ) ) ;
}
}
}
catch ( . . . )
{
}
}
2005-06-02 13:17:09 +06:00
QString GeometryGUI : : engineIOR ( ) const
2003-05-12 21:24:23 +06:00
{
2005-06-02 13:17:09 +06:00
if ( ! CORBA : : is_nil ( GetGeomGen ( ) ) )
return QString ( getApp ( ) - > orb ( ) - > object_to_string ( GetGeomGen ( ) ) ) ;
2009-02-13 17:16:39 +05:00
return " " ;
2003-05-12 21:24:23 +06:00
}
2012-08-09 13:58:02 +06:00
# if OCC_VERSION_LARGE > 0x06040000 // Porting to OCCT6.5.1
Handle ( TColStd_HArray1OfByte ) GeometryGUI : : getTexture
# else
Handle ( Graphic3d_HArray1OfBytes ) GeometryGUI : : getTexture
# endif
( SalomeApp_Study * theStudy , int theId , int & theWidth , int & theHeight )
{
theWidth = theHeight = 0 ;
# if OCC_VERSION_LARGE > 0x06040000 // Porting to OCCT6.5.1
Handle ( TColStd_HArray1OfByte ) aTexture ;
# else
Handle ( Graphic3d_HArray1OfBytes ) aTexture ;
# endif
if ( theStudy ) {
TextureMap aTextureMap = myTextureMap [ theStudy - > studyDS ( ) - > StudyId ( ) ] ;
aTexture = aTextureMap [ theId ] ;
if ( aTexture . IsNull ( ) ) {
GEOM : : GEOM_IInsertOperations_var aInsOp = GeometryGUI : : GetGeomGen ( ) - > GetIInsertOperations ( theStudy - > studyDS ( ) - > StudyId ( ) ) ;
if ( ! aInsOp - > _is_nil ( ) ) {
CORBA : : Long aWidth , aHeight ;
SALOMEDS : : TMPFile_var aStream = aInsOp - > GetTexture ( theId , aWidth , aHeight ) ;
if ( aWidth > 0 & & aHeight > 0 & & aStream - > length ( ) > 0 ) {
theWidth = aWidth ;
theHeight = aHeight ;
# if OCC_VERSION_LARGE > 0x06040000 // Porting to OCCT6.5.1
aTexture = new TColStd_HArray1OfByte ( 1 , aStream - > length ( ) ) ;
# else
aTexture = new Graphic3d_HArray1OfBytes ( 1 , aStream - > length ( ) ) ;
# endif
for ( int i = 0 ; i < aStream - > length ( ) ; i + + )
aTexture - > SetValue ( i + 1 , ( Standard_Byte ) aStream [ i ] ) ;
aTextureMap [ theId ] = aTexture ;
}
}
}
}
return aTexture ;
}
2005-11-03 13:30:14 +05:00
LightApp_Selection * GeometryGUI : : createSelection ( ) const
2003-05-12 21:24:23 +06:00
{
2005-06-02 13:17:09 +06:00
return new GEOMGUI_Selection ( ) ;
2004-06-16 21:24:55 +06:00
}
2005-06-02 13:17:09 +06:00
2009-02-13 17:16:39 +05:00
void GeometryGUI : : contextMenuPopup ( const QString & client , QMenu * menu , QString & title )
2005-06-03 16:41:52 +06:00
{
2012-08-09 13:58:02 +06:00
SalomeApp_Module : : contextMenuPopup ( client , menu , title ) ;
2005-06-03 16:41:52 +06:00
SALOME_ListIO lst ;
2012-10-08 17:16:36 +06:00
getApp ( ) - > selectionMgr ( ) - > selectedObjects ( lst ) ;
2013-02-12 17:35:16 +06:00
//Add submenu for predefined materials
bool isPredefMat = SUIT_Session : : session ( ) - > resourceMgr ( ) - > booleanValue ( " Geometry " , " predef_materials " ) ;
if ( ( client = = " OCCViewer " | | client = = " VTKViewer " ) & & lst . Extent ( ) > 0 ) {
QtxPopupMgr * mgr = popupMgr ( ) ;
//get parrent for submenu
QAction * act = mgr - > action ( mgr - > actionId ( action ( GEOMOp : : OpMaterialProperties ) ) ) ;
//Clear old menu
QMenu * oldMenu = act - > menu ( ) ;
if ( oldMenu ) {
delete oldMenu ;
}
if ( isPredefMat ) {
QMenu * matMenu = new QMenu ( ) ;
QSignalMapper * signalMapper = new QSignalMapper ( matMenu ) ;
//Get current material model for the object
QVariant v ;
LightApp_Application * anApp = dynamic_cast < LightApp_Application * > ( getApp ( ) ) ;
if ( anApp & & anApp - > activeViewManager ( ) ) {
LightApp_Study * aStudy = dynamic_cast < LightApp_Study * > ( anApp - > activeStudy ( ) ) ;
if ( aStudy ) {
v = aStudy - > getObjectProperty ( anApp - > activeViewManager ( ) - > getGlobalId ( ) , lst . Last ( ) - > getEntry ( ) , GEOM : : propertyName ( GEOM : : Material ) , QVariant ( ) ) ;
}
}
QString curModel = " " ;
if ( v . canConvert < QString > ( ) ) curModel = v . toString ( ) ;
// get list of all predefined materials
QStringList materials = Material_ResourceMgr : : resourceMgr ( ) - > materials ( ) ;
bool found = false ;
foreach ( QString material , materials )
{
QAction * menAct = matMenu - > addAction ( material ) ;
connect ( menAct , SIGNAL ( toggled ( bool ) ) , signalMapper , SLOT ( map ( ) ) ) ;
signalMapper - > setMapping ( menAct , material ) ;
menAct - > setCheckable ( true ) ;
// Set checked if this material is current
Material_Model aModel ;
aModel . fromResources ( material ) ;
2013-06-17 18:39:23 +06:00
if ( ! found & & aModel . toProperties ( ) = = curModel ) {
menAct - > setChecked ( true ) ;
found = true ;
}
2013-02-12 17:35:16 +06:00
}
matMenu - > insertAction ( matMenu - > addSeparator ( ) , action ( GEOMOp : : OpPredefMaterCustom ) ) ;
matMenu - > insertSeparator ( action ( GEOMOp : : OpPredefMaterCustom ) ) ;
connect ( signalMapper , SIGNAL ( mapped ( const QString & ) ) ,
this , SLOT ( OnSetMaterial ( const QString & ) ) ) ;
act - > setMenu ( matMenu ) ;
}
}
//Set name
2012-10-08 17:16:36 +06:00
if ( ( client = = " OCCViewer " | | client = = " VTKViewer " ) & & lst . Extent ( ) = = 1 ) {
Handle ( SALOME_InteractiveObject ) io = lst . First ( ) ;
SalomeApp_Study * appStudy = dynamic_cast < SalomeApp_Study * > ( application ( ) - > activeStudy ( ) ) ;
_PTR ( Study ) study = appStudy - > studyDS ( ) ;
_PTR ( SObject ) obj = study - > FindObjectID ( io - > getEntry ( ) ) ;
if ( obj ) {
QString aName = QString ( obj - > GetName ( ) . c_str ( ) ) ;
aName . remove ( QRegExp ( " \\ s+$ " ) ) ;
title = aName ;
2009-02-13 17:16:39 +05:00
}
}
2005-06-03 16:41:52 +06:00
}
2005-06-22 12:29:29 +06:00
2013-02-12 17:35:16 +06:00
void GeometryGUI : : OnSetMaterial ( const QString & theName )
{
OnGUIEvent ( GEOMOp : : OpPredefMaterial , QVariant ( theName ) ) ;
}
2005-06-22 12:29:29 +06:00
void GeometryGUI : : createPreferences ( )
{
int tabId = addPreference ( tr ( " PREF_TAB_SETTINGS " ) ) ;
int genGroup = addPreference ( tr ( " PREF_GROUP_GENERAL " ) , tabId ) ;
2009-02-13 17:16:39 +05:00
setPreferenceProperty ( genGroup , " columns " , 2 ) ;
2008-03-07 12:45:34 +05:00
int dispmode = addPreference ( tr ( " PREF_DISPLAY_MODE " ) , genGroup ,
2012-08-09 13:58:02 +06:00
LightApp_Preferences : : Selector ,
" Geometry " , " display_mode " ) ;
2008-03-07 12:45:34 +05:00
2005-06-22 12:29:29 +06:00
addPreference ( tr ( " PREF_SHADING_COLOR " ) , genGroup ,
2012-08-09 13:58:02 +06:00
LightApp_Preferences : : Color , " Geometry " , " shading_color " ) ;
addPreference ( tr ( " PREF_EDGES_IN_SHADING " ) , genGroup ,
LightApp_Preferences : : Color , " Geometry " , " edges_in_shading_color " ) ;
2008-03-07 12:45:34 +05:00
addPreference ( tr ( " PREF_WIREFRAME_COLOR " ) , genGroup ,
2012-08-09 13:58:02 +06:00
LightApp_Preferences : : Color , " Geometry " , " wireframe_color " ) ;
2008-03-07 12:45:34 +05:00
addPreference ( tr ( " PREF_FREE_BOUND_COLOR " ) , genGroup ,
2012-08-09 13:58:02 +06:00
LightApp_Preferences : : Color , " Geometry " , " free_bound_color " ) ;
2008-03-07 12:45:34 +05:00
addPreference ( tr ( " PREF_LINE_COLOR " ) , genGroup ,
2012-08-09 13:58:02 +06:00
LightApp_Preferences : : Color , " Geometry " , " line_color " ) ;
2008-03-07 12:45:34 +05:00
addPreference ( tr ( " PREF_POINT_COLOR " ) , genGroup ,
2012-08-09 13:58:02 +06:00
LightApp_Preferences : : Color , " Geometry " , " point_color " ) ;
2008-03-07 12:45:34 +05:00
addPreference ( tr ( " PREF_ISOS_COLOR " ) , genGroup ,
2012-08-09 13:58:02 +06:00
LightApp_Preferences : : Color , " Geometry " , " isos_color " ) ;
addPreference ( tr ( " PREF_TOPLEVEL_COLOR " ) , genGroup ,
LightApp_Preferences : : Color , " Geometry " , " toplevel_color " ) ;
int top_lev_dm = addPreference ( tr ( " PREF_TOPLEVEL_DM " ) , genGroup ,
LightApp_Preferences : : Selector , " Geometry " , " toplevel_dm " ) ;
2008-03-07 12:45:34 +05:00
2005-06-22 15:58:12 +06:00
int step = addPreference ( tr ( " PREF_STEP_VALUE " ) , genGroup ,
2012-08-09 13:58:02 +06:00
LightApp_Preferences : : IntSpin , " Geometry " , " SettingsGeomStep " ) ;
int defl = addPreference ( tr ( " PREF_DEFLECTION " ) , genGroup ,
LightApp_Preferences : : DblSpin , " Geometry " , " deflection_coeff " ) ;
2013-02-12 17:35:16 +06:00
addPreference ( tr ( " PREF_PREDEF_MATERIALS " ) , genGroup ,
2013-06-17 18:39:23 +06:00
LightApp_Preferences : : Bool , " Geometry " , " predef_materials " ) ;
2013-02-12 17:35:16 +06:00
2012-08-09 13:58:02 +06:00
int material = addPreference ( tr ( " PREF_MATERIAL " ) , genGroup ,
2013-06-17 18:39:23 +06:00
LightApp_Preferences : : Selector ,
" Geometry " , " material " ) ;
2013-02-12 17:35:16 +06:00
addPreference ( tr ( " PREF_EDITGROUP_COLOR " ) , genGroup ,
LightApp_Preferences : : Color , " Geometry " , " editgroup_color " ) ;
2012-12-13 14:40:36 +06:00
2012-08-09 13:58:02 +06:00
const int nb = 4 ;
int wd [ nb ] ;
int iter = 0 ;
wd [ iter + + ] = addPreference ( tr ( " PREF_EDGE_WIDTH " ) , genGroup ,
2012-12-13 14:40:36 +06:00
LightApp_Preferences : : IntSpin , " Geometry " , " edge_width " ) ;
2012-08-09 13:58:02 +06:00
wd [ iter + + ] = addPreference ( tr ( " PREF_ISOLINES_WIDTH " ) , genGroup ,
2012-12-13 14:40:36 +06:00
LightApp_Preferences : : IntSpin , " Geometry " , " isolines_width " ) ;
2012-08-09 13:58:02 +06:00
wd [ iter + + ] = addPreference ( tr ( " PREF_PREVIEW_EDGE_WIDTH " ) , genGroup ,
2012-12-13 14:40:36 +06:00
LightApp_Preferences : : IntSpin , " Geometry " , " preview_edge_width " ) ;
2012-08-09 13:58:02 +06:00
wd [ iter + + ] = addPreference ( tr ( " PREF_MEASURES_LINE_WIDTH " ) , genGroup ,
2012-12-13 14:40:36 +06:00
LightApp_Preferences : : IntSpin , " Geometry " , " measures_line_width " ) ;
2012-08-09 13:58:02 +06:00
2012-12-13 14:40:36 +06:00
for ( int i = 0 ; i < nb ; i + + ) {
setPreferenceProperty ( wd [ i ] , " min " , 1 ) ;
2012-08-09 13:58:02 +06:00
setPreferenceProperty ( wd [ i ] , " max " , 5 ) ;
}
2013-02-12 17:35:16 +06:00
int isoGroup = addPreference ( tr ( " PREF_ISOS " ) , tabId ) ;
setPreferenceProperty ( isoGroup , " columns " , 2 ) ;
int isoU = addPreference ( tr ( " PREF_ISOS_U " ) , isoGroup ,
LightApp_Preferences : : IntSpin , " Geometry " , " iso_number_u " ) ;
setPreferenceProperty ( isoU , " min " , 0 ) ;
setPreferenceProperty ( isoU , " max " , 100000 ) ;
int isoV = addPreference ( tr ( " PREF_ISOS_V " ) , isoGroup ,
LightApp_Preferences : : IntSpin , " Geometry " , " iso_number_v " ) ;
setPreferenceProperty ( isoV , " min " , 0 ) ;
setPreferenceProperty ( isoV , " max " , 100000 ) ;
2012-08-09 13:58:02 +06:00
// Quantities with individual precision settings
int precGroup = addPreference ( tr ( " GEOM_PREF_GROUP_PRECISION " ) , tabId ) ;
setPreferenceProperty ( precGroup , " columns " , 2 ) ;
const int nbQuantities = 8 ;
int prec [ nbQuantities ] , ii = 0 ;
prec [ ii + + ] = addPreference ( tr ( " GEOM_PREF_length_precision " ) , precGroup ,
LightApp_Preferences : : IntSpin , " Geometry " , " length_precision " ) ;
prec [ ii + + ] = addPreference ( tr ( " GEOM_PREF_angle_precision " ) , precGroup ,
LightApp_Preferences : : IntSpin , " Geometry " , " angle_precision " ) ;
prec [ ii + + ] = addPreference ( tr ( " GEOM_PREF_len_tol_precision " ) , precGroup ,
LightApp_Preferences : : IntSpin , " Geometry " , " len_tol_precision " ) ;
prec [ ii + + ] = addPreference ( tr ( " GEOM_PREF_ang_tol_precision " ) , precGroup ,
LightApp_Preferences : : IntSpin , " Geometry " , " ang_tol_precision " ) ;
prec [ ii + + ] = addPreference ( tr ( " GEOM_PREF_weight_precision " ) , precGroup ,
LightApp_Preferences : : IntSpin , " Geometry " , " weight_precision " ) ;
prec [ ii + + ] = addPreference ( tr ( " GEOM_PREF_density_precision " ) , precGroup ,
LightApp_Preferences : : IntSpin , " Geometry " , " density_precision " ) ;
prec [ ii + + ] = addPreference ( tr ( " GEOM_PREF_parametric_precision " ) , precGroup ,
LightApp_Preferences : : IntSpin , " Geometry " , " parametric_precision " ) ;
prec [ ii ] = addPreference ( tr ( " GEOM_PREF_param_tol_precision " ) , precGroup ,
LightApp_Preferences : : IntSpin , " Geometry " , " param_tol_precision " ) ;
// Set property for precision value for spinboxes
for ( ii = 0 ; ii < nbQuantities ; ii + + ) {
setPreferenceProperty ( prec [ ii ] , " min " , - 14 ) ;
setPreferenceProperty ( prec [ ii ] , " max " , 14 ) ;
setPreferenceProperty ( prec [ ii ] , " precision " , 2 ) ;
}
2005-06-22 15:58:12 +06:00
2008-03-07 12:45:34 +05:00
int VertexGroup = addPreference ( tr ( " PREF_GROUP_VERTEX " ) , tabId ) ;
2009-02-13 17:16:39 +05:00
setPreferenceProperty ( VertexGroup , " columns " , 2 ) ;
2005-06-22 15:58:12 +06:00
2008-03-07 12:45:34 +05:00
int typeOfMarker = addPreference ( tr ( " PREF_TYPE_OF_MARKER " ) , VertexGroup ,
LightApp_Preferences : : Selector , " Geometry " , " type_of_marker " ) ;
int markerScale = addPreference ( tr ( " PREF_MARKER_SCALE " ) , VertexGroup ,
2012-08-09 13:58:02 +06:00
LightApp_Preferences : : Selector , " Geometry " , " marker_scale " ) ;
2005-07-06 18:42:51 +06:00
// Set property for default display mode
QStringList aModesList ;
aModesList . append ( tr ( " MEN_WIREFRAME " ) ) ;
aModesList . append ( tr ( " MEN_SHADING " ) ) ;
2012-08-09 13:58:02 +06:00
aModesList . append ( tr ( " MEN_SHADING_WITH_EDGES " ) ) ;
2008-03-07 12:45:34 +05:00
2009-02-13 17:16:39 +05:00
QList < QVariant > anIndexesList ;
2005-07-06 18:42:51 +06:00
anIndexesList . append ( 0 ) ;
anIndexesList . append ( 1 ) ;
2012-08-09 13:58:02 +06:00
anIndexesList . append ( 2 ) ;
2008-03-07 12:45:34 +05:00
2005-07-06 18:42:51 +06:00
setPreferenceProperty ( dispmode , " strings " , aModesList ) ;
setPreferenceProperty ( dispmode , " indexes " , anIndexesList ) ;
2008-03-07 12:45:34 +05:00
2012-08-09 13:58:02 +06:00
// Set property for top level display mode
QStringList aTopModesList ;
aTopModesList . append ( tr ( " MEN_SHOW_ADD_WACTOR " ) ) ;
aTopModesList . append ( tr ( " MEN_KEEP_CURRENT_DM " ) ) ;
aTopModesList . append ( tr ( " MEN_WIREFRAME " ) ) ;
aTopModesList . append ( tr ( " MEN_SHADING " ) ) ;
aTopModesList . append ( tr ( " MEN_SHADING_WITH_EDGES " ) ) ;
QList < QVariant > aTopIndexesList ;
aTopIndexesList . append ( 0 ) ;
aTopIndexesList . append ( 1 ) ;
aTopIndexesList . append ( 2 ) ;
aTopIndexesList . append ( 3 ) ;
aTopIndexesList . append ( 4 ) ;
setPreferenceProperty ( top_lev_dm , " strings " , aTopModesList ) ;
setPreferenceProperty ( top_lev_dm , " indexes " , aTopIndexesList ) ;
2008-03-07 12:45:34 +05:00
// Set property for step value for spinboxes
2009-02-13 17:16:39 +05:00
setPreferenceProperty ( step , " min " , 1 ) ;
2008-03-07 12:45:34 +05:00
setPreferenceProperty ( step , " max " , 10000 ) ;
setPreferenceProperty ( step , " precision " , 3 ) ;
2012-08-09 13:58:02 +06:00
// Set property for deflection value for spinboxes
2013-02-12 17:35:16 +06:00
setPreferenceProperty ( defl , " min " , GEOM : : minDeflection ( ) ) ;
2012-08-09 13:58:02 +06:00
setPreferenceProperty ( defl , " max " , 1.0 ) ;
setPreferenceProperty ( defl , " step " , 1.0e-04 ) ;
setPreferenceProperty ( defl , " precision " , 6 ) ;
2008-03-07 12:45:34 +05:00
2012-08-09 13:58:02 +06:00
// Set property for default material
2013-02-12 17:35:16 +06:00
setPreferenceProperty ( material , " strings " , Material_ResourceMgr : : resourceMgr ( ) - > materials ( ) ) ;
2012-08-09 13:58:02 +06:00
// Set property vertex marker type
QList < QVariant > aMarkerTypeIndicesList ;
QList < QVariant > aMarkerTypeIconsList ;
2008-03-07 12:45:34 +05:00
2012-08-09 13:58:02 +06:00
SUIT_ResourceMgr * resMgr = SUIT_Session : : session ( ) - > resourceMgr ( ) ;
for ( int i = GEOM : : MT_POINT ; i < GEOM : : MT_USER ; i + + ) {
QString icoFile = QString ( " ICON_VERTEX_MARKER_%1 " ) . arg ( i ) ;
QPixmap pixmap = resMgr - > loadPixmap ( " GEOM " , tr ( qPrintable ( icoFile ) ) ) ;
aMarkerTypeIndicesList < < ( i - 1 ) ;
aMarkerTypeIconsList < < pixmap ;
}
2008-03-07 12:45:34 +05:00
2012-08-09 13:58:02 +06:00
setPreferenceProperty ( typeOfMarker , " indexes " , aMarkerTypeIndicesList ) ;
setPreferenceProperty ( typeOfMarker , " icons " , aMarkerTypeIconsList ) ;
2008-03-07 12:45:34 +05:00
2012-08-09 13:58:02 +06:00
// Set property for vertex marker scale
QList < QVariant > aMarkerScaleIndicesList ;
QStringList aMarkerScaleValuesList ;
2008-03-07 12:45:34 +05:00
2012-08-09 13:58:02 +06:00
for ( int iii = GEOM : : MS_10 ; iii < = GEOM : : MS_70 ; iii + + ) {
aMarkerScaleIndicesList < < iii ;
aMarkerScaleValuesList < < QString : : number ( ( iii - ( int ) GEOM : : MS_10 ) * 0.5 + 1.0 ) ;
}
2008-03-07 12:45:34 +05:00
2012-08-09 13:58:02 +06:00
setPreferenceProperty ( markerScale , " strings " , aMarkerScaleValuesList ) ;
setPreferenceProperty ( markerScale , " indexes " , aMarkerScaleIndicesList ) ;
2008-03-07 12:45:34 +05:00
2012-08-09 13:58:02 +06:00
int originGroup = addPreference ( tr ( " PREF_GROUP_ORIGIN_AND_BASE_VECTORS " ) , tabId ) ;
setPreferenceProperty ( originGroup , " columns " , 2 ) ;
2008-03-07 12:45:34 +05:00
2012-08-09 13:58:02 +06:00
int baseVectorsLength = addPreference ( tr ( " PREF_BASE_VECTORS_LENGTH " ) , originGroup ,
LightApp_Preferences : : DblSpin , " Geometry " , " base_vectors_length " ) ;
setPreferenceProperty ( baseVectorsLength , " min " , 0.01 ) ;
setPreferenceProperty ( baseVectorsLength , " max " , 1000 ) ;
2008-03-07 12:45:34 +05:00
2012-08-09 13:58:02 +06:00
addPreference ( tr ( " PREF_AUTO_CREATE " ) , originGroup ,
LightApp_Preferences : : Bool , " Geometry " , " auto_create_base_objects " ) ;
2008-03-07 12:45:34 +05:00
2012-08-09 13:58:02 +06:00
int operationsGroup = addPreference ( tr ( " PREF_GROUP_OPERATIONS " ) , tabId ) ;
setPreferenceProperty ( operationsGroup , " columns " , 2 ) ;
2008-03-07 12:45:34 +05:00
2012-08-09 13:58:02 +06:00
addPreference ( tr ( " GEOM_PREVIEW " ) , operationsGroup ,
LightApp_Preferences : : Bool , " Geometry " , " geom_preview " ) ;
2005-06-22 12:29:29 +06:00
}
void GeometryGUI : : preferencesChanged ( const QString & section , const QString & param )
{
2008-03-07 12:45:34 +05:00
if ( section = = " Geometry " ) {
SUIT_ResourceMgr * aResourceMgr = SUIT_Session : : session ( ) - > resourceMgr ( ) ;
if ( param = = QString ( " SettingsGeomStep " ) ) {
double spin_step = aResourceMgr - > doubleValue ( section , param , 100. ) ;
EmitSignalDefaultStepValueChanged ( spin_step ) ;
2012-12-13 14:40:36 +06:00
}
else if ( param = = QString ( " toplevel_color " ) ) {
2012-08-09 13:58:02 +06:00
QColor c = aResourceMgr - > colorValue ( " Geometry " , " toplevel_color " , QColor ( 170 , 85 , 0 ) ) ;
GEOM_AISShape : : setTopLevelColor ( SalomeApp_Tools : : color ( c ) ) ;
2012-12-13 14:40:36 +06:00
}
else if ( param = = QString ( " toplevel_dm " ) ) {
2012-08-09 13:58:02 +06:00
GEOM_AISShape : : setTopLevelDisplayMode ( ( GEOM_AISShape : : TopLevelDispMode ) aResourceMgr - > integerValue ( " Geometry " , " toplevel_dm " , 0 ) ) ;
2008-03-07 12:45:34 +05:00
}
2012-12-13 14:40:36 +06:00
}
2005-06-22 12:29:29 +06:00
}
2005-09-27 12:32:15 +06:00
2005-11-03 13:30:14 +05:00
LightApp_Displayer * GeometryGUI : : displayer ( )
2005-09-27 12:32:15 +06:00
{
2012-12-13 14:40:36 +06:00
if ( ! myDisplayer )
2005-09-27 12:32:15 +06:00
myDisplayer = new GEOM_Displayer ( dynamic_cast < SalomeApp_Study * > ( getApp ( ) - > activeStudy ( ) ) ) ;
return myDisplayer ;
}
2008-03-07 12:45:34 +05:00
void GeometryGUI : : setLocalSelectionMode ( const int mode )
{
myLocalSelectionMode = mode ;
}
2012-12-13 14:40:36 +06:00
2008-03-07 12:45:34 +05:00
int GeometryGUI : : getLocalSelectionMode ( ) const
{
return myLocalSelectionMode ;
}
2009-02-13 17:16:39 +05:00
const char gSeparator = ' _ ' ; // character used to separate parameter names
const char gDigitsSep = ' : ' ; // character used to separate numeric parameter values (color = r:g:b)
/*!
* \ brief Store visual parameters
*
* This method is called just before the study document is saved .
2012-08-09 13:58:02 +06:00
* Store visual parameters in AttributeParameter attribute ( s )
2009-02-13 17:16:39 +05:00
*/
void GeometryGUI : : storeVisualParameters ( int savePoint )
{
SalomeApp_Study * appStudy = dynamic_cast < SalomeApp_Study * > ( application ( ) - > activeStudy ( ) ) ;
2012-08-09 13:58:02 +06:00
if ( ! appStudy | | ! appStudy - > studyDS ( ) )
2009-02-13 17:16:39 +05:00
return ;
_PTR ( Study ) studyDS = appStudy - > studyDS ( ) ;
// componentName is used for encoding of entries when storing them in IParameters
std : : string componentName = myComponentGeom - > ComponentDataType ( ) ;
//_PTR(SComponent) aSComponent = studyDS->FindComponent("GEOM");
//if (!aSComponent) return;
// IParameters
_PTR ( AttributeParameter ) ap = studyDS - > GetModuleParameters ( " Interface Applicative " ,
componentName . c_str ( ) ,
savePoint ) ;
_PTR ( IParameters ) ip = ClientFactory : : getIParameters ( ap ) ;
QList < SUIT_ViewManager * > lst ;
QList < SUIT_ViewManager * > : : Iterator it ;
// main cycle to store parameters of displayed objects
lst . clear ( ) ;
getApp ( ) - > viewManagers ( lst ) ;
2012-08-09 13:58:02 +06:00
for ( it = lst . begin ( ) ; it ! = lst . end ( ) ; it + + ) {
2009-02-13 17:16:39 +05:00
SUIT_ViewManager * vman = * it ;
QString vType = vman - > getType ( ) ;
2012-08-09 13:58:02 +06:00
int aMgrId = vman - > getGlobalId ( ) ;
2009-02-13 17:16:39 +05:00
// saving VTK actors properties
2012-08-09 13:58:02 +06:00
QVector < SUIT_ViewWindow * > views = vman - > getViews ( ) ;
for ( int i = 0 , iEnd = vman - > getViewsCount ( ) ; i < iEnd ; i + + ) {
const ObjMap anObjects = appStudy - > getObjectMap ( aMgrId ) ;
ObjMap : : ConstIterator o_it = anObjects . begin ( ) ;
for ( ; o_it ! = anObjects . end ( ) ; o_it + + ) {
const PropMap aProps = o_it . value ( ) ;
//Check that object exists in the study
_PTR ( SObject ) obj ( studyDS - > FindObjectID ( o_it . key ( ) . toLatin1 ( ) . data ( ) ) ) ;
if ( ! obj | | ! ( aProps . count ( ) > 0 ) )
continue ;
// entry is "encoded" = it does NOT contain component adress, since it is a
// subject to change on next component loading
std : : string entry = ip - > encodeEntry ( o_it . key ( ) . toLatin1 ( ) . data ( ) , componentName ) ;
_PTR ( GenericAttribute ) anAttr ;
2012-12-13 14:40:36 +06:00
if ( ! obj - > FindAttribute ( anAttr , " AttributeIOR " ) )
2012-08-09 13:58:02 +06:00
continue ;
2013-02-12 17:35:16 +06:00
QString param , occParam = vType ;
occParam + = GEOM : : sectionSeparator ( ) ;
occParam + = QString : : number ( aMgrId ) ;
occParam + = GEOM : : sectionSeparator ( ) ;
2012-08-09 13:58:02 +06:00
2013-02-12 17:35:16 +06:00
if ( aProps . contains ( GEOM : : propertyName ( GEOM : : Visibility ) ) ) {
param = occParam + GEOM : : propertyName ( GEOM : : Visibility ) ;
ip - > setParameter ( entry , param . toStdString ( ) , aProps . value ( GEOM : : propertyName ( GEOM : : Visibility ) ) . toBool ( ) ? " On " : " Off " ) ;
2012-08-09 13:58:02 +06:00
}
2013-02-12 17:35:16 +06:00
if ( aProps . contains ( GEOM : : propertyName ( GEOM : : DisplayMode ) ) ) {
param = occParam + GEOM : : propertyName ( GEOM : : DisplayMode ) ;
ip - > setParameter ( entry , param . toStdString ( ) , aProps . value ( GEOM : : propertyName ( GEOM : : DisplayMode ) ) . toString ( ) . toStdString ( ) ) ;
2012-08-09 13:58:02 +06:00
}
2013-02-12 17:35:16 +06:00
if ( aProps . contains ( GEOM : : propertyName ( GEOM : : Color ) ) ) {
QColor c = aProps . value ( GEOM : : propertyName ( GEOM : : Color ) ) . value < QColor > ( ) ;
2013-06-17 18:39:23 +06:00
QStringList val ;
val < < QString : : number ( c . redF ( ) ) ;
val < < QString : : number ( c . greenF ( ) ) ;
val < < QString : : number ( c . blueF ( ) ) ;
2013-02-12 17:35:16 +06:00
param = occParam + GEOM : : propertyName ( GEOM : : Color ) ;
ip - > setParameter ( entry , param . toStdString ( ) , val . join ( GEOM : : subSectionSeparator ( ) ) . toStdString ( ) ) ;
2012-08-09 13:58:02 +06:00
}
2012-12-13 14:40:36 +06:00
if ( vType = = SVTK_Viewer : : Type ( ) ) {
2013-02-12 17:35:16 +06:00
if ( aProps . contains ( GEOM : : propertyName ( GEOM : : Opacity ) ) ) {
param = occParam + GEOM : : propertyName ( GEOM : : Opacity ) ;
ip - > setParameter ( entry , param . toStdString ( ) , QString : : number ( 1. - aProps . value ( GEOM : : propertyName ( GEOM : : Transparency ) ) . toDouble ( ) ) . toStdString ( ) ) ;
2012-08-09 13:58:02 +06:00
}
} else if ( vType = = SOCC_Viewer : : Type ( ) ) {
2013-02-12 17:35:16 +06:00
if ( aProps . contains ( GEOM : : propertyName ( GEOM : : Transparency ) ) ) {
param = occParam + GEOM : : propertyName ( GEOM : : Transparency ) ;
ip - > setParameter ( entry , param . toStdString ( ) , aProps . value ( GEOM : : propertyName ( GEOM : : Transparency ) ) . toString ( ) . toStdString ( ) ) ;
2012-08-09 13:58:02 +06:00
}
2013-02-12 17:35:16 +06:00
if ( aProps . contains ( GEOM : : propertyName ( GEOM : : TopLevel ) ) ) {
param = occParam + GEOM : : propertyName ( GEOM : : TopLevel ) ;
ip - > setParameter ( entry , param . toStdString ( ) , aProps . value ( GEOM : : propertyName ( GEOM : : TopLevel ) ) . toString ( ) . toStdString ( ) ) ;
2012-12-13 14:40:36 +06:00
}
2012-08-09 13:58:02 +06:00
}
2013-02-12 17:35:16 +06:00
if ( aProps . contains ( GEOM : : propertyName ( GEOM : : NbIsos ) ) ) {
param = occParam + GEOM : : propertyName ( GEOM : : NbIsos ) ;
ip - > setParameter ( entry , param . toStdString ( ) , aProps . value ( GEOM : : propertyName ( GEOM : : NbIsos ) ) . toString ( ) . toStdString ( ) ) ;
2012-08-09 13:58:02 +06:00
}
2013-02-12 17:35:16 +06:00
if ( aProps . contains ( GEOM : : propertyName ( GEOM : : EdgesDirection ) ) ) {
param = occParam + GEOM : : propertyName ( GEOM : : EdgesDirection ) ;
ip - > setParameter ( entry , param . toStdString ( ) , aProps . value ( GEOM : : propertyName ( GEOM : : EdgesDirection ) ) . toString ( ) . toStdString ( ) ) ;
2012-08-09 13:58:02 +06:00
}
2013-02-12 17:35:16 +06:00
if ( aProps . contains ( GEOM : : propertyName ( GEOM : : Deflection ) ) ) {
param = occParam + GEOM : : propertyName ( GEOM : : Deflection ) ;
ip - > setParameter ( entry , param . toStdString ( ) , aProps . value ( GEOM : : propertyName ( GEOM : : Deflection ) ) . toString ( ) . toStdString ( ) ) ;
2012-08-09 13:58:02 +06:00
}
//Marker type of the vertex - ONLY for the "Vertex" and "Compound of the Vertex"
2013-02-12 17:35:16 +06:00
if ( aProps . contains ( GEOM : : propertyName ( GEOM : : PointMarker ) ) ) {
param = occParam + GEOM : : propertyName ( GEOM : : PointMarker ) ;
ip - > setParameter ( entry , param . toStdString ( ) , aProps . value ( GEOM : : propertyName ( GEOM : : PointMarker ) ) . toString ( ) . toStdString ( ) ) ;
2012-08-09 13:58:02 +06:00
}
2013-02-12 17:35:16 +06:00
if ( aProps . contains ( GEOM : : propertyName ( GEOM : : Material ) ) ) {
param = occParam + GEOM : : propertyName ( GEOM : : Material ) ;
ip - > setParameter ( entry , param . toStdString ( ) , aProps . value ( GEOM : : propertyName ( GEOM : : Material ) ) . toString ( ) . toStdString ( ) ) ;
2012-08-09 13:58:02 +06:00
}
2013-02-12 17:35:16 +06:00
if ( aProps . contains ( GEOM : : propertyName ( GEOM : : LineWidth ) ) ) {
param = occParam + GEOM : : propertyName ( GEOM : : LineWidth ) ;
ip - > setParameter ( entry , param . toStdString ( ) , aProps . value ( GEOM : : propertyName ( GEOM : : LineWidth ) ) . toString ( ) . toStdString ( ) ) ;
2012-08-09 13:58:02 +06:00
}
2012-12-13 14:40:36 +06:00
2013-02-12 17:35:16 +06:00
if ( aProps . contains ( GEOM : : propertyName ( GEOM : : IsosWidth ) ) ) {
param = occParam + GEOM : : propertyName ( GEOM : : IsosWidth ) ;
ip - > setParameter ( entry , param . toStdString ( ) , aProps . value ( GEOM : : propertyName ( GEOM : : IsosWidth ) ) . toString ( ) . toStdString ( ) ) ;
2012-08-09 13:58:02 +06:00
}
} // object iterator
} // for (views)
2009-02-13 17:16:39 +05:00
} // for (viewManagers)
}
/*!
* \ brief Restore visual parameters
*
* This method is called after the study document is opened .
2012-08-09 13:58:02 +06:00
* Restore visual parameters from AttributeParameter attribute ( s )
2009-02-13 17:16:39 +05:00
*/
void GeometryGUI : : restoreVisualParameters ( int savePoint )
{
SalomeApp_Study * appStudy = dynamic_cast < SalomeApp_Study * > ( application ( ) - > activeStudy ( ) ) ;
if ( ! appStudy | | ! appStudy - > studyDS ( ) )
return ;
_PTR ( Study ) studyDS = appStudy - > studyDS ( ) ;
// componentName is used for encoding of entries when storing them in IParameters
std : : string componentName = myComponentGeom - > ComponentDataType ( ) ;
//_PTR(SComponent) aSComponent = studyDS->FindComponent("GEOM");
//if (!aSComponent) return;
// IParameters
_PTR ( AttributeParameter ) ap = studyDS - > GetModuleParameters ( " Interface Applicative " ,
componentName . c_str ( ) ,
savePoint ) ;
_PTR ( IParameters ) ip = ClientFactory : : getIParameters ( ap ) ;
std : : vector < std : : string > entries = ip - > getEntries ( ) ;
for ( std : : vector < std : : string > : : iterator entIt = entries . begin ( ) ; entIt ! = entries . end ( ) ; + + entIt )
{
// entry is a normal entry - it should be "decoded" (setting base adress of component)
QString entry ( ip - > decodeEntry ( * entIt ) . c_str ( ) ) ;
// Check that the entry corresponds to a real object in the Study
// as the object may be deleted or modified after the visual state is saved.
_PTR ( SObject ) so = studyDS - > FindObjectID ( entry . toLatin1 ( ) . data ( ) ) ;
if ( ! so ) continue ; //Skip the not existent entry
std : : vector < std : : string > paramNames = ip - > getAllParameterNames ( * entIt ) ;
std : : vector < std : : string > paramValues = ip - > getAllParameterValues ( * entIt ) ;
std : : vector < std : : string > : : iterator namesIt = paramNames . begin ( ) ;
std : : vector < std : : string > : : iterator valuesIt = paramValues . begin ( ) ;
// actors are stored in a map after displaying of them for
// quicker access in the future: map < viewID to actor >
NCollection_DataMap < int , GEOM_Actor * > vtkActors ;
NCollection_DataMap < int , Handle ( GEOM_AISShape ) > occActors ;
2012-08-09 13:58:02 +06:00
QString viewerTypStr ;
QString viewIndexStr ;
int viewIndex ;
QVector < PropMap > aListOfMap ;
2009-02-13 17:16:39 +05:00
for ( ; namesIt ! = paramNames . end ( ) ; + + namesIt , + + valuesIt )
{
// visual parameters are stored in strings as follows: ViewerType_ViewIndex_ParamName.
// '_' is used as separator and should not be used in viewer type or parameter names.
2013-02-12 17:35:16 +06:00
QStringList lst = QString ( ( * namesIt ) . c_str ( ) ) . split ( GEOM : : sectionSeparator ( ) , QString : : SkipEmptyParts ) ;
2009-02-13 17:16:39 +05:00
if ( lst . size ( ) ! = 3 )
continue ;
2012-08-09 13:58:02 +06:00
viewerTypStr = lst [ 0 ] ;
viewIndexStr = lst [ 1 ] ;
2009-02-13 17:16:39 +05:00
QString paramNameStr = lst [ 2 ] ;
bool ok ;
2012-08-09 13:58:02 +06:00
viewIndex = viewIndexStr . toUInt ( & ok ) ;
2009-02-13 17:16:39 +05:00
if ( ! ok ) // bad conversion of view index to integer
2012-08-09 13:58:02 +06:00
continue ;
2012-12-13 14:40:36 +06:00
if ( ( viewIndex + 1 ) > aListOfMap . count ( ) ) {
2012-08-09 13:58:02 +06:00
aListOfMap . resize ( viewIndex + 1 ) ;
}
2009-02-13 17:16:39 +05:00
2012-08-09 13:58:02 +06:00
QString val ( ( * valuesIt ) . c_str ( ) ) ;
2013-02-12 17:35:16 +06:00
if ( paramNameStr = = GEOM : : propertyName ( GEOM : : Visibility ) ) {
aListOfMap [ viewIndex ] . insert ( GEOM : : propertyName ( GEOM : : Visibility ) , val = = " On " ) ;
} else if ( paramNameStr = = GEOM : : propertyName ( GEOM : : Opacity ) ) {
aListOfMap [ viewIndex ] . insert ( GEOM : : propertyName ( GEOM : : Transparency ) , 1. - val . toDouble ( ) ) ;
} else if ( paramNameStr = = GEOM : : propertyName ( GEOM : : Transparency ) ) {
aListOfMap [ viewIndex ] . insert ( GEOM : : propertyName ( GEOM : : Transparency ) , val . toDouble ( ) ) ;
} else if ( paramNameStr = = GEOM : : propertyName ( GEOM : : TopLevel ) ) {
2013-06-17 18:39:23 +06:00
aListOfMap [ viewIndex ] . insert ( GEOM : : propertyName ( GEOM : : TopLevel ) , val = = " true " | | val = = " 1 " ) ;
2013-02-12 17:35:16 +06:00
} else if ( paramNameStr = = GEOM : : propertyName ( GEOM : : DisplayMode ) ) {
aListOfMap [ viewIndex ] . insert ( GEOM : : propertyName ( GEOM : : DisplayMode ) , val . toInt ( ) ) ;
} else if ( paramNameStr = = GEOM : : propertyName ( GEOM : : NbIsos ) ) {
aListOfMap [ viewIndex ] . insert ( GEOM : : propertyName ( GEOM : : NbIsos ) , val ) ;
} else if ( paramNameStr = = GEOM : : propertyName ( GEOM : : Color ) ) {
QStringList rgb = val . split ( GEOM : : subSectionSeparator ( ) ) ;
2012-12-13 14:40:36 +06:00
if ( rgb . count ( ) = = 3 ) {
2013-02-12 17:35:16 +06:00
QColor c = QColor : : fromRgbF ( rgb [ 0 ] . toDouble ( ) , rgb [ 1 ] . toDouble ( ) , rgb [ 2 ] . toDouble ( ) ) ;
aListOfMap [ viewIndex ] . insert ( GEOM : : propertyName ( GEOM : : Color ) , c ) ;
2012-08-09 13:58:02 +06:00
}
2013-02-12 17:35:16 +06:00
} else if ( paramNameStr = = GEOM : : propertyName ( GEOM : : EdgesDirection ) ) {
aListOfMap [ viewIndex ] . insert ( GEOM : : propertyName ( GEOM : : EdgesDirection ) , val = = " true " | | val = = " 1 " ) ;
} else if ( paramNameStr = = GEOM : : propertyName ( GEOM : : Deflection ) ) {
aListOfMap [ viewIndex ] . insert ( GEOM : : propertyName ( GEOM : : Deflection ) , val . toDouble ( ) ) ;
} else if ( paramNameStr = = GEOM : : propertyName ( GEOM : : PointMarker ) ) {
aListOfMap [ viewIndex ] . insert ( GEOM : : propertyName ( GEOM : : PointMarker ) , val ) ;
} else if ( paramNameStr = = GEOM : : propertyName ( GEOM : : Material ) ) {
aListOfMap [ viewIndex ] . insert ( GEOM : : propertyName ( GEOM : : Material ) , val ) ;
} else if ( paramNameStr = = GEOM : : propertyName ( GEOM : : LineWidth ) ) {
aListOfMap [ viewIndex ] . insert ( GEOM : : propertyName ( GEOM : : LineWidth ) , val . toInt ( ) ) ;
} else if ( paramNameStr = = GEOM : : propertyName ( GEOM : : IsosWidth ) ) {
aListOfMap [ viewIndex ] . insert ( GEOM : : propertyName ( GEOM : : IsosWidth ) , val . toInt ( ) ) ;
2009-02-13 17:16:39 +05:00
}
} // for names/parameters iterator
2012-08-09 13:58:02 +06:00
QList < SUIT_ViewManager * > lst = getApp ( ) - > viewManagers ( ) ;
for ( int index = 0 ; index < aListOfMap . count ( ) ; index + + ) {
appStudy - > setObjectPropMap ( index , entry , aListOfMap [ index ] ) ;
//Get Visibility property of the current PropMap
2013-02-12 17:35:16 +06:00
if ( aListOfMap [ index ] . value ( GEOM : : propertyName ( GEOM : : Visibility ) ) = = 1 ) {
2012-08-09 13:58:02 +06:00
SUIT_ViewManager * vman = lst . at ( index ) ;
SUIT_ViewModel * vmodel = vman - > getViewModel ( ) ;
displayer ( ) - > Display ( entry , true , dynamic_cast < SALOME_View * > ( vmodel ) ) ;
}
}
2009-02-13 17:16:39 +05:00
} // for entries iterator
// update all VTK and OCC views
QList < SUIT_ViewManager * > lst ;
getApp ( ) - > viewManagers ( lst ) ;
for ( QList < SUIT_ViewManager * > : : Iterator it = lst . begin ( ) ; it ! = lst . end ( ) ; it + + ) {
SUIT_ViewModel * vmodel = ( * it ) - > getViewModel ( ) ;
if ( ! vmodel )
continue ;
if ( vmodel - > getType ( ) = = SVTK_Viewer : : Type ( ) ) {
SVTK_ViewWindow * vtkView = ( SVTK_ViewWindow * ) ( * it ) - > getActiveView ( ) ;
vtkView - > getRenderer ( ) - > ResetCameraClippingRange ( ) ;
vtkView - > Repaint ( ) ;
}
else if ( vmodel - > getType ( ) = = SOCC_Viewer : : Type ( ) ) {
//SOCC_ViewWindow* occView = (SOCC_ViewWindow*) (*it)->getActiveView();
SALOME_View * occVMod = dynamic_cast < SALOME_View * > ( vmodel ) ;
if ( occVMod )
occVMod - > Repaint ( ) ;
}
}
}
2012-08-09 13:58:02 +06:00
void GeometryGUI : : onViewAboutToShow ( )
{
SUIT_ViewWindow * window = application ( ) - > desktop ( ) - > activeWindow ( ) ;
QAction * a = action ( GEOMOp : : OpSwitchVectors ) ;
if ( window ) {
a - > setEnabled ( true ) ;
bool vmode = window - > property ( " VectorsMode " ) . toBool ( ) ;
a - > setText ( vmode = = 1 ? tr ( " MEN_VECTOR_MODE_OFF " ) : tr ( " MEN_VECTOR_MODE_ON " ) ) ;
} else {
a - > setText ( tr ( " MEN_VECTOR_MODE_ON " ) ) ;
a - > setEnabled ( false ) ;
}
}
/*!
\ brief Return action by id
\ param id identifier of the action
2012-12-13 14:40:36 +06:00
\ return action
2012-08-09 13:58:02 +06:00
*/
QAction * GeometryGUI : : getAction ( const int id ) {
return action ( id ) ;
}
2013-02-28 20:00:05 +06:00
/*!
\ brief GEOM module message handler
This method can be re - implemented in the subclasses .
This is a GEOM module message handler .
\ param msg the message received .
*/
void GeometryGUI : : message ( const QString & msg )
{
// dispatch message
QStringList data = msg . split ( " / " ) ;
const int nbStrings = data . count ( ) ;
if ( nbStrings > 0 ) {
if ( data [ 0 ] = = " modified " ) {
// get mesh entry
QString anIOR = nbStrings > 1 ? data [ 1 ] : QString ( ) ;
if ( anIOR . isEmpty ( ) ) {
return ;
}
// Get the geom object.
GEOM : : GEOM_Object_ptr anObj = GeometryGUI : : GetObjectFromIOR ( anIOR ) ;
// Clear the shape buffer
GeometryGUI : : ClearShapeBuffer ( anObj ) ;
}
}
}
/*!
\ brief Clears the shape buffer .
This is a static method . It clears the shape buffer .
\ param theObj the object
*/
void GeometryGUI : : ClearShapeBuffer ( GEOM : : GEOM_Object_ptr theObj )
{
if ( CORBA : : is_nil ( theObj ) )
return ;
CORBA : : String_var IOR = SalomeApp_Application : : orb ( ) - > object_to_string ( theObj ) ;
TCollection_AsciiString asciiIOR ( ( char * ) IOR . in ( ) ) ;
GEOM_Client : : get_client ( ) . RemoveShapeFromBuffer ( asciiIOR ) ;
SALOMEDSClient_StudyManager * aManager = SalomeApp_Application : : studyMgr ( ) ;
if ( ! aManager )
return ;
_PTR ( Study ) aStudy = aManager - > GetStudyByID ( theObj - > GetStudyID ( ) ) ;
if ( ! aStudy )
return ;
_PTR ( SObject ) aSObj ( aStudy - > FindObjectIOR ( std : : string ( IOR ) ) ) ;
if ( ! aSObj )
return ;
_PTR ( ChildIterator ) anIt ( aStudy - > NewChildIterator ( aSObj ) ) ;
for ( anIt - > InitEx ( true ) ; anIt - > More ( ) ; anIt - > Next ( ) ) {
_PTR ( GenericAttribute ) anAttr ;
if ( anIt - > Value ( ) - > FindAttribute ( anAttr , " AttributeIOR " ) ) {
_PTR ( AttributeIOR ) anIOR ( anAttr ) ;
TCollection_AsciiString asciiIOR ( ( char * ) anIOR - > Value ( ) . c_str ( ) ) ;
GEOM_Client : : get_client ( ) . RemoveShapeFromBuffer ( asciiIOR ) ;
}
}
}
/*!
\ brief Returns the object from IOR .
This is a static method . It returns the object from its IOR .
\ param IOR object IOR
\ return GEOM object .
*/
GEOM : : GEOM_Object_ptr GeometryGUI : : GetObjectFromIOR ( const QString & IOR )
{
GEOM : : GEOM_Object_var geomObj ;
if ( ! IOR . isEmpty ( ) ) {
CORBA : : Object_var corbaObj = SalomeApp_Application : : orb ( ) - > string_to_object
( IOR . toLatin1 ( ) . constData ( ) ) ;
if ( ! CORBA : : is_nil ( corbaObj ) )
geomObj = GEOM : : GEOM_Object : : _narrow ( corbaObj ) ;
}
return geomObj . _retn ( ) ;
}
/*!
\ brief Returns IOR of the object .
This is a static method . It returns the object ' s IOR .
\ param object the GEOM object .
\ return object ' s IOR .
*/
QString GeometryGUI : : GetIORFromObject ( GEOM : : GEOM_Object_ptr object )
{
QString IOR ;
if ( ! CORBA : : is_nil ( object ) ) {
CORBA : : String_var anIOR =
SalomeApp_Application : : orb ( ) - > object_to_string ( object ) ;
IOR = anIOR . in ( ) ;
}
return IOR ;
}
2012-08-09 13:58:02 +06:00
/*!
\ brief Check if this object is can ' t be renamed in place
This method can be re - implemented in the subclasses .
Return true in case if object isn ' t reference or component ( module root ) .
\ param entry column id
\ return \ c true if the item can be renamed by the user in place ( e . g . in the Object browser )
*/
bool GeometryGUI : : renameAllowed ( const QString & entry ) const {
SalomeApp_Application * app = dynamic_cast < SalomeApp_Application * > ( SUIT_Session : : session ( ) - > activeApplication ( ) ) ;
2012-12-13 14:40:36 +06:00
SalomeApp_Study * appStudy = app ? dynamic_cast < SalomeApp_Study * > ( app - > activeStudy ( ) ) : 0 ;
2012-08-09 13:58:02 +06:00
SalomeApp_DataObject * obj = appStudy ? dynamic_cast < SalomeApp_DataObject * > ( appStudy - > findObjectByEntry ( entry ) ) : 0 ;
2012-12-13 14:40:36 +06:00
2012-08-09 13:58:02 +06:00
return ( app & & appStudy & & obj & & ! appStudy - > isComponent ( entry ) & & ! obj - > isReference ( ) ) ;
}
/*!
Rename object by entry .
\ param entry entry of the object
\ param name new name of the object
\ brief Return \ c true if rename operation finished successfully , \ c false otherwise .
*/
2012-12-13 14:40:36 +06:00
bool GeometryGUI : : renameObject ( const QString & entry , const QString & name )
{
2012-08-09 13:58:02 +06:00
bool result = false ;
2012-12-13 14:40:36 +06:00
SalomeApp_Application * app =
dynamic_cast < SalomeApp_Application * > ( SUIT_Session : : session ( ) - > activeApplication ( ) ) ;
2012-08-09 13:58:02 +06:00
SalomeApp_Study * appStudy = app ? dynamic_cast < SalomeApp_Study * > ( app - > activeStudy ( ) ) : 0 ;
2012-12-13 14:40:36 +06:00
if ( ! appStudy )
2012-08-09 13:58:02 +06:00
return result ;
2012-12-13 14:40:36 +06:00
2012-08-09 13:58:02 +06:00
_PTR ( Study ) aStudy = appStudy - > studyDS ( ) ;
2012-12-13 14:40:36 +06:00
if ( ! aStudy )
2012-08-09 13:58:02 +06:00
return result ;
bool aLocked = ( _PTR ( AttributeStudyProperties ) ( appStudy - > studyDS ( ) - > GetProperties ( ) ) ) - > IsLocked ( ) ;
if ( aLocked ) {
SUIT_MessageBox : : warning ( app - > desktop ( ) , QObject : : tr ( " WRN_WARNING " ) , QObject : : tr ( " WRN_STUDY_LOCKED " ) ) ;
return result ;
}
_PTR ( SObject ) obj ( aStudy - > FindObjectID ( qPrintable ( entry ) ) ) ;
_PTR ( GenericAttribute ) anAttr ;
if ( obj ) {
if ( obj - > FindAttribute ( anAttr , " AttributeName " ) ) {
_PTR ( AttributeName ) aName ( anAttr ) ;
GEOM : : GEOM_Object_var anObj = GEOM : : GEOM_Object : : _narrow ( GeometryGUI : : ClientSObjectToObject ( obj ) ) ;
if ( ! CORBA : : is_nil ( anObj ) ) {
aName - > SetValue ( name . toLatin1 ( ) . data ( ) ) ; // rename the SObject
anObj - > SetName ( name . toLatin1 ( ) . data ( ) ) ; // Rename the corresponding GEOM_Object
result = true ;
}
}
}
return result ;
}
2013-02-12 17:35:16 +06:00
void GeometryGUI : : updateMaterials ( )
{
LightApp_Preferences * pref = preferences ( ) ;
if ( pref ) {
QStringList materials = Material_ResourceMgr : : resourceMgr ( ) - > materials ( ) ;
QString currentMaterial = SUIT_Session : : session ( ) - > resourceMgr ( ) - > stringValue ( " Geometry " , " material " ) ;
if ( ! materials . contains ( currentMaterial ) )
// user material set as default in the preferences, might be removed
SUIT_Session : : session ( ) - > resourceMgr ( ) - > setValue ( " Geometry " , " material " , QString ( " Plastic " ) ) ;
QtxPreferenceItem * prefItem = pref - > rootItem ( ) - > findItem ( tr ( " PREF_MATERIAL " ) , true ) ;
if ( prefItem ) {
setPreferenceProperty ( prefItem - > id ( ) ,
2013-06-17 18:39:23 +06:00
" strings " , materials ) ;
2013-02-12 17:35:16 +06:00
prefItem - > retrieve ( ) ;
}
}
}