1 // GEOM GEOMGUI : GUI for Geometry component
3 // Copyright (C) 2003 OPEN CASCADE, EADS/CCR, LIP6, CEA/DEN,
4 // CEDRAT, EDF R&D, LEG, PRINCIPIA R&D, BUREAU VERITAS
6 // This library is free software; you can redistribute it and/or
7 // modify it under the terms of the GNU Lesser General Public
8 // License as published by the Free Software Foundation; either
9 // version 2.1 of the License.
11 // This library is distributed in the hope that it will be useful,
12 // but WITHOUT ANY WARRANTY; without even the implied warranty of
13 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
14 // Lesser General Public License for more details.
16 // You should have received a copy of the GNU Lesser General Public
17 // License along with this library; if not, write to the Free Software
18 // Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
20 // See http://www.salome-platform.org/ or email : webmaster.salome@opencascade.com
24 // File : GeometryGUI.cxx
25 // Author : Lucien PIGNOLONI
29 #include "GeometryGUI.h"
30 #include "GEOMGUI_OCCSelector.h"
31 #include "GEOMGUI_Selection.h"
32 #include "GEOM_Displayer.h"
34 #include <SUIT_MessageBox.h>
35 #include <SUIT_ResourceMgr.h>
36 #include <SUIT_Session.h>
37 #include <SUIT_ViewManager.h>
39 #include <OCCViewer_ViewWindow.h>
40 #include <OCCViewer_ViewPort3d.h>
41 #include <OCCViewer_ViewModel.h>
42 #include <OCCViewer_ViewManager.h>
44 #include <SVTK_ViewWindow.h>
45 #include <SVTK_RenderWindowInteractor.h>
46 #include <SVTK_InteractorStyle.h>
47 #include <SVTK_ViewModel.h>
48 #include <SVTK_ViewManager.h>
50 #include <SalomeApp_Application.h>
51 #include <LightApp_SelectionMgr.h>
52 #include <LightApp_VTKSelector.h>
53 #include <LightApp_DataObject.h>
54 #include <SalomeApp_Study.h>
55 #include <LightApp_Preferences.h>
56 #include <SALOME_LifeCycleCORBA.hxx>
57 #include <SALOME_ListIO.hxx>
58 #include <SALOME_ListIteratorOfListIO.hxx>
61 #include <qfileinfo.h>
64 #include <Prs3d_Drawer.hxx>
65 #include <Prs3d_IsoAspect.hxx>
66 #include <Aspect_TypeOfMarker.hxx>
67 #include <OSD_SharedLibrary.hxx>
69 #include <utilities.h>
71 #include <vtkCamera.h>
72 #include <vtkRenderer.h>
76 Standard_EXPORT CAM_Module* createModule() {
77 return new GeometryGUI();
83 GEOM::GEOM_Gen_var GeometryGUI::myComponentGeom = GEOM::GEOM_Gen::_nil();
85 GEOM::GEOM_Gen_var GeometryGUI::GetGeomGen()
87 // Bug 12290: exception in Mesh GUI on GEOMBase::GetShape() if Geometry GUI hasn't been loaded
88 if (CORBA::is_nil(myComponentGeom))
90 return GeometryGUI::myComponentGeom;
93 bool GeometryGUI::InitGeomGen()
96 if( CORBA::is_nil( myComponentGeom ) ) return false;
100 //=======================================================================
101 // function : ClientSObjectToObject
103 //=======================================================================
104 CORBA::Object_var GeometryGUI::ClientSObjectToObject (_PTR(SObject) theSObject)
106 _PTR(GenericAttribute) anAttr;
107 CORBA::Object_var anObj;
109 std::string aValue = theSObject->GetIOR();
110 if (strcmp(aValue.c_str(), "") != 0) {
111 CORBA::ORB_ptr anORB = SalomeApp_Application::orb();
112 anObj = anORB->string_to_object(aValue.c_str());
115 INFOS("ClientSObjectToObject - Unknown exception was occured!!!");
117 return anObj._retn();
120 //=======================================================================
121 // function : ClientStudyToStudy
123 //=======================================================================
124 SALOMEDS::Study_var GeometryGUI::ClientStudyToStudy (_PTR(Study) theStudy)
126 SALOME_NamingService *aNamingService = SalomeApp_Application::namingService();
127 CORBA::Object_var aSMObject = aNamingService->Resolve("/myStudyManager");
128 SALOMEDS::StudyManager_var aStudyManager = SALOMEDS::StudyManager::_narrow(aSMObject);
129 int aStudyID = theStudy->StudyId();
130 SALOMEDS::Study_var aDSStudy = aStudyManager->GetStudyByID(aStudyID);
131 return aDSStudy._retn();
134 //=================================================================================
135 // class : CustomItem
136 // purpose : Set Font to a text.
137 //=================================================================================
138 class CustomItem : public QCustomMenuItem
141 CustomItem(const QString& s, const QFont& f) : myString(s), myFont(f) {}
144 void paint(QPainter* p, const QColorGroup& cg, bool act, bool /*enabled*/, int x, int y, int w, int h)
147 p->fillRect( x, y, w, h, act ? cg.highlight() : cg.mid() );
148 p->setPen( act ? cg.highlightedText() : cg.buttonText() );
149 p->setFont( myFont );
150 p->drawText( x, y, w, h, AlignHCenter | AlignVCenter | ShowPrefix | DontClip | SingleLine, myString );
156 return QFontMetrics( myFont ).size( AlignHCenter | AlignVCenter | ShowPrefix | DontClip | SingleLine, myString );
159 bool fullSpan() const
169 //=======================================================================
170 // function : GeometryGUI::GeometryGUI()
171 // purpose : Constructor
172 //=======================================================================
173 GeometryGUI::GeometryGUI() :
174 SalomeApp_Module( "GEOM" )
176 if ( CORBA::is_nil( myComponentGeom ) )
178 SALOME_LifeCycleCORBA* ls = new SALOME_LifeCycleCORBA( getApp()->namingService() );
179 Engines::Component_var comp = ls->FindOrLoad_Component( "FactoryServer", "GEOM" );
180 myComponentGeom = GEOM::GEOM_Gen::_narrow( comp );
184 myActiveDialogBox = 0;
187 gp_Pnt origin = gp_Pnt(0., 0., 0.);
188 gp_Dir direction = gp_Dir(0., 0., 1.);
189 myWorkingPlane = gp_Ax3(origin, direction);
191 myOCCSelectors.setAutoDelete( true );
192 myVTKSelectors.setAutoDelete( true );
195 myLocalSelectionMode = GEOM_ALLOBJECTS;
198 //=======================================================================
199 // function : GeometryGUI::~GeometryGUI()
200 // purpose : Destructor
201 //=======================================================================
202 GeometryGUI::~GeometryGUI()
206 //=======================================================================
207 // function : GeometryGUI::getLibrary()
208 // purpose : get or load GUI library by name [ internal ]
209 //=======================================================================
210 typedef GEOMGUI* (*LibraryGUI)( GeometryGUI* );
211 GEOMGUI* GeometryGUI::getLibrary( const QString& libraryName )
213 if ( !myGUIMap.contains( libraryName ) ) {
214 // try to load library if it is not loaded yet
217 if ( (libs = getenv( "LD_LIBRARY_PATH" )) ) {
218 QStringList dirList = QStringList::split( ":", libs, false ); // skip empty entries
220 if ( (libs = getenv( "PATH" )) ) {
221 QStringList dirList = QStringList::split( ";", libs, false ); // skip empty entries
223 for( int i = dirList.count()-1; i >= 0; i-- ) {
224 QString dir = dirList[ i ];
225 QFileInfo fi( Qtx::addSlash( dirList[ i ] ) + libraryName );
227 OSD_SharedLibrary aSharedLibrary( (char*)fi.fileName().latin1() );
228 bool res = aSharedLibrary.DlOpen( OSD_RTLD_LAZY );
230 MESSAGE( "Can't open library : " << aSharedLibrary.DlError() );
231 continue; // continue search further
233 OSD_Function osdF = aSharedLibrary.DlSymb( "GetLibGUI" );
234 if ( osdF != NULL ) {
235 LibraryGUI func = (GEOMGUI* (*) (GeometryGUI*))osdF;
236 GEOMGUI* libGUI = (*func)(this);
238 myGUIMap[ libraryName ] = libGUI;
239 break; // found and loaded!
246 if ( myGUIMap.contains( libraryName ) )
247 // library is successfully loaded
248 return myGUIMap[ libraryName ];
252 //=======================================================================
253 // function : GeometryGUI::ActiveWorkingPlane()
254 // purpose : Activate Working Plane View
255 //=======================================================================
256 void GeometryGUI::ActiveWorkingPlane()
258 gp_Dir DZ = myWorkingPlane.Direction();
259 gp_Dir DY = myWorkingPlane.YDirection();
261 SUIT_ViewWindow* window = application()->desktop()->activeWindow();
262 bool ViewOCC = ( window && window->getViewManager()->getType() == OCCViewer_Viewer::Type() );
263 bool ViewVTK = ( window && window->getViewManager()->getType() == SVTK_Viewer::Type() );
266 OCCViewer_ViewWindow* vw = dynamic_cast<OCCViewer_ViewWindow*>( window );
268 Handle(V3d_View) view3d = vw->getViewPort()->getView();
270 view3d->SetProj(DZ.X(), DZ.Y(), DZ.Z());
271 view3d->SetUp(DY.X(), DY.Y(), DY.Z());
277 SVTK_ViewWindow* vw = dynamic_cast<SVTK_ViewWindow*>( window );
279 vtkCamera* camera = vw->getRenderer()->GetActiveCamera();
281 camera->SetPosition(DZ.X(), DZ.Y(), DZ.Z());
282 camera->SetViewUp(DY.X(), DY.Y(), DY.Z());
283 camera->SetFocalPoint(0,0,0);
290 //=======================================================================
291 // function : GeometryGUI::SetActiveDialogBox()
292 // purpose : Set active dialog box
293 //=======================================================================
294 void GeometryGUI::SetActiveDialogBox( QDialog* aDlg )
296 myActiveDialogBox = (QDialog*)aDlg;
299 //=======================================================================
300 // function : GeometryGUI::EmitSignalDeactivateDialog()
301 // purpose : Emit a signal to deactivate the active dialog Box
302 //=======================================================================
303 void GeometryGUI::EmitSignalDeactivateDialog()
305 emit SignalDeactivateActiveDialog();
308 //=======================================================================
309 // function : GeometryGUI::EmitSignalCloseAllDialogs()
310 // purpose : Emit a signal to close all non modal dialogs box
311 //=======================================================================
312 void GeometryGUI::EmitSignalCloseAllDialogs()
314 emit SignalCloseAllDialogs();
317 //=======================================================================
318 // function : GeometryGUI::EmitSignalDefaultStepValueChanged()
319 // purpose : Emit a signal to inform that default real spin box step has
321 //=======================================================================
322 void GeometryGUI::EmitSignalDefaultStepValueChanged(double newVal)
324 emit SignalDefaultStepValueChanged(newVal);
327 //=======================================================================
328 // function : GeometryGUI::OnGUIEvent()
329 // purpose : common slot for all menu/toolbar actions
330 //=======================================================================
331 void GeometryGUI::OnGUIEvent()
333 const QObject* obj = sender();
334 if ( !obj || !obj->inherits( "QAction" ) )
336 int id = actionId((QAction*)obj);
341 //=======================================================================
342 // function : GeometryGUI::OnGUIEvent()
343 // purpose : manage all events on GUI [static]
344 //=======================================================================
345 void GeometryGUI::OnGUIEvent( int id )
347 SUIT_Application* anApp = application();
349 SUIT_Desktop* desk = anApp->desktop();
351 // check type of the active viewframe
352 SUIT_ViewWindow* window = desk->activeWindow();
353 bool ViewOCC = ( window && window->getViewManager()->getType() == OCCViewer_Viewer::Type() );
354 bool ViewVTK = ( window && window->getViewManager()->getType() == SVTK_Viewer::Type() );
355 // if current viewframe is not of OCC and not of VTK type - return immediately
356 // fix for IPAL8958 - allow some commands to execute even when NO viewer is active (rename for example)
357 bool NotViewerDependentCommand = ( id == 901 || id == 216 || id == 213 );
358 if ( !ViewOCC && !ViewVTK && !NotViewerDependentCommand )
361 // fix for IPAL9103, point 2
362 if ( CORBA::is_nil( GetGeomGen() ) ) {
363 SUIT_MessageBox::error1( desk, tr( "GEOM_ERROR" ), tr( "GEOM_ERR_GET_ENGINE" ), tr( "GEOM_BUT_OK" ) );
367 GEOMGUI* library = 0;
368 // try to get-or-load corresponding GUI library
369 if( id == 111 || // MENU FILE - IMPORT BREP
370 id == 112 || // MENU FILE - IMPORT IGES
371 id == 113 || // MENU FILE - IMPORT STEP
372 id == 121 || // MENU FILE - EXPORT BREP
373 id == 122 || // MENU FILE - EXPORT IGES
374 id == 123 || // MENU FILE - EXPORT STEP
375 id == 2171 || // POPUP VIEWER - SELECT ONLY - VERTEX
376 id == 2172 || // POPUP VIEWER - SELECT ONLY - EDGE
377 id == 2173 || // POPUP VIEWER - SELECT ONLY - WIRE
378 id == 2174 || // POPUP VIEWER - SELECT ONLY - FACE
379 id == 2175 || // POPUP VIEWER - SELECT ONLY - SHELL
380 id == 2176 || // POPUP VIEWER - SELECT ONLY - SOLID
381 id == 2177 || // POPUP VIEWER - SELECT ONLY - COMPOUND
382 id == 2178 || // POPUP VIEWER - SELECT ONLY - SELECT ALL
383 id == 31 || // MENU EDIT - COPY
384 id == 33 || // MENU EDIT - DELETE
385 id == 411 || // MENU SETTINGS - ADD IN STUDY
386 id == 412 || // MENU SETTINGS - SHADING COLOR
387 id == 5103 || // MENU TOOLS - CHECK GEOMETRY
388 id == 8032 || // POPUP VIEWER - COLOR
389 id == 8033 || // POPUP VIEWER - TRANSPARENCY
390 id == 8034 || // POPUP VIEWER - ISOS
391 id == 8035 || // POPUP VIEWER - AUTO COLOR
392 id == 8036 || // POPUP VIEWER - DISABLE AUTO COLOR
393 id == 804 || // POPUP VIEWER - ADD IN STUDY
394 id == 901 || // OBJECT BROWSER - RENAME
395 id == 9024 ) { // OBJECT BROWSER - OPEN
396 //cout << "id " << id << " received" << endl;
398 library = getLibrary( "libGEOMToolsGUI.so" );
400 library = getLibrary( "GEOMToolsGUI.dll" );
403 else if( id == 211 || // MENU VIEW - WIREFRAME/SHADING
404 id == 212 || // MENU VIEW - DISPLAY ALL
405 id == 213 || // MENU VIEW - DISPLAY ONLY
406 id == 214 || // MENU VIEW - ERASE ALL
407 id == 215 || // MENU VIEW - ERASE
408 id == 216 || // MENU VIEW - DISPLAY
409 id == 80311 || // POPUP VIEWER - WIREFRAME
410 id == 80312 ) { // POPUP VIEWER - SHADING
412 library = getLibrary( "libDisplayGUI.so" );
414 library = getLibrary( "DisplayGUI.dll" );
417 else if( id == 4011 || // MENU BASIC - POINT
418 id == 4012 || // MENU BASIC - LINE
419 id == 4013 || // MENU BASIC - CIRCLE
420 id == 4014 || // MENU BASIC - ELLIPSE
421 id == 4015 || // MENU BASIC - ARC
422 id == 4016 || // MENU BASIC - VECTOR
423 id == 4017 || // MENU BASIC - PLANE
424 id == 4018 || // MENU BASIC - WPLANE
425 id == 4019 || // MENU BASIC - CURVE
426 id == 4020 ) { // MENU BASIC - REPAIR
428 library = getLibrary( "libBasicGUI.so" );
430 library = getLibrary( "BasicGUI.dll" );
433 else if( id == 4021 || // MENU PRIMITIVE - BOX
434 id == 4022 || // MENU PRIMITIVE - CYLINDER
435 id == 4023 || // MENU PRIMITIVE - SPHERE
436 id == 4024 || // MENU PRIMITIVE - TORUS
437 id == 4025 ) { // MENU PRIMITIVE - CONE
439 library = getLibrary( "libPrimitiveGUI.so" );
441 library = getLibrary( "PrimitiveGUI.dll" );
444 else if( id == 4031 || // MENU GENERATION - PRISM
445 id == 4032 || // MENU GENERATION - REVOLUTION
446 id == 4033 || // MENU GENERATION - FILLING
447 id == 4034 ) { // MENU GENERATION - PIPE
449 library = getLibrary( "libGenerationGUI.so" );
451 library = getLibrary( "GenerationGUI.dll" );
454 else if( id == 404 || // MENU ENTITY - SKETCHER
455 id == 407 ) { // MENU ENTITY - EXPLODE
457 library = getLibrary( "libEntityGUI.so" );
459 library = getLibrary( "EntityGUI.dll" );
462 else if( id == 4081 || // MENU BUILD - EDGE
463 id == 4082 || // MENU BUILD - WIRE
464 id == 4083 || // MENU BUILD - FACE
465 id == 4084 || // MENU BUILD - SHELL
466 id == 4085 || // MENU BUILD - SOLID
467 id == 4086 ) { // MENU BUILD - COMPUND
469 library = getLibrary( "libBuildGUI.so" );
471 library = getLibrary( "BuildGUI.dll" );
474 else if( id == 5011 || // MENU BOOLEAN - FUSE
475 id == 5012 || // MENU BOOLEAN - COMMON
476 id == 5013 || // MENU BOOLEAN - CUT
477 id == 5014 ) { // MENU BOOLEAN - SECTION
479 library = getLibrary( "libBooleanGUI.so" );
481 library = getLibrary( "BooleanGUI.dll" );
484 else if( id == 5021 || // MENU TRANSFORMATION - TRANSLATION
485 id == 5022 || // MENU TRANSFORMATION - ROTATION
486 id == 5023 || // MENU TRANSFORMATION - LOCATION
487 id == 5024 || // MENU TRANSFORMATION - MIRROR
488 id == 5025 || // MENU TRANSFORMATION - SCALE
489 id == 5026 || // MENU TRANSFORMATION - OFFSET
490 id == 5027 || // MENU TRANSFORMATION - MULTI-TRANSLATION
491 id == 5028 ) { // MENU TRANSFORMATION - MULTI-ROTATION
493 library = getLibrary( "libTransformationGUI.so" );
495 library = getLibrary( "TransformationGUI.dll" );
498 else if( id == 503 || // MENU OPERATION - PARTITION
499 id == 504 || // MENU OPERATION - ARCHIMEDE
500 id == 505 || // MENU OPERATION - FILLET
501 id == 506 || // MENU OPERATION - CHAMFER
502 id == 507 || // MENU OPERATION - CLIPPING RANGE
503 id == 508 ) { // MENU OPERATION - GET SHAPES ON SHAPE
505 library = getLibrary( "libOperationGUI.so" );
507 library = getLibrary( "OperationGUI.dll" );
510 else if( id == 601 || // MENU REPAIR - SEWING
511 id == 603 || // MENU REPAIR - SUPPRESS FACES
512 id == 604 || // MENU REPAIR - SUPPRESS HOLE
513 id == 605 || // MENU REPAIR - SHAPE PROCESSING
514 id == 606 || // MENU REPAIR - CLOSE CONTOUR
515 id == 607 || // MENU REPAIR - REMOVE INTERNAL WIRES
516 id == 608 || // MENU REPAIR - ADD POINT ON EDGE
517 id == 609 || // MENU MEASURE - FREE BOUNDARIES
518 id == 610 || // MENU MEASURE - FREE FACES
519 id == 611 || // MENU REPAIR - CHANGE ORIENTATION
520 id == 602 || // MENU REPAIR - GLUE FACES
521 id == 612 ) { // MENU REPAIR - REMOVE EXTRA EDGES
523 library = getLibrary( "libRepairGUI.so" );
525 library = getLibrary( "RepairGUI.dll" );
528 else if( id == 701 || // MENU MEASURE - PROPERTIES
529 id == 702 || // MENU MEASURE - CDG
530 id == 703 || // MENU MEASURE - INERTIA
531 id == 704 || // MENU MEASURE - NORMALE
532 id == 7041 || // MENU MEASURE - BOUNDING BOX
533 id == 7042 || // MENU MEASURE - MIN DISTANCE
534 id == 7043 || // MENU MEASURE - ANGLE
535 id == 705 || // MENU MEASURE - TOLERANCE
536 id == 706 || // MENU MEASURE - WHATIS
537 id == 707 || // MENU MEASURE - CHECK
538 id == 7072 || // MENU MEASURE - CHECK COMPOUND OF BLOCKS
539 id == 708 ) { // MENU MEASURE - POINT COORDINATES
541 library = getLibrary( "libMeasureGUI.so" );
543 library = getLibrary( "MeasureGUI.dll" );
546 else if( id == 800 || // MENU GROUP - CREATE
547 id == 8001 || // POPUP MENU - CREATE GROUP
548 id == 801 ) { // MENU GROUP - EDIT
550 library = getLibrary( "libGroupGUI.so" );
552 library = getLibrary( "GroupGUI.dll" );
555 else if( id == 9999 || // MENU BLOCKS - HEXAHEDRAL SOLID
556 id == 9998 || // MENU BLOCKS - MULTI-TRANSFORMATION
557 id == 9997 || // MENU BLOCKS - QUADRANGLE FACE
558 id == 99991 || // MENU BLOCKS - PROPAGATE
559 id == 9995 ) { // MENU BLOCKS - EXPLODE ON BLOCKS
561 library = getLibrary( "libBlocksGUI.so" );
563 library = getLibrary( "BlocksGUI.dll" );
567 // call method of corresponding GUI library
569 library->OnGUIEvent( id, desk );
571 SUIT_MessageBox::error1( desk, tr( "GEOM_ERROR" ), tr( "GEOM_ERR_LIB_NOT_FOUND" ), tr( "GEOM_BUT_OK" ) );
575 //=================================================================================
576 // function : GeometryGUI::OnKeyPress()
577 // purpose : Called when any key is pressed by user [static]
578 //=================================================================================
579 void GeometryGUI::OnKeyPress( SUIT_ViewWindow* win, QKeyEvent* pe )
583 for ( it = myGUIMap.begin(); it != myGUIMap.end(); ++it ) {
584 SUIT_Application* anApp = application();
586 bOk = bOk && it.data()->OnKeyPress( pe, anApp->desktop(), win );
592 //=================================================================================
593 // function : GeometryGUI::OnMouseMove()
594 // purpose : Manages mouse move events [static]
595 //=================================================================================
596 void GeometryGUI::OnMouseMove( SUIT_ViewWindow* win, QMouseEvent* pe )
600 for ( it = myGUIMap.begin(); it != myGUIMap.end(); ++it ) {
601 SUIT_Application* anApp = application();
603 bOk = bOk && it.data()->OnMouseMove( pe, anApp->desktop(), win );
609 //=================================================================================
610 // function : GeometryGUI::0nMousePress()
611 // purpose : Manage mouse press events [static]
612 //=================================================================================
613 void GeometryGUI::OnMousePress( SUIT_ViewWindow* win, QMouseEvent* pe )
616 // OnMousePress() should return false if this event should be processed further
617 // (see OCCViewer_Viewer3d::onMousePress() for explanation)
618 bool processed = false;
619 for ( it = myGUIMap.begin(); it != myGUIMap.end(); ++it ) {
620 SUIT_Application* anApp = application();
622 processed = processed || it.data()->OnMousePress( pe, anApp->desktop(), win );
628 static void UpdateVtkSelection()
630 QPtrList<SUIT_ViewWindow> winList = application()->desktop()->windows();
631 SUIT_ViewWindow* win = 0;
632 for ( win = winList.first(); win; win = winList.next() ) {
633 if ( win->getViewManager()->getTypeView() == VIEW_VTK ) {
634 SVTK_ViewWindow* vw = dynamic_cast<SVTK_ViewWindow*>( window );
636 SVTK_RenderWindowInteractor* anInteractor = vw->getRWInteractor();
637 anInteractor->SetSelectionProp();
638 anInteractor->SetSelectionTolerance();
639 SVTK_InteractorStyleSALOME* aStyle = anInteractor->GetInteractorStyleSALOME();
641 aStyle->setPreselectionProp();
648 //=================================================================================
649 // function : GeometryGUI::SetSettings()
650 // purpose : Called when GEOM module is activated [static]
651 //=================================================================================
652 bool GeometryGUI::SetSettings()
654 QMenuBar* Mb = parent->getMainMenuBar();
655 SUIT_Study* ActiveStudy = application()->activeStudy();
657 // Wireframe or Shading
659 SUIT_ViewWindow* window = application()->desktop()->activeWindow();
660 bool ViewOCC = ( window && window->getViewManager()->getType() == VIEW_OCC );
661 bool ViewVTK = ( window && window->getViewManager()->getType() == VIEW_VTK );
663 OCCViewer_ViewManager* vm = dynamic_cast<OCCViewer_ViewManager*>( window->getViewManager() );
665 Handle(AIS_InteractiveContext) ic = vm->getOCCViewer()->getAISContext();
666 DisplayMode = ic->DisplayMode();
669 else if ( ViewVTK ) {
670 SVTK_ViewWindow* vw = dynamic_cast<SVTK_ViewWindow*>( window );
672 SVTK_RenderWindowInteractor* myRenderInter = vw->getRWInteractor();
673 DisplayMode = myRenderInter->GetDisplayMode();
677 if( DisplayMode == 1 )
679 Mb->changeItem( 211, tr( "GEOM_MEN_WIREFRAME" ) );
681 Mb->changeItem( 211, tr( "GEOM_MEN_SHADING" ) );
684 // Add in Study - !!!ALWAYS TRUE!!! /////// VSR : TO BE REMOVED
685 QString AddInStudy = QAD_CONFIG->getSetting("Geometry:SettingsAddInStudy");
686 int Settings_AddInStudy;
687 // if(!AddInStudy.isEmpty())
688 // Settings_AddInStudy = AddInStudy.toInt();
691 Settings_AddInStudy = 1;
692 Mb->setItemChecked(411, Settings_AddInStudy);
695 QString S = QAD_CONFIG->getSetting("Geometry:SettingsGeomStep");
697 QAD_CONFIG->addSetting("Geometry:SettingsGeomStep", "100");
700 int count = ActiveStudy->getStudyFramesCount();
701 for(int i = 0; i < count; i++) {
702 if(ActiveStudy->getStudyFrame(i)->getTypeView() == VIEW_OCC) {
703 OCCViewer_Viewer3d* v3d = ((OCCViewer_ViewFrame*)ActiveStudy->getStudyFrame(i)->getRightFrame()->getViewFrame())->getViewer();
704 Handle (AIS_InteractiveContext) ic = v3d->getAISContext();
706 QString IsoU = QAD_CONFIG->getSetting("Geometry:SettingsIsoU");
707 QString IsoV = QAD_CONFIG->getSetting("Geometry:SettingsIsoV");
709 ic->DefaultDrawer()->UIsoAspect()->SetNumber(IsoU.toInt());
711 ic->DefaultDrawer()->VIsoAspect()->SetNumber(IsoV.toInt());
717 // PAL5356: update VTK selection
718 ::UpdateVtkSelection();
721 for ( it = myGUIMap.begin(); it != myGUIMap.end(); ++it )
722 bOk = bOk && it.data()->SetSettings( parent );
724 // MZN: Enable/disable "Clipping range" menu item(from GEOM_CLIPPING variable)
725 if (getenv( "GEOM_CLIPPING" ) == NULL)
727 QMenuItem* mi = Mb->findItem(50);
728 if (mi && mi->popup())
729 mi->popup()->removeItem(507);
736 //=======================================================================
737 // function : createGeomAction
739 //=======================================================================
740 void GeometryGUI::createGeomAction( const int id, const QString& po_id, const QString& icon_id, const int key, const bool toggle )
743 QWidget* parent = application()->desktop();
744 SUIT_ResourceMgr* resMgr = SUIT_Session::session()->resourceMgr();
746 if ( icon_id.length() )
747 pix = resMgr->loadPixmap( "GEOM", tr( icon_id ) );
749 pix = resMgr->loadPixmap( "GEOM", tr( QString( "ICO_" )+po_id ), false );
751 icon = QIconSet( pix );
753 QString tooltip = tr( QString( "TOP_" )+po_id ),
754 menu = tr( QString( "MEN_" )+po_id ),
755 status_bar = tr( QString( "STB_" )+po_id );
757 createAction( id, tooltip, icon, menu, status_bar, key, parent, toggle, this, SLOT( OnGUIEvent() ) );
762 //=======================================================================
763 // function : GeometryGUI::initialize()
764 // purpose : Called when GEOM module is created
765 //=======================================================================
766 void GeometryGUI::initialize( CAM_Application* app )
768 SalomeApp_Module::initialize( app );
770 // ----- create actions --------------
772 createGeomAction( 111, "IMPORT", "", (CTRL + Key_I) );
773 createGeomAction( 121, "EXPORT", "", (CTRL + Key_E) );
775 createGeomAction( 33, "DELETE", "", Key_Delete );
777 createGeomAction( 4011, "POINT" );
778 createGeomAction( 4012, "LINE" );
779 createGeomAction( 4013, "CIRCLE" );
780 createGeomAction( 4014, "ELLIPSE" );
781 createGeomAction( 4015, "ARC" );
782 createGeomAction( 4019, "CURVE" );
783 createGeomAction( 4016, "VECTOR" );
784 createGeomAction( 4017, "PLANE" );
785 createGeomAction( 4018, "WORK_PLANE" );
786 createGeomAction( 4020, "LOCAL_CS" );
788 createGeomAction( 4021, "BOX" );
789 createGeomAction( 4022, "CYLINDER" );
790 createGeomAction( 4023, "SPHERE" );
791 createGeomAction( 4024, "TORUS" );
792 createGeomAction( 4025, "CONE" );
794 createGeomAction( 4031, "EXTRUSION" );
795 createGeomAction( 4032, "REVOLUTION" );
796 createGeomAction( 4033, "FILLING" );
797 createGeomAction( 4034, "PIPE" );
799 createGeomAction( 800, "GROUP_CREATE" );
800 createGeomAction( 801, "GROUP_EDIT" );
802 createGeomAction( 9997, "Q_FACE" );
803 createGeomAction( 9999, "HEX_SOLID" );
805 createGeomAction( 404, "SKETCH" );
806 createGeomAction( 407, "EXPLODE" );
808 createGeomAction( 4081, "EDGE" );
809 createGeomAction( 4082, "WIRE" );
810 createGeomAction( 4083, "FACE" );
811 createGeomAction( 4084, "SHELL" );
812 createGeomAction( 4085, "SOLID" );
813 createGeomAction( 4086, "COMPOUND" );
815 createGeomAction( 5011, "FUSE" );
816 createGeomAction( 5012, "COMMON" );
817 createGeomAction( 5013, "CUT" );
818 createGeomAction( 5014, "SECTION" );
820 createGeomAction( 5021, "TRANSLATION" );
821 createGeomAction( 5022, "ROTATION" );
822 createGeomAction( 5023, "MODIFY_LOCATION" );
823 createGeomAction( 5024, "MIRROR" );
824 createGeomAction( 5025, "SCALE" );
825 createGeomAction( 5026, "OFFSET" );
826 createGeomAction( 5027, "MUL_TRANSLATION" );
827 createGeomAction( 5028, "MUL_ROTATION" );
829 createGeomAction( 503, "PARTITION" );
830 createGeomAction( 504, "ARCHIMEDE" );
831 createGeomAction( 505, "FILLET" );
832 createGeomAction( 506, "CHAMFER" );
833 //createGeomAction( 507, "CLIPPING" );
834 createGeomAction( 508, "GET_SHAPES_ON_SHAPES" );
836 createGeomAction( 9998, "MUL_TRANSFORM" );
837 createGeomAction( 9995, "EXPLODE_BLOCKS" );
838 createGeomAction( 99991, "PROPAGATE" );
840 createGeomAction( 601, "SEWING" );
841 createGeomAction( 602, "GLUE_FACES" );
842 createGeomAction( 603, "SUPPRESS_FACES" );
843 createGeomAction( 604, "SUPPERSS_HOLES" );
844 createGeomAction( 605, "SHAPE_PROCESS" );
845 createGeomAction( 606, "CLOSE_CONTOUR" );
846 createGeomAction( 607, "SUPPRESS_INT_WIRES" );
847 createGeomAction( 608, "POINT_ON_EDGE" );
848 createGeomAction( 609, "CHECK_FREE_BNDS" );
849 createGeomAction( 610, "CHECK_FREE_FACES" );
850 createGeomAction( 611, "CHANGE_ORIENTATION" );
851 createGeomAction( 612, "REMOVE_EXTRA_EDGES" );
853 createGeomAction( 708, "POINT_COORDS" );
854 createGeomAction( 701, "BASIC_PROPS" );
855 createGeomAction( 702, "MASS_CENTER" );
856 createGeomAction( 703, "INERTIA" );
857 createGeomAction( 704, "NORMALE" );
858 createGeomAction( 7041, "BND_BOX" );
859 createGeomAction( 7042, "MIN_DIST" );
860 createGeomAction( 7043, "MEASURE_ANGLE" );
862 createGeomAction( 705, "TOLERANCE" );
863 createGeomAction( 706, "WHAT_IS" );
864 createGeomAction( 707, "CHECK" );
865 createGeomAction( 7072, "CHECK_COMPOUND" );
867 #ifdef _DEBUG_ // PAL16821
868 createGeomAction( 5103, "CHECK_GEOMETRY" );
870 createGeomAction( 412, "SHADING_COLOR" );
872 createGeomAction( 211, "SHADING" );
873 createGeomAction( 212, "DISPLAY_ALL" );
874 createGeomAction( 214, "ERASE_ALL" );
875 createGeomAction( 216, "DISPLAY" );
876 createGeomAction( 2171, "VERTEX_SEL_ONLY" ,"", 0, true );
877 createGeomAction( 2172, "EDGE_SEL_ONLY", "", 0, true );
878 createGeomAction( 2173, "WIRE_SEL_ONLY", "", 0, true );
879 createGeomAction( 2174, "FACE_SEL_ONLY", "", 0, true );
880 createGeomAction( 2175, "SHELL_SEL_ONLY", "", 0, true );
881 createGeomAction( 2176, "SOLID_SEL_ONLY", "", 0, true );
882 createGeomAction( 2177, "COMPOUND_SEL_ONLY", "", 0, true );
883 createGeomAction( 2178, "ALL_SEL_ONLY", "", 0, true );
884 createGeomAction( 213, "DISPLAY_ONLY" );
885 createGeomAction( 215, "ERASE" );
887 createGeomAction( 901, "POP_RENAME", "", Key_F2 );
888 createGeomAction( 80311, "POP_WIREFRAME", "", 0, true );
889 createGeomAction( 80312, "POP_SHADING", "", 0, true );
890 createGeomAction( 8032, "POP_COLOR" );
891 createGeomAction( 8033, "POP_TRANSPARENCY" );
892 createGeomAction( 8034, "POP_ISOS" );
893 createGeomAction( 8035, "POP_AUTO_COLOR" );
894 createGeomAction( 8036, "POP_DISABLE_AUTO_COLOR" );
895 createGeomAction( 8001, "POP_CREATE_GROUP" );
897 // make wireframe-shading items to be exclusive (only one at a time is selected)
898 //QActionGroup* dispModeGr = new QActionGroup( this, "", true );
899 //dispModeGr->add( action( 80311 ) );
900 //dispModeGr->add( action( 80312 ) );
901 // ---- create menu --------------------------
903 int fileId = createMenu( tr( "MEN_FILE" ), -1, -1 );
904 createMenu( separator(), fileId, 10 );
905 createMenu( 111, fileId, 10 );
906 createMenu( 121, fileId, 10 );
907 createMenu( separator(), fileId, -1 );
909 int editId = createMenu( tr( "MEN_EDIT" ), -1, -1 );
910 createMenu( 33, editId, -1 );
912 int newEntId = createMenu( tr( "MEN_NEW_ENTITY" ), -1, -1, 10 );
914 int basicId = createMenu( tr( "MEN_BASIC" ), newEntId, -1 );
915 createMenu( 4011, basicId, -1 );
916 createMenu( 4012, basicId, -1 );
917 createMenu( 4013, basicId, -1 );
918 createMenu( 4014, basicId, -1 );
919 createMenu( 4015, basicId, -1 );
920 createMenu( 4019, basicId, -1 );
921 createMenu( separator(), basicId, -1 );
922 createMenu( 4016, basicId, -1 );
923 createMenu( 4017, basicId, -1 );
924 createMenu( 4018, basicId, -1 );
925 createMenu( 4020, basicId, -1 );
927 int primId = createMenu( tr( "MEN_PRIMITIVES" ), newEntId, -1 );
928 createMenu( 4021, primId, -1 );
929 createMenu( 4022, primId, -1 );
930 createMenu( 4023, primId, -1 );
931 createMenu( 4024, primId, -1 );
932 createMenu( 4025, primId, -1 );
934 int genId = createMenu( tr( "MEN_GENERATION" ), newEntId, -1 );
935 createMenu( 4031, genId, -1 );
936 createMenu( 4032, genId, -1 );
937 createMenu( 4033, genId, -1 );
938 createMenu( 4034, genId, -1 );
939 createMenu( separator(), newEntId, -1 );
941 int groupId = createMenu( tr( "MEN_GROUP" ), newEntId, -1 );
942 createMenu( 800, groupId, -1 );
943 createMenu( 801, groupId, -1 );
944 createMenu( separator(), newEntId, -1 );
946 int blocksId = createMenu( tr( "MEN_BLOCKS" ), newEntId, -1 );
947 createMenu( 9997, blocksId, -1 );
948 createMenu( 9999, blocksId, -1 );
950 createMenu( separator(), newEntId, -1 );
951 createMenu( 404, newEntId, -1 );
952 createMenu( separator(), newEntId, -1 );
953 createMenu( 407, newEntId, -1 );
955 int buildId = createMenu( tr( "MEN_BUILD" ), newEntId, -1 );
956 createMenu( 4081, buildId, -1 );
957 createMenu( 4082, buildId, -1 );
958 createMenu( 4083, buildId, -1 );
959 createMenu( 4084, buildId, -1 );
960 createMenu( 4085, buildId, -1 );
961 createMenu( 4086, buildId, -1 );
963 int operId = createMenu( tr( "MEN_OPERATIONS" ), -1, -1, 10 );
965 int boolId = createMenu( tr( "MEN_BOOLEAN" ), operId, -1 );
966 createMenu( 5011, boolId, -1 );
967 createMenu( 5012, boolId, -1 );
968 createMenu( 5013, boolId, -1 );
969 createMenu( 5014, boolId, -1 );
971 int transId = createMenu( tr( "MEN_TRANSFORMATION" ), operId, -1 );
972 createMenu( 5021, transId, -1 );
973 createMenu( 5022, transId, -1 );
974 createMenu( 5023, transId, -1 );
975 createMenu( 5024, transId, -1 );
976 createMenu( 5025, transId, -1 );
977 createMenu( 5026, transId, -1 );
978 createMenu( separator(), transId, -1 );
979 createMenu( 5027, transId, -1 );
980 createMenu( 5028, transId, -1 );
982 createMenu( 503, operId, -1 );
983 createMenu( 504, operId, -1 );
984 createMenu( 508, operId, -1 );
985 createMenu( separator(), operId, -1 );
986 createMenu( 505, transId, -1 );
987 createMenu( 506, transId, -1 );
988 //createMenu( 507, transId, -1 );
990 int blockId = createMenu( tr( "MEN_BLOCKS" ), operId, -1 );
991 createMenu( 9998, blockId, -1 );
992 createMenu( 9995, blockId, -1 );
993 createMenu( 99991, blockId, -1 );
995 int repairId = createMenu( tr( "MEN_REPAIR" ), -1, -1, 10 );
996 createMenu( 605, repairId, -1 );
997 createMenu( 603, repairId, -1 );
998 createMenu( 606, repairId, -1 );
999 createMenu( 607, repairId, -1 );
1000 createMenu( 604, repairId, -1 );
1001 createMenu( 601, repairId, -1 );
1002 createMenu( 602, repairId, -1 );
1003 createMenu( 608, repairId, -1 );
1004 //createMenu( 609, repairId, -1 );
1005 //createMenu( 610, repairId, -1 );
1006 createMenu( 611, repairId, -1 );
1007 createMenu( 612, repairId, -1 );
1009 int measurId = createMenu( tr( "MEN_MEASURES" ), -1, -1, 10 );
1010 createMenu( 708, measurId, -1 );
1011 createMenu( 701, measurId, -1 );
1012 createMenu( separator(), measurId, -1 );
1013 createMenu( 702, measurId, -1 );
1014 createMenu( 703, measurId, -1 );
1015 createMenu( 704, measurId, -1 );
1016 // NPAL16572: move "Check free boundaries" and "Check free faces" from "Repair" to "Measure"
1017 createMenu( separator(), measurId, -1 );
1018 createMenu( 609, measurId, -1 );
1019 createMenu( 610, measurId, -1 );
1021 createMenu( separator(), measurId, -1 );
1023 int dimId = createMenu( tr( "MEN_DIMENSIONS" ), measurId, -1 );
1024 createMenu( 7041, dimId, -1 );
1025 createMenu( 7042, dimId, -1 );
1026 createMenu( 7043, dimId, -1 );
1027 createMenu( separator(), measurId, -1 );
1029 createMenu( 705, measurId, -1 );
1030 createMenu( separator(), measurId, -1 );
1031 createMenu( 706, measurId, -1 );
1032 createMenu( 707, measurId, -1 );
1033 createMenu( 7072, measurId, -1 );
1035 #ifdef _DEBUG_ // PAL16821
1036 int toolsId = createMenu( tr( "MEN_TOOLS" ), -1, -1, 50 );
1037 createMenu( separator(), toolsId, -1 );
1038 createMenu( 5103, toolsId, -1 );
1040 //int prefId = createMenu( tr( "MEN_PREFERENCES" ), -1, -1, 50 );
1041 //createMenu( separator(), prefId, -1 );
1042 //int geomId = createMenu( tr( "MEN_PREFERENCES_GEOM" ), prefId, -1 );
1043 //createMenu( 412, geomId, -1 );
1044 //createMenu( separator(), prefId, -1 );
1046 int viewId = createMenu( tr( "MEN_VIEW" ), -1, -1 );
1047 createMenu( separator(), viewId, -1 );
1049 int dispmodeId = createMenu( tr( "MEN_DISPLAY_MODE" ), viewId, -1 );
1050 createMenu( 211, dispmodeId, -1 );
1052 createMenu( separator(), viewId, -1 );
1053 createMenu( 212, viewId, -1 );
1054 createMenu( 214, viewId, -1 );
1055 createMenu( separator(), viewId, -1 );
1059 because of these items are accessible through object browser and viewers
1060 we have removed they from main menu
1062 createMenu( 216, viewId, -1 );
1063 createMenu( 213, viewId, -1 );
1064 createMenu( 215, viewId, -1 );
1067 // ---- create toolbars --------------------------
1069 int basicTbId = createTool( tr( "TOOL_BASIC" ) );
1070 createTool( 4011, basicTbId );
1071 createTool( 4012, basicTbId );
1072 createTool( 4013, basicTbId );
1073 createTool( 4014, basicTbId );
1074 createTool( 4015, basicTbId );
1075 createTool( 4019, basicTbId );
1076 createTool( 4016, basicTbId );
1077 createTool( 4017, basicTbId );
1078 createTool( 4018, basicTbId );
1079 createTool( 4020, basicTbId );
1081 int primTbId = createTool( tr( "TOOL_PRIMITIVES" ) );
1082 createTool( 4021, primTbId );
1083 createTool( 4022, primTbId );
1084 createTool( 4023, primTbId );
1085 createTool( 4024, primTbId );
1086 createTool( 4025, primTbId );
1088 int boolTbId = createTool( tr( "TOOL_BOOLEAN" ) );
1089 createTool( 5011, boolTbId );
1090 createTool( 5012, boolTbId );
1091 createTool( 5013, boolTbId );
1092 createTool( 5014, boolTbId );
1094 int genTbId = createTool( tr( "TOOL_GENERATION" ) );
1095 createTool( 4031, genTbId );
1096 createTool( 4032, genTbId );
1097 createTool( 4033, genTbId );
1098 createTool( 4034, genTbId );
1100 int transTbId = createTool( tr( "TOOL_TRANSFORMATION" ) );
1101 createTool( 5021, transTbId );
1102 createTool( 5022, transTbId );
1103 createTool( 5023, transTbId );
1104 createTool( 5024, transTbId );
1105 createTool( 5025, transTbId );
1106 createTool( 5026, transTbId );
1107 createTool( separator(), transTbId );
1108 createTool( 5027, transTbId );
1109 createTool( 5028, transTbId );
1111 // ---- create popup menus --------------------------
1113 QString clientOCCorVTK = "(client='OCCViewer' or client='VTKViewer')";
1114 QString clientOCCorVTK_AndSomeVisible = clientOCCorVTK + " and selcount>0 and isVisible";
1116 QString clientOCCorVTKorOB = "(client='ObjectBrowser' or client='OCCViewer' or client='VTKViewer')";
1117 QString clientOCCorVTKorOB_AndSomeVisible = clientOCCorVTKorOB + " and selcount>0 and isVisible";
1119 QString autoColorPrefix =
1120 "(client='ObjectBrowser' or client='OCCViewer') and type='Shape' and selcount=1 and isOCC=true";
1122 QtxPopupMgr* mgr = popupMgr();
1123 mgr->insert( action( 901 ), -1, -1 ); // rename
1124 mgr->setRule( action( 901 ), "$type in {'Shape' 'Group'} and selcount=1", true );
1125 mgr->insert( action( 33 ), -1, -1 ); // delete
1126 mgr->setRule( action( 33 ), "$type in {'Shape' 'Group'} and selcount>0", true );
1127 mgr->insert( action( 8001 ), -1, -1 ); // create group
1128 mgr->setRule( action( 8001 ), "client='ObjectBrowser' and type='Shape' and selcount=1 and isOCC=true", true );
1129 mgr->insert( action( 801 ), -1, -1 ); // edit group
1130 mgr->setRule( action( 801 ), "client='ObjectBrowser' and type='Group' and selcount=1 and isOCC=true", true );
1131 mgr->insert( separator(), -1, -1 ); // -----------
1132 dispmodeId = mgr->insert( tr( "MEN_DISPLAY_MODE" ), -1, -1 ); // display mode menu
1133 mgr->insert( action( 80311 ), dispmodeId, -1 ); // wireframe
1134 mgr->setRule( action( 80311 ), clientOCCorVTK_AndSomeVisible, true );
1135 mgr->setRule( action( 80311 ), clientOCCorVTK + " and displaymode='Wireframe'", false );
1136 mgr->insert( action( 80312 ), dispmodeId, -1 ); // shading
1137 mgr->setRule( action( 80312 ), clientOCCorVTK_AndSomeVisible, true );
1138 mgr->setRule( action( 80312 ), clientOCCorVTK + " and displaymode='Shading'", false );
1139 mgr->insert( separator(), -1, -1 ); // -----------
1140 mgr->insert( action( 8032 ), -1, -1 ); // color
1141 mgr->setRule( action( 8032 ), clientOCCorVTKorOB_AndSomeVisible + " and ($component={'GEOM'})", true );
1142 mgr->insert( action( 8033 ), -1, -1 ); // transparency
1143 mgr->setRule( action( 8033 ), clientOCCorVTK_AndSomeVisible, true );
1144 mgr->insert( action( 8034 ), -1, -1 ); // isos
1145 mgr->setRule( action( 8034 ), clientOCCorVTK_AndSomeVisible + " and selcount>0 and isVisible", true );
1146 mgr->insert( separator(), -1, -1 ); // -----------
1147 mgr->insert( action( 8035 ), -1, -1 ); // auto color
1148 mgr->setRule( action( 8035 ), autoColorPrefix + " and isAutoColor=false", true );
1149 mgr->insert( action( 8036 ), -1, -1 ); // disable auto color
1150 mgr->setRule( action( 8036 ), autoColorPrefix + " and isAutoColor=true", true );
1151 mgr->insert( separator(), -1, -1 ); // -----------
1154 QString canDisplay = "($component={'GEOM'}) and (selcount>0) and ({true} in $canBeDisplayed) ",
1155 onlyComponent = "((type='Component') and selcount=1)",
1156 rule = canDisplay + "and ((($type in {%1}) and( %2 )) or " + onlyComponent + ")",
1157 types = "'Shape' 'Group'";
1159 mgr->insert( action( 216 ), -1, -1 ); // display
1160 mgr->setRule( action( 216 ), rule.arg( types ).arg( "not isVisible" ), true );
1162 mgr->insert( action( 215 ), -1, -1 ); // erase
1163 mgr->setRule( action( 215 ), rule.arg( types ).arg( "isVisible" ), true );
1165 mgr->insert( action( 214 ), -1, -1 ); // erase All
1166 mgr->setRule( action( 214 ), clientOCCorVTK, true );
1168 QString selectOnly = "(client='OCCViewer' or client='VTKViewer') and (selcount=0)";
1170 int selectolnyId = mgr->insert( tr("MEN_SELECT_ONLY"), -1, -1); //select only menu
1171 mgr->insert( action(2171), selectolnyId, -1); //Vertex
1172 mgr->setRule(action(2171), selectOnly, true);
1173 mgr->setRule(action(2171), selectOnly + " and selectionmode='VERTEX'", false);
1174 mgr->insert( action(2172), selectolnyId, -1); //Edge
1175 mgr->setRule(action(2172), selectOnly, true);
1176 mgr->setRule(action(2172), selectOnly + " and selectionmode='EDGE'", false);
1177 mgr->insert( action(2173), selectolnyId, -1); //Wire
1178 mgr->setRule(action(2173), selectOnly, true);
1179 mgr->setRule(action(2173), selectOnly + " and selectionmode='WIRE'", false);
1180 mgr->insert( action(2174), selectolnyId, -1); //Face
1181 mgr->setRule(action(2174), selectOnly, true);
1182 mgr->setRule(action(2174), selectOnly + " and selectionmode='FACE'", false);
1183 mgr->insert( action(2175), selectolnyId, -1); //Shell
1184 mgr->setRule(action(2175), selectOnly, true);
1185 mgr->setRule(action(2175), selectOnly + " and selectionmode='SHELL'", false);
1186 mgr->insert( action(2176), selectolnyId, -1); //Solid
1187 mgr->setRule(action(2176), selectOnly, true);
1188 mgr->setRule(action(2176), selectOnly + " and selectionmode='SOLID'", false);
1189 mgr->insert( action(2177), selectolnyId, -1); //Compound
1190 mgr->setRule(action(2177), selectOnly, true);
1191 mgr->setRule(action(2177), selectOnly + " and selectionmode='COMPOUND'", false);
1192 mgr->insert( separator(), selectolnyId, -1);
1193 mgr->insert( action(2178), selectolnyId, -1); //Clear selection filter
1194 mgr->setRule(action(2178), selectOnly, true);
1195 mgr->setRule(action(2178), selectOnly + " and selectionmode='ALL'", false);
1197 mgr->insert( action( 213 ), -1, -1 ); // display only
1198 mgr->setRule( action( 213 ), rule.arg( types ).arg( "true" ), true );
1199 mgr->insert( separator(), -1, -1 );
1201 mgr->hide( mgr->actionId( action( myEraseAll ) ) );
1204 //=======================================================================
1205 // function : GeometryGUI::activateModule()
1206 // purpose : Called when GEOM module is activated
1207 //=======================================================================
1208 bool GeometryGUI::activateModule( SUIT_Study* study )
1210 if ( CORBA::is_nil( myComponentGeom ) )
1213 bool res = SalomeApp_Module::activateModule( study );
1218 setMenuShown( true );
1219 setToolShown( true );
1221 connect( application()->desktop(), SIGNAL( windowActivated( SUIT_ViewWindow* ) ),
1222 this, SLOT( onWindowActivated( SUIT_ViewWindow* ) ) );
1224 // Reset actions accelerator keys
1225 //action(111)->setAccel(QKeySequence(CTRL + Key_I)); // Import
1226 //action(121)->setAccel(QKeySequence(CTRL + Key_E)); // Export
1227 action(111)->setEnabled(true); // Import: CTRL + Key_I
1228 action(121)->setEnabled(true); // Export: CTRL + Key_E
1229 action( 33)->setEnabled(true); // Delete: Key_Delete
1230 action(901)->setEnabled(true); // Rename: Key_F2
1232 GUIMap::Iterator it;
1233 for ( it = myGUIMap.begin(); it != myGUIMap.end(); ++it )
1234 it.data()->activate( application()->desktop() );
1236 LightApp_SelectionMgr* sm = getApp()->selectionMgr();
1238 SUIT_ViewManager* vm;
1239 ViewManagerList OCCViewManagers, VTKViewManagers;
1240 application()->viewManagers( OCCViewer_Viewer::Type(), OCCViewManagers );
1241 for ( vm = OCCViewManagers.first(); vm; vm = OCCViewManagers.next() )
1242 myOCCSelectors.append( new GEOMGUI_OCCSelector( ((OCCViewer_ViewManager*)vm)->getOCCViewer(), sm ) );
1243 application()->viewManagers( SVTK_Viewer::Type(), VTKViewManagers );
1244 for ( vm = VTKViewManagers.first(); vm; vm = VTKViewManagers.next() )
1245 myVTKSelectors.append( new LightApp_VTKSelector( dynamic_cast<SVTK_Viewer*>( vm->getViewModel() ), sm ) );
1248 SALOME_ListIO selected;
1249 sm->selectedObjects( selected );
1250 sm->clearSelected();
1252 // disable OCC selectors
1253 getApp()->selectionMgr()->setEnabled( false, OCCViewer_Viewer::Type() );
1254 for ( GEOMGUI_OCCSelector* sr = myOCCSelectors.first(); sr; sr = myOCCSelectors.next() )
1255 sr->setEnabled(true);
1257 // disable VTK selectors
1258 getApp()->selectionMgr()->setEnabled( false, SVTK_Viewer::Type() );
1259 for ( LightApp_VTKSelector* sr = myVTKSelectors.first(); sr; sr = myVTKSelectors.next() )
1260 sr->setEnabled(true);
1262 sm->setSelectedObjects( selected, true ); //NPAL 19674
1268 //=======================================================================
1269 // function : GeometryGUI::deactivateModule()
1270 // purpose : Called when GEOM module is deactivated
1271 //=======================================================================
1272 bool GeometryGUI::deactivateModule( SUIT_Study* study )
1274 setMenuShown( false );
1275 setToolShown( false );
1277 disconnect( application()->desktop(), SIGNAL( windowActivated( SUIT_ViewWindow* ) ),
1278 this, SLOT( onWindowActivated( SUIT_ViewWindow* ) ) );
1280 EmitSignalCloseAllDialogs();
1282 GUIMap::Iterator it;
1283 for ( it = myGUIMap.begin(); it != myGUIMap.end(); ++it )
1284 it.data()->deactivate();
1286 // Unset actions accelerator keys
1287 //action(111)->setAccel(QKeySequence()); // Import
1288 //action(121)->setAccel(QKeySequence()); // Export
1289 action(111)->setEnabled(false); // Import: CTRL + Key_I
1290 action(121)->setEnabled(false); // Export: CTRL + Key_E
1291 action( 33)->setEnabled(false); // Delete: Key_Delete
1292 action(901)->setEnabled(false); // Rename: Key_F2
1294 myOCCSelectors.clear();
1295 getApp()->selectionMgr()->setEnabled( true, OCCViewer_Viewer::Type() );
1297 myVTKSelectors.clear();
1298 getApp()->selectionMgr()->setEnabled( true, SVTK_Viewer::Type() );
1300 return SalomeApp_Module::deactivateModule( study );
1303 //=================================================================================
1304 // function : GeometryGUI::DefinePopup()
1305 // purpose : Called from desktop to define popup menu [static]
1306 //=================================================================================
1308 void GeometryGUI::DefinePopup(QString& theContext, QString& theParent, QString& theObject)
1310 QAD_Study* ActiveStudy = QAD_Application::getDesktop()->getActiveStudy();
1311 SALOME_Selection* Sel = SALOME_Selection::Selection(ActiveStudy->getSelection());
1316 if ( theParent == "Viewer" ) {
1317 if ( Sel->IObjectCount() == 0 )
1318 theContext = "NothingSelected";
1321 if ( Sel->IObjectCount() == 1 ) {
1322 Handle(SALOME_InteractiveObject) IO = Sel->firstIObject();
1323 if( IO->hasEntry() ) {
1324 SALOMEDS::SObject_var sobj = ActiveStudy->getStudyDocument()->FindObjectID( IO->getEntry() );
1325 if ( !sobj->_is_nil() ) {
1326 SALOMEDS::SComponent_var scomp = sobj->GetFatherComponent();
1327 if ( !strcmp(scomp->GetID(), IO->getEntry() ) ) {
1328 // component is selected
1329 theObject = "Component";
1332 GEOM::GEOM_Object_var aGObj = GEOM::GEOM_Object::_narrow( sobj->GetObject() );
1333 if ( !CORBA::is_nil( aGObj ) ) {
1334 switch( aGObj->GetType() ) {
1336 theObject = "Group";
1339 theObject = "Shape";
1349 //=================================================================================
1350 // function : GeometryGUI::CustomPopup()
1351 // purpose : Called from desktop to create popup menu [static]
1352 //=================================================================================
1353 bool GeometryGUI::CustomPopup(QAD_Desktop* parent, QPopupMenu* popup, const QString& theContext,
1354 const QString& theParent, const QString& theObject)
1356 GeometryGUI* geomGUI = GetGeomGUI();
1358 // Deactivate any non modal dialog box to get the neutral point
1359 geomGUI->EmitSignalDeactivateDialog();
1360 QAD_Study* anActiveStudy = parent->getActiveStudy();
1361 QAD_StudyFrame* aStudyFrame = anActiveStudy->getActiveStudyFrame();
1362 QAD_ViewFrame* aViewFrame = aStudyFrame->getRightFrame()->getViewFrame();
1363 SALOME_Selection* Sel = SALOME_Selection::Selection(anActiveStudy->getSelection());
1364 QString parentComponent = ((SALOMEGUI_Desktop*)parent)->getComponentFromSelection();
1365 bool isOCCViewer = aViewFrame->getTypeView() == VIEW_OCC;
1366 bool isVTKViewer = aViewFrame->getTypeView() == VIEW_VTK;
1367 int aDisplayMode = 0;
1370 if ( aViewFrame->getTypeView() == VIEW_OCC )
1371 aDisplayMode = ((OCCViewer_ViewFrame*)aViewFrame)->getViewer()->getAISContext()->DisplayMode();
1372 else if ( aViewFrame->getTypeView() == VIEW_VTK )
1373 aDisplayMode = (dynamic_cast<SVTK_ViewFrame*>( aViewFrame )->getRWInteractor()->GetDisplayMode();
1375 int nbSel = Sel->IObjectCount();
1378 ////// NOTHING SELECTED
1381 else if ( nbSel == 1 ) {
1382 ////// SINGLE OBJECT SELECTION
1383 if ( parentComponent != parent->getActiveComponent() ) {
1384 ////// selected object does not belong to GEOM module:
1385 // remove all commands except Display/Erase...
1387 int id = popup->idAt( 0 );
1388 if ( id <= QAD_TopLabel_Popup_ID )
1389 popup->removeItemAt( 0 );
1395 ////// selected object belong to the GEOM module
1396 // get interactive object
1397 Handle(SALOME_InteractiveObject) IObject = Sel->firstIObject();
1398 objectName = IObject->getName();
1399 // if object has entry get SObject
1400 SALOMEDS::SObject_var SO;
1401 if ( IObject->hasEntry() )
1402 SO = anActiveStudy->getStudyDocument()->FindObjectID( IObject->getEntry() );
1404 if ( theObject == "Component" ) {
1405 ////// menu for component
1406 if ( !isOCCViewer && !isVTKViewer ) {
1407 popup->removeItem( QAD_DisplayOnly_Popup_ID );
1408 popup->removeItem( QAD_Display_Popup_ID );
1409 popup->removeItem( QAD_Erase_Popup_ID );
1413 ////// not component (should be shape)
1414 if ( IObject->hasEntry() ) /////// VSR : TO BE REMOVED
1415 popup->removeItem( 804 ); // "Add in Study"
1417 // Here could be analysis of the geom shape's type
1420 SALOMEDS::GenericAttribute_var aTmpAttr;
1421 if( SO->_is_nil() || SO->GetFatherComponent()->FindAttribute( aTmpAttr, "AttributeIOR") )
1422 popup->removeItem( 9024 ); // "Open" /////// VSR : TO BE REMOVED
1424 if ( !isOCCViewer && theParent == "ObjectBrowser" ) {
1425 if ( theObject == "Shape" )
1426 popup->removeItem( 800 ); // Create Group
1427 else if ( theObject == "Group" )
1428 popup->removeItem( 801 ); // Edit Group
1431 if ( isOCCViewer || isVTKViewer ) {
1432 ////// current viewer is OCC or VTK
1433 SALOME_Prs* prs = aViewFrame->CreatePrs( IObject->getEntry() );
1434 if ( aViewFrame->isVisible( IObject ) ) {
1435 ////// object is already displayed in the viewer
1436 popup->removeItem( QAD_Display_Popup_ID );
1437 if ( isOCCViewer ) {
1438 ////// OCC viewer only
1439 OCCViewer_Prs* occPrs = dynamic_cast<OCCViewer_Prs*>( prs );
1440 if ( occPrs && !occPrs->IsNull() ) {
1441 AIS_ListOfInteractive ioList;
1442 occPrs->GetObjects( ioList );
1443 QMenuItem* mi = popup->findItem( 803 );
1444 if ( mi && mi->popup() ) {
1445 if ( ioList.First()->DisplayMode() == 0 )
1446 mi->popup()->setItemChecked( 80311, true ); // "Wireframe"
1447 else if ( ioList.First()->DisplayMode() == 1 )
1448 mi->popup()->setItemChecked( 80312, true ); // "Shading"
1449 else if ( ioList.First()->DisplayMode() < 0 )
1450 mi->popup()->setItemChecked( aDisplayMode == 0 ? 80311 : 80312 , true ); // "Wireframe" or "Shading"
1455 ////// VTK viewer only
1456 //popup->removeItem( 8034 ); // "Isos"
1457 SVTK_Prs* vtkPrs = dynamic_cast<SVTK_Prs*>( prs );
1458 if ( vtkPrs && !vtkPrs->IsNull() ) {
1459 vtkActorCollection* actorList = vtkPrs->GetObjects();
1460 actorList->InitTraversal();
1461 SALOME_Actor* ac = SALOME_Actor::SafeDownCast( actorList->GetNextActor() );
1462 QMenuItem* mi = popup->findItem( 803 );
1463 if ( ac && mi && mi->popup() ) {
1464 if ( ac->getDisplayMode() == 0 )
1465 mi->popup()->setItemChecked( 80311, true ); // "Wireframe"
1466 else if ( ac->getDisplayMode() == 1 )
1467 mi->popup()->setItemChecked( 80312, true ); // "Shading"
1469 mi->popup()->setItemChecked( aDisplayMode == 0 ? 80311 : 80312 , true ); // "Wireframe" or "Shading"
1475 ////// object is not yet displayed in the viewer
1476 popup->removeItem( 803 ); // "Display Mode"
1477 popup->removeItem( 8032 ); // "Color"
1478 popup->removeItem( 8033 ); // "Transparency"
1479 popup->removeItem( 8034 ); // "Isos"
1480 popup->removeItem( QAD_Erase_Popup_ID );
1485 ////// other viewer type (neither OCC nor VTK)
1486 popup->removeItem( 803 ); // "Display Mode"
1487 popup->removeItem( 8032 ); // "Color"
1488 popup->removeItem( 8033 ); // "Transparency"
1489 popup->removeItem( 8034 ); // "Isos"
1490 popup->removeItem( QAD_Display_Popup_ID );
1491 popup->removeItem( QAD_DisplayOnly_Popup_ID );
1492 popup->removeItem( QAD_Erase_Popup_ID );
1498 ////// MULTIPLE SELECTION
1499 if ( parentComponent != parent->getActiveComponent() ) {
1500 ////// not GEOM module objects or objects belong to different modules
1501 // remove all commands except Display/Erase...
1503 int id = popup->idAt( 0 );
1504 if ( id <= QAD_TopLabel_Popup_ID )
1505 popup->removeItemAt( 0 );
1509 if ( parentComponent.isNull() ) {
1510 ////// objects belong to different modules
1511 popup->removeItem(QAD_Display_Popup_ID);
1512 popup->removeItem(QAD_DisplayOnly_Popup_ID);
1513 popup->removeItem(QAD_Erase_Popup_ID);
1516 objectName = tr( "GEOM_MEN_POPUP_NAME" ).arg( nbSel );
1520 ////// all selected objects belong to GEOM module
1521 popup->removeItem( 901 ); // "Rename"
1523 SALOME_ListIteratorOfListIO It( Sel->StoredIObjects() );
1524 bool isComponent = false;
1525 bool needOpen = false;
1526 bool needDisplay = false;
1527 bool needErase = false;
1528 int needToPublish = 0;
1530 for( ;It.More();It.Next() ) {
1531 Handle(SALOME_InteractiveObject) anIObject = It.Value();
1533 if ( aViewFrame->isVisible( anIObject ) )
1538 if( anIObject->hasEntry() ) {
1539 needToPublish = -1; /////// VSR : TO BE REMOVED
1540 SALOMEDS::SObject_var obj = anActiveStudy->getStudyDocument()->FindObjectID( anIObject->getEntry() );
1541 SALOMEDS::GenericAttribute_var aTmpAttr;
1542 if ( !obj->_is_nil() && !obj->GetFatherComponent()->FindAttribute( aTmpAttr, "AttributeIOR" ) )
1543 needOpen = true; /////// VSR : TO BE REMOVED
1544 if ( !obj->_is_nil() && QString( obj->GetID() ) == QString( obj->GetFatherComponent()->GetID() ) )
1548 if ( needToPublish != -1 ) needToPublish = 1;
1551 if( needOpen || ( !isOCCViewer && !isVTKViewer ) ) {
1552 ////// Data is not loaded yet or current viewer is neither OCC nor VTK
1553 popup->removeItem( 803 ); // "Display Mode"
1554 popup->removeItem( 8032 ); // "Color"
1555 popup->removeItem( 8033 ); // "Transparency"
1556 popup->removeItem( 8034 ); // "Isos"
1557 popup->removeItem( 804 ); // "Add in Study"
1558 popup->removeItem( QAD_DisplayOnly_Popup_ID );
1559 popup->removeItem( QAD_Display_Popup_ID );
1560 popup->removeItem( QAD_Erase_Popup_ID );
1563 popup->removeItem( 9024 ); // "Open"
1564 if ( needToPublish <= 0 )
1565 popup->removeItem( 804 ); // "Add in Study"
1568 popup->removeItem( 803 ); // "Display Mode"
1569 popup->removeItem( 8032 ); // "Color"
1570 popup->removeItem( 8033 ); // "Transparency"
1571 popup->removeItem( 8034 ); // "Isos"
1572 popup->removeItem( QAD_DisplayOnly_Popup_ID );
1576 popup->removeItem( QAD_Display_Popup_ID );
1578 popup->removeItem( QAD_Erase_Popup_ID );
1579 if ( !isOCCViewer && !isVTKViewer)
1580 popup->removeItem( 8034 ); // "Isos"
1585 // check popup for unnecessary separators
1586 QAD_Tools::checkPopup( popup );
1587 // find popup menu's TopLabel item (with title)
1588 int topItem = popup->indexOf( QAD_TopLabel_Popup_ID );
1589 if ( topItem >= 0 ) {
1590 // remove popup menu's title item
1591 popup->removeItem( QAD_TopLabel_Popup_ID );
1592 if ( theParent == "Viewer" && !objectName.isEmpty() && popup->count() > 0 ) {
1593 // set bold font for popup menu's title
1594 QFont f = popup->font(); f.setBold( TRUE );
1595 popup->removeItem( QAD_TopLabel_Popup_ID );
1596 popup->insertItem( new CustomItem( objectName, f ), QAD_TopLabel_Popup_ID, topItem );
1605 //=======================================================================
1606 // function : GeometryGUI::BuildPresentation()
1608 //=======================================================================
1609 void GeometryGUI::BuildPresentation( const Handle(SALOME_InteractiveObject)& io, SUIT_ViewWindow* win )
1611 //GEOM_Displayer().Display( io, false, win );
1614 //=======================================================================
1615 // function : onWindowActivated()
1616 // purpose : update menu items' status - disable non-OCC-viewer-compatible actions
1617 //=======================================================================
1618 void GeometryGUI::onWindowActivated( SUIT_ViewWindow* win )
1623 const bool ViewOCC = ( win->getViewManager()->getType() == OCCViewer_Viewer::Type() );
1624 const bool ViewVTK = ( win->getViewManager()->getType() == SVTK_Viewer::Type() );
1626 // disable non-OCC viewframe menu commands
1627 // action( 404 )->setEnabled( ViewOCC ); // SKETCHER
1628 action( 603 )->setEnabled( ViewOCC ); // SuppressFace
1629 action( 604 )->setEnabled( ViewOCC ); // SuppressHole
1630 action( 606 )->setEnabled( ViewOCC ); // CloseContour
1631 action( 607 )->setEnabled( ViewOCC ); // RemoveInternalWires
1632 action( 608 )->setEnabled( ViewOCC ); // AddPointOnEdge
1633 // action( 609 )->setEnabled( ViewOCC ); // Free boundaries
1635 action( 800 )->setEnabled( ViewOCC ); // Create Group
1636 action( 801 )->setEnabled( ViewOCC ); // Edit Group
1638 action( 9998 )->setEnabled( ViewOCC ); // MENU BLOCKS - MULTI-TRANSFORMATION
1641 void GeometryGUI::windows( QMap<int, int>& mappa ) const
1643 mappa.insert( SalomeApp_Application::WT_ObjectBrowser, Qt::DockLeft );
1644 mappa.insert( SalomeApp_Application::WT_PyConsole, Qt::DockBottom );
1647 void GeometryGUI::viewManagers( QStringList& lst ) const
1649 lst.append( OCCViewer_Viewer::Type() );
1652 void GeometryGUI::onViewManagerAdded( SUIT_ViewManager* vm )
1654 if ( vm->getType() == OCCViewer_Viewer::Type() )
1656 qDebug( "connect" );
1657 connect( vm, SIGNAL( keyPress ( SUIT_ViewWindow*, QKeyEvent* ) ),
1658 this, SLOT( OnKeyPress( SUIT_ViewWindow*, QKeyEvent* ) ) );
1659 connect( vm, SIGNAL( mousePress( SUIT_ViewWindow*, QMouseEvent* ) ),
1660 this, SLOT( OnMousePress( SUIT_ViewWindow*, QMouseEvent* ) ) );
1661 connect( vm, SIGNAL( mouseMove ( SUIT_ViewWindow*, QMouseEvent* ) ),
1662 this, SLOT( OnMouseMove( SUIT_ViewWindow*, QMouseEvent* ) ) );
1665 LightApp_SelectionMgr* sm = getApp()->selectionMgr();
1666 myOCCSelectors.append( new GEOMGUI_OCCSelector( ((OCCViewer_ViewManager*)vm)->getOCCViewer(), sm ) );
1668 // disable OCC selectors
1669 getApp()->selectionMgr()->setEnabled( false, OCCViewer_Viewer::Type() );
1670 for ( GEOMGUI_OCCSelector* sr = myOCCSelectors.first(); sr; sr = myOCCSelectors.next() )
1671 sr->setEnabled(true);
1673 else if ( vm->getType() == SVTK_Viewer::Type() )
1675 LightApp_SelectionMgr* sm = getApp()->selectionMgr();
1676 myVTKSelectors.append( new LightApp_VTKSelector( dynamic_cast<SVTK_Viewer*>( vm->getViewModel() ), sm ) );
1678 // disable VTK selectors
1679 getApp()->selectionMgr()->setEnabled( false, SVTK_Viewer::Type() );
1680 for ( LightApp_VTKSelector* sr = myVTKSelectors.first(); sr; sr = myVTKSelectors.next() )
1681 sr->setEnabled(true);
1685 void GeometryGUI::onViewManagerRemoved( SUIT_ViewManager* vm )
1687 SUIT_ViewModel* viewer = vm->getViewModel();
1688 if ( vm->getType() == OCCViewer_Viewer::Type() )
1690 for ( GEOMGUI_OCCSelector* sr = myOCCSelectors.first(); sr; sr = myOCCSelectors.next() )
1691 if ( sr->viewer() == viewer )
1693 myOCCSelectors.remove( sr );
1697 if ( vm->getType() == SVTK_Viewer::Type() )
1699 for ( LightApp_VTKSelector* sr = myVTKSelectors.first(); sr; sr = myVTKSelectors.next() )
1700 if ( sr->viewer() == viewer )
1702 myVTKSelectors.remove( sr );
1708 QString GeometryGUI::engineIOR() const
1710 if ( !CORBA::is_nil( GetGeomGen() ) )
1711 return QString( getApp()->orb()->object_to_string( GetGeomGen() ) );
1712 return QString( "" );
1715 LightApp_Selection* GeometryGUI::createSelection() const
1717 return new GEOMGUI_Selection();
1720 void GeometryGUI::contextMenuPopup( const QString& client, QPopupMenu* menu, QString& title )
1722 SalomeApp_Module::contextMenuPopup( client, menu, title );
1724 getApp()->selectionMgr()->selectedObjects( lst );
1725 if ( ( client == "OCCViewer" || client == "VTKViewer" ) && lst.Extent() == 1 ) {
1726 Handle(SALOME_InteractiveObject) io = lst.First();
1727 SalomeApp_Study* appStudy = dynamic_cast<SalomeApp_Study*>( application()->activeStudy() );
1728 _PTR(Study) study = appStudy->studyDS();
1729 _PTR(SObject) obj = study->FindObjectID( io->getEntry() );
1731 title = QString( obj->GetName().c_str() );
1735 void GeometryGUI::createPreferences()
1737 int tabId = addPreference( tr( "PREF_TAB_SETTINGS" ) );
1739 int genGroup = addPreference( tr( "PREF_GROUP_GENERAL" ), tabId );
1740 setPreferenceProperty( genGroup, "columns", 1 );
1742 int dispmode = addPreference( tr( "PREF_DISPLAY_MODE" ), genGroup,
1743 LightApp_Preferences::Selector, "Geometry", "display_mode" );
1745 addPreference( tr( "PREF_SHADING_COLOR" ), genGroup,
1746 LightApp_Preferences::Color, "Geometry", "shading_color" );
1748 addPreference( tr( "PREF_WIREFRAME_COLOR" ), genGroup,
1749 LightApp_Preferences::Color, "Geometry", "wireframe_color" );
1751 addPreference( tr( "PREF_FREE_BOUND_COLOR" ), genGroup,
1752 LightApp_Preferences::Color, "Geometry", "free_bound_color" );
1754 addPreference( tr( "PREF_LINE_COLOR"), genGroup,
1755 LightApp_Preferences::Color, "Geometry", "line_color" );
1757 addPreference( tr( "PREF_POINT_COLOR"), genGroup,
1758 LightApp_Preferences::Color, "Geometry", "point_color" );
1760 addPreference( tr( "PREF_ISOS_COLOR" ), genGroup,
1761 LightApp_Preferences::Color, "Geometry", "isos_color" );
1763 int step = addPreference( tr( "PREF_STEP_VALUE" ), genGroup,
1764 LightApp_Preferences::IntSpin, "Geometry", "SettingsGeomStep" );
1766 int VertexGroup = addPreference( tr( "PREF_GROUP_VERTEX" ), tabId );
1768 int typeOfMarker = addPreference( tr( "PREF_TYPE_OF_MARKER" ), VertexGroup,
1769 LightApp_Preferences::Selector, "Geometry", "type_of_marker" );
1771 int markerScale = addPreference( tr( "PREF_MARKER_SCALE" ), VertexGroup,
1772 LightApp_Preferences::DblSpin, "Geometry", "marker_scale" );
1774 // Set property for default display mode
1775 QStringList aModesList;
1776 aModesList.append( tr("MEN_WIREFRAME") );
1777 aModesList.append( tr("MEN_SHADING") );
1779 QValueList<QVariant> anIndexesList;
1780 anIndexesList.append(0);
1781 anIndexesList.append(1);
1783 setPreferenceProperty( dispmode, "strings", aModesList );
1784 setPreferenceProperty( dispmode, "indexes", anIndexesList );
1786 // Set property for step value for spinboxes
1787 setPreferenceProperty( step, "min", 0.001 );
1788 setPreferenceProperty( step, "max", 10000 );
1789 setPreferenceProperty( step, "precision", 3 );
1791 // Set property for type of vertex marker
1792 QStringList aTypeOfMarkerList;
1793 QValueList<QVariant> anTypeOfMarkerIndexesList;
1795 aTypeOfMarkerList.append( tr("TOM_PLUS") );
1796 anTypeOfMarkerIndexesList.append(Aspect_TOM_PLUS);
1798 aTypeOfMarkerList.append( tr("TOM_POINT") );
1799 anTypeOfMarkerIndexesList.append(Aspect_TOM_POINT);
1801 aTypeOfMarkerList.append( tr("TOM_STAR") );
1802 anTypeOfMarkerIndexesList.append(Aspect_TOM_STAR);
1804 aTypeOfMarkerList.append( tr("TOM_O") );
1805 anTypeOfMarkerIndexesList.append(Aspect_TOM_O);
1807 aTypeOfMarkerList.append( tr("TOM_X") );
1808 anTypeOfMarkerIndexesList.append(Aspect_TOM_X);
1810 aTypeOfMarkerList.append( tr("TOM_O_POINT") );
1811 anTypeOfMarkerIndexesList.append(Aspect_TOM_O_POINT);
1813 aTypeOfMarkerList.append( tr("TOM_O_PLUS") );
1814 anTypeOfMarkerIndexesList.append(Aspect_TOM_O_PLUS);
1816 aTypeOfMarkerList.append( tr("TOM_O_STAR") );
1817 anTypeOfMarkerIndexesList.append(Aspect_TOM_O_STAR);
1819 aTypeOfMarkerList.append( tr("TOM_O_X") );
1820 anTypeOfMarkerIndexesList.append(Aspect_TOM_O_X);
1823 setPreferenceProperty( typeOfMarker, "strings", aTypeOfMarkerList );
1824 setPreferenceProperty( typeOfMarker, "indexes", anTypeOfMarkerIndexesList );
1826 // Set property for Vertex Marker scale
1827 setPreferenceProperty( markerScale, "min", 1. );
1828 setPreferenceProperty( markerScale, "max", 7. );
1829 setPreferenceProperty( markerScale, "precision", 0.01 );
1830 setPreferenceProperty( markerScale, "step", 0.5 );
1834 void GeometryGUI::preferencesChanged( const QString& section, const QString& param )
1836 if (section == "Geometry") {
1837 SUIT_ResourceMgr* aResourceMgr = SUIT_Session::session()->resourceMgr();
1838 if (param == QString("SettingsGeomStep")) {
1839 double spin_step = aResourceMgr->doubleValue(section, param, 100.);
1840 EmitSignalDefaultStepValueChanged(spin_step);
1845 LightApp_Displayer* GeometryGUI::displayer()
1848 myDisplayer = new GEOM_Displayer( dynamic_cast<SalomeApp_Study*>( getApp()->activeStudy() ) );
1852 void GeometryGUI::setLocalSelectionMode(const int mode)
1854 myLocalSelectionMode = mode;
1856 int GeometryGUI::getLocalSelectionMode() const
1858 return myLocalSelectionMode;