foreach ( const int anId, anObsoleteIds ) {
myViewManagerMap.remove( anId );
myObjectStateMap.remove( anId );
- myObjectDisplayOrderMap.remove( anId );
myShapesMap.remove( anId );
myVTKPrsMap.remove( anId );
}
bool anIsDummyObject3D = false;
bool anIsGroup = false;
bool anIsObjectCanBeColored = false;
+ bool isRoot = false;
+
+ SUIT_SelectionMgr* aSelectionMgr = getApp()->selectionMgr();
+ SUIT_DataOwnerPtrList anOwners;
+ aSelectionMgr->selected( anOwners );
+ if( anIsObjectBrowser && anOwners.size()==1 )
+ {
+ QString anEntry = anOwners[0]->keyString();
+ LightApp_Study* aStudy = dynamic_cast<LightApp_Study*>( getApp()->activeStudy() );
+ if( aStudy )
+ isRoot = aStudy->isComponent( anEntry );
+ }
// Check the selected GEOM objects (take into account the Object Browser only)
if ( anIsObjectBrowser ) {
HYDROGUI_PolylineOp* aPolylineOp = dynamic_cast<HYDROGUI_PolylineOp*>( anOp );
if ( aPolylineOp && aPolylineOp->deleteEnabled() )
theMenu->addAction( action( DeleteId ) );
+
+ theMenu->addSeparator();
+ theMenu->addAction( action( SetZLevelId ) );
+ theMenu->addSeparator();
}
if( anIsObjectBrowser || anIsGraphicsView || anIsOCCView || anIsVTKView )
theMenu->addAction( action( HideAllId ) );
theMenu->addSeparator();
}
- if ( anIsOCCView || anIsVTKView ) {
+
+ if ( anIsOCCView || anIsVTKView )
+ {
theMenu->addSeparator();
theMenu->addAction( action( CopyViewerPositionId ) );
}
+
+ if( isRoot )
+ theMenu->addAction( action( EditLocalCSId ) );
}
void HYDROGUI_Module::update( const int flags )
ObjectState& anObjectState = aEntry2ObjectStateMap[ anEntry ];
anObjectState.Visibility = theState;
-
- // Remember the display order ( needed for Z layers assignment only )
- QStringList& anObjectEntries = myObjectDisplayOrderMap[ theViewId ];
- anObjectEntries.removeAll( anEntry );
- if ( theState ) {
- anObjectEntries.append( anEntry );
- }
}
}
void HYDROGUI_Module::onMouseMove( SUIT_ViewWindow* theViewWindow, QMouseEvent* )
{
- double aX, aY, aZ;
+ double X, Y, Z;
bool doShow = false;
HYDROGUI_Displayer* aDisplayer = getDisplayer();
if ( aDisplayer )
aDisplayer->SaveCursorViewPosition( theViewWindow );
- doShow = aDisplayer->GetCursorViewCoordinates( theViewWindow, aX, aY, aZ );
+ doShow = aDisplayer->GetCursorViewCoordinates( theViewWindow, X, Y, Z );
if ( doShow )
{
// Show the coordinates in the status bar
SUIT_Desktop* aDesktop = getApp()->desktop();
- if ( aDesktop && aDesktop->statusBar() ) {
- QString aXStr = HYDROGUI_Tool::GetCoordinateString( aX );
- QString anYStr = HYDROGUI_Tool::GetCoordinateString( aY );
- aDesktop->statusBar()->showMessage( tr("COORDINATES_INFO").arg( aXStr ).arg( anYStr ) );
+ if ( aDesktop && aDesktop->statusBar() )
+ {
+ gp_Pnt aWPnt( X, Y, Z );
+ int aStudyId = application()->activeStudy()->id();
+ HYDROData_Document::Document( aStudyId )->Transform( aWPnt, false );
+ double WX = aWPnt.X(), WY = aWPnt.Y();
+
+ QString aXStr = HYDROGUI_Tool::GetCoordinateString( X, true );
+ QString anYStr = HYDROGUI_Tool::GetCoordinateString( Y, true );
+ QString aWXStr = HYDROGUI_Tool::GetCoordinateString( WX, true );
+ QString aWYStr = HYDROGUI_Tool::GetCoordinateString( WY, true );
+ QString aMsg = tr( "COORDINATES_INFO" );
+ aMsg = aMsg.arg( aXStr ).arg( anYStr ).arg( aWXStr ).arg( aWYStr );
+ aDesktop->statusBar()->showMessage( aMsg );
}
}
}
-/**
- * Get the object display order. Needed for Z layers assignment only.
- */
-int HYDROGUI_Module::getObjectDisplayOrder(
- const int theViewId, const Handle(HYDROData_Entity)& theObject) const
-{
- if( theObject.IsNull() )
- return -1;
-
- QString anEntry = HYDROGUI_DataObject::dataObjectEntry( theObject );
- QStringList anObjectEntries = myObjectDisplayOrderMap.value( theViewId );
-
- return anObjectEntries.indexOf( anEntry );
-}
-
/**
* Returns stack of active operations;
*/