Implementation of 0022617: [CEA 1060] In OCC view, add "Show vertices" in the contextual menu.

This commit is contained in:
akl 2014-08-27 11:03:29 +04:00
parent 50dba628d8
commit b23bafd42b
20 changed files with 240 additions and 6 deletions

View File

@ -11,10 +11,9 @@ box2 = geompy.MakeBox(-50,-50,-50, 0,0,0)
sphere = geompy.MakeSphere(50,50,50, 30) sphere = geompy.MakeSphere(50,50,50, 30)
fuse = geompy.MakeBoolean(box,sphere,3) fuse = geompy.MakeBoolean(box,sphere,3)
fuse_id = geompy.addToStudy(fuse,"Fuse") fuse_id = geompy.addToStudy(fuse,"Fuse")
box_id = geompy.addToStudy(box2, "Box")
gg = salome.ImportComponentGUI("GEOM") gg = salome.ImportComponentGUI("GEOM")
gg.createAndDisplayGO(fuse_id) gg.createAndDisplayGO(fuse_id)
gg.setDisplayMode(fuse_id,1) gg.setDisplayMode(fuse_id,1)
gg.createAndDisplayGO(box_id) gg.setVectorsMode(fuse_id, 1)
gg.setVectorsMode(box_id, 1) gg.setVerticesMode(fuse_id, 1)

View File

@ -29,6 +29,17 @@ functionality for all objects in the current view via the main menu
\n <b>TUI Command:</b> <em>gg.setVectorsMode(ID, Bool)</em> \n <b>TUI Command:</b> <em>gg.setVectorsMode(ID, Bool)</em>
\n Also it is possible to show the vertices of the selected
shape. For this, choose in the context menu of the shape
<b>Display mode -> Show Vertices</b>, or apply this
functionality for all objects in the current view via the main menu
<b> View -> Display Mode -> Show/Hide Vertices.</b>
\image html vertices_mode.png
<center><em>Vertices Mode (Show Vertices)</em></center>
\n <b>TUI Command:</b> <em>gg.setVerticesMode(ID, Bool)</em>
Our <b>TUI Scripts</b> provide you with useful examples of Our <b>TUI Scripts</b> provide you with useful examples of
\ref tui_change_disp_mode "Changing Display Parameters". \ref tui_change_disp_mode "Changing Display Parameters".

View File

@ -136,6 +136,12 @@ bool DisplayGUI::OnGUIEvent(int theCommandID, SUIT_Desktop* parent)
( GetVectorMode() ? tr("MEN_VECTOR_MODE_ON") : tr( "MEN_VECTOR_MODE_OFF" ) ); ( GetVectorMode() ? tr("MEN_VECTOR_MODE_ON") : tr( "MEN_VECTOR_MODE_OFF" ) );
getGeometryGUI()->menuMgr()->update(); getGeometryGUI()->menuMgr()->update();
break; break;
case GEOMOp::OpSwitchVertices: // MENU VIEW - DISPLAY MODE - SHOW/HIDE VERTICES
SetVerticesMode(!GetVerticesMode());
getGeometryGUI()->action( GEOMOp::OpSwitchVertices )->setText
( GetVerticesMode() ? tr("MEN_VERTICES_MODE_ON") : tr( "MEN_VERTICES_MODE_OFF" ) );
getGeometryGUI()->menuMgr()->update();
break;
case GEOMOp::OpWireframe: // POPUP MENU - DISPLAY MODE - WIREFRAME case GEOMOp::OpWireframe: // POPUP MENU - DISPLAY MODE - WIREFRAME
ChangeDisplayMode( 0 ); ChangeDisplayMode( 0 );
break; break;
@ -151,6 +157,9 @@ bool DisplayGUI::OnGUIEvent(int theCommandID, SUIT_Desktop* parent)
case GEOMOp::OpVectors: // POPUP MENU - DISPLAY MODE - SHOW EDGE DIRECTION case GEOMOp::OpVectors: // POPUP MENU - DISPLAY MODE - SHOW EDGE DIRECTION
ChangeDisplayMode( 4 ); ChangeDisplayMode( 4 );
break; break;
case GEOMOp::OpVertices: // POPUP MENU - DISPLAY MODE - SHOW VERTICES
ChangeDisplayMode( 5 );
break;
default: default:
app->putInfo(tr("GEOM_PRP_COMMAND").arg(theCommandID)); app->putInfo(tr("GEOM_PRP_COMMAND").arg(theCommandID));
break; break;
@ -485,6 +494,52 @@ int DisplayGUI::GetVectorMode( SUIT_ViewWindow* viewWindow )
return viewWindow->property( "VectorsMode" ).toBool(); return viewWindow->property( "VectorsMode" ).toBool();
} }
//=====================================================================================
// function : DisplayGUI::SetVerticesMode()
// purpose : Set vertices mode for the viewer
//=====================================================================================
void DisplayGUI::SetVerticesMode( const bool mode, SUIT_ViewWindow* viewWindow )
{
SUIT_OverrideCursor();
SalomeApp_Application* app = getGeometryGUI()->getApp();
if ( !app ) return;
SalomeApp_Study* aStudy = dynamic_cast< SalomeApp_Study* >( app->activeStudy() );
if ( !aStudy ) return;
if ( !viewWindow )
viewWindow = app->desktop()->activeWindow();
GEOM_Displayer displayer( aStudy );
viewWindow->setProperty( "VerticesMode", mode );
int aMgrId = viewWindow->getViewManager()->getGlobalId();
SALOME_ListIO anIOlst;
displayer.GetActiveView()->GetVisible( anIOlst );
for ( SALOME_ListIteratorOfListIO It( anIOlst ); It.More(); It.Next() ) {
Handle( SALOME_InteractiveObject ) io = It.Value();
aStudy->setObjectProperty( aMgrId, io->getEntry(), GEOM::propertyName( GEOM::Vertices ), mode );
displayer.Redisplay( io, false );
}
displayer.UpdateViewer();
GeometryGUI::Modified();
}
//=====================================================================================
// function : DisplayGUI::GetVerticesMode()
// purpose : Get the "show vertices" mode of the viewer
//=====================================================================================
int DisplayGUI::GetVerticesMode( SUIT_ViewWindow* viewWindow )
{
if ( !viewWindow )
viewWindow = getGeometryGUI()->getApp()->desktop()->activeWindow();
return viewWindow->property( "VerticesMode" ).toBool();
}
//===================================================================================== //=====================================================================================
// function : DisplayGUI::ChangeDisplayMode() // function : DisplayGUI::ChangeDisplayMode()
// purpose : Set display mode for selected objects in the viewer given // purpose : Set display mode for selected objects in the viewer given
@ -516,6 +571,8 @@ void DisplayGUI::ChangeDisplayMode( const int mode, SUIT_ViewWindow* viewWindow
QVariant v = aStudy->getObjectProperty( mgrId, selected.First()->getEntry(), GEOM::propertyName( GEOM::EdgesDirection ), QVariant() ); QVariant v = aStudy->getObjectProperty( mgrId, selected.First()->getEntry(), GEOM::propertyName( GEOM::EdgesDirection ), QVariant() );
bool vectorMode = v.isValid() ? !v.toBool() : false; bool vectorMode = v.isValid() ? !v.toBool() : false;
v = aStudy->getObjectProperty( mgrId, selected.First()->getEntry(), GEOM::propertyName( GEOM::Vertices ), QVariant() );
bool verticesMode = v.isValid() ? !v.toBool() : false;
for ( SALOME_ListIteratorOfListIO It( selected ); It.More(); It.Next() ) { for ( SALOME_ListIteratorOfListIO It( selected ); It.More(); It.Next() ) {
Handle( SALOME_InteractiveObject ) io = It.Value(); Handle( SALOME_InteractiveObject ) io = It.Value();
@ -525,6 +582,9 @@ void DisplayGUI::ChangeDisplayMode( const int mode, SUIT_ViewWindow* viewWindow
else if ( mode == 4 ) { else if ( mode == 4 ) {
aStudy->setObjectProperty( mgrId, io->getEntry(), GEOM::propertyName( GEOM::EdgesDirection ), vectorMode ); aStudy->setObjectProperty( mgrId, io->getEntry(), GEOM::propertyName( GEOM::EdgesDirection ), vectorMode );
} }
else if ( mode == 5 ) {
aStudy->setObjectProperty( mgrId, io->getEntry(), GEOM::propertyName( GEOM::Vertices ), verticesMode );
}
displayer.Redisplay( io, false ); displayer.Redisplay( io, false );
} }
displayer.UpdateViewer(); displayer.UpdateViewer();

View File

@ -69,6 +69,12 @@ public:
int GetVectorMode( SUIT_ViewWindow* = 0 ); int GetVectorMode( SUIT_ViewWindow* = 0 );
// Invert vector mode ( shadin <-> wireframe ) for the viewer // Invert vector mode ( shadin <-> wireframe ) for the viewer
// VERTICES MODE methods
// Set vertices mode for the viewer
void SetVerticesMode( const bool, SUIT_ViewWindow* = 0 );
// Get vertices mode of the viewer
int GetVerticesMode( SUIT_ViewWindow* = 0 );
// Set display mode for selected objects in the viewer given // Set display mode for selected objects in the viewer given
// (current viewer if <viewWindow> = 0 ) // (current viewer if <viewWindow> = 0 )
void ChangeDisplayMode( const int, SUIT_ViewWindow* = 0 ); void ChangeDisplayMode( const int, SUIT_ViewWindow* = 0 );

View File

@ -171,6 +171,8 @@ QVariant GEOMGUI_Selection::parameter( const int idx, const QString& p ) const
v = isAutoColor( idx ); v = isAutoColor( idx );
else if ( p == "isVectorsMode" ) else if ( p == "isVectorsMode" )
v = isVectorsMode( idx ); v = isVectorsMode( idx );
else if ( p == "isVerticesMode" )
v = isVerticesMode( idx );
else if ( p == "topLevel" ) else if ( p == "topLevel" )
v = topLevel( idx ); v = topLevel( idx );
else if ( p == "autoBringToFront" ) else if ( p == "autoBringToFront" )
@ -428,6 +430,53 @@ bool GEOMGUI_Selection::isVectorsMode( const int index ) const
return res; return res;
} }
bool GEOMGUI_Selection::isVerticesMode( const int index ) const
{
#ifdef USE_VISUAL_PROP_MAP
QVariant v = visibleProperty( entry( index ), GEOM::propertyName( GEOM::Vertices ) );
if ( v.canConvert( QVariant::Bool ) )
return v.toBool();
#endif
bool res = false;
SALOME_View* view = GEOM_Displayer::GetActiveView();
QString viewType = activeViewType();
if ( view && ( viewType == OCCViewer_Viewer::Type() || viewType == SVTK_Viewer::Type() ) ) {
SALOME_Prs* prs = view->CreatePrs( entry( index ).toLatin1().constData() );
if ( prs ) {
if ( viewType == OCCViewer_Viewer::Type() ) { // assuming OCC
SOCC_Prs* occPrs = (SOCC_Prs*) prs;
AIS_ListOfInteractive lst;
occPrs->GetObjects( lst );
if ( lst.Extent() ) {
Handle(AIS_InteractiveObject) io = lst.First();
if ( !io.IsNull() ) {
Handle(GEOM_AISShape) aSh = Handle(GEOM_AISShape)::DownCast(io);
if ( !aSh.IsNull() )
res = aSh->isShowVertices();
}
}
}
else if ( viewType == SVTK_Viewer::Type() ) { // assuming VTK
SVTK_Prs* vtkPrs = dynamic_cast<SVTK_Prs*>( prs );
vtkActorCollection* lst = vtkPrs ? vtkPrs->GetObjects() : 0;
if ( lst ) {
lst->InitTraversal();
vtkActor* actor = lst->GetNextActor();
if ( actor ) {
GEOM_Actor* aGeomActor = GEOM_Actor::SafeDownCast(actor);
if ( aGeomActor )
res = aGeomActor->GetVerticesMode();
}
}
}
}
}
return res;
}
bool GEOMGUI_Selection::hasChildren( const _PTR(SObject)& obj ) bool GEOMGUI_Selection::hasChildren( const _PTR(SObject)& obj )
{ {
if ( obj ) { if ( obj ) {

View File

@ -67,6 +67,7 @@ private:
QString displayMode( const int ) const; QString displayMode( const int ) const;
QString selectionMode() const; QString selectionMode() const;
bool isVectorsMode( const int ) const; bool isVectorsMode( const int ) const;
bool isVerticesMode( const int ) const;
bool hasChildren( const int ) const; bool hasChildren( const int ) const;
int nbChildren( const int ) const; int nbChildren( const int ) const;
bool hasConcealedChildren( const int ) const; bool hasConcealedChildren( const int ) const;

View File

@ -871,6 +871,9 @@ void GEOM_Displayer::updateShapeProperties( const Handle(GEOM_AISShape)& AISShap
// set display vectors flag // set display vectors flag
AISShape->SetDisplayVectors( propMap.value( GEOM::propertyName( GEOM::EdgesDirection ) ).toBool() ); AISShape->SetDisplayVectors( propMap.value( GEOM::propertyName( GEOM::EdgesDirection ) ).toBool() );
// set display vertices flag
AISShape->SetDisplayVertices( propMap.value( GEOM::propertyName( GEOM::Vertices ) ).toBool() );
// set transparency // set transparency
if( HasTransparency() ) { if( HasTransparency() ) {
AISShape->SetTransparency( GetTransparency() ); AISShape->SetTransparency( GetTransparency() );
@ -1144,6 +1147,9 @@ void GEOM_Displayer::updateActorProperties( GEOM_Actor* actor, bool create )
// set display vectors flag // set display vectors flag
actor->SetVectorMode( propMap.value( GEOM::propertyName( GEOM::EdgesDirection ) ).toBool() ); actor->SetVectorMode( propMap.value( GEOM::propertyName( GEOM::EdgesDirection ) ).toBool() );
// set display vertices flag
actor->SetVerticesMode( propMap.value( GEOM::propertyName( GEOM::Vertices ) ).toBool() );
// set display mode // set display mode
int displayMode = HasDisplayMode() ? int displayMode = HasDisplayMode() ?
// predefined display mode, manually set to displayer via GEOM_Displayer::SetDisplayMode() function // predefined display mode, manually set to displayer via GEOM_Displayer::SetDisplayMode() function
@ -2498,6 +2504,9 @@ PropMap GEOM_Displayer::getDefaultPropertyMap()
// - show edges direction flag (false by default) // - show edges direction flag (false by default)
propMap.insert( GEOM::propertyName( GEOM::EdgesDirection ), false ); propMap.insert( GEOM::propertyName( GEOM::EdgesDirection ), false );
// - show vertices flag (false by default)
propMap.insert( GEOM::propertyName( GEOM::Vertices ), false );
// - shading color (take default value from preferences) // - shading color (take default value from preferences)
propMap.insert( GEOM::propertyName( GEOM::ShadingColor ), propMap.insert( GEOM::propertyName( GEOM::ShadingColor ),
colorFromResources( "shading_color", QColor( 255, 255, 0 ) ) ); colorFromResources( "shading_color", QColor( 255, 255, 0 ) ) );

View File

@ -2900,6 +2900,10 @@ Please, select face, shell or solid and try again</translation>
<source>MEN_POP_VECTORS</source> <source>MEN_POP_VECTORS</source>
<translation>Show Edge Direction</translation> <translation>Show Edge Direction</translation>
</message> </message>
<message>
<source>MEN_POP_VERTICES</source>
<translation>Show Vertices</translation>
</message>
<message> <message>
<source>MEN_PREFERENCES</source> <source>MEN_PREFERENCES</source>
<translation>Preferences</translation> <translation>Preferences</translation>
@ -3072,6 +3076,14 @@ Please, select face, shell or solid and try again</translation>
<source>MEN_VECTOR_MODE_OFF</source> <source>MEN_VECTOR_MODE_OFF</source>
<translation>Hide Edge Direction</translation> <translation>Hide Edge Direction</translation>
</message> </message>
<message>
<source>MEN_VERTICES_MODE_ON</source>
<translation>Show Vertices</translation>
</message>
<message>
<source>MEN_VERTICES_MODE_OFF</source>
<translation>Hide Vertices</translation>
</message>
<message> <message>
<source>MEN_WIREFRAME</source> <source>MEN_WIREFRAME</source>
<translation>Wireframe</translation> <translation>Wireframe</translation>
@ -3768,6 +3780,10 @@ Please, select face, shell or solid and try again</translation>
<source>STB_POP_VECTORS</source> <source>STB_POP_VECTORS</source>
<translation>Show Edge Direction</translation> <translation>Show Edge Direction</translation>
</message> </message>
<message>
<source>STB_POP_VERTICES</source>
<translation>Show Vertices</translation>
</message>
<message> <message>
<source>STB_POP_SETTEXTURE</source> <source>STB_POP_SETTEXTURE</source>
<translation>Add a texture</translation> <translation>Add a texture</translation>

View File

@ -520,11 +520,13 @@ void GeometryGUI::OnGUIEvent( int id, const QVariant& theParam )
case GEOMOp::OpHide: // MENU VIEW - ERASE case GEOMOp::OpHide: // MENU VIEW - ERASE
case GEOMOp::OpShow: // MENU VIEW - DISPLAY case GEOMOp::OpShow: // MENU VIEW - DISPLAY
case GEOMOp::OpSwitchVectors: // MENU VIEW - VECTOR MODE case GEOMOp::OpSwitchVectors: // MENU VIEW - VECTOR MODE
case GEOMOp::OpSwitchVertices: // MENU VIEW - VERTICES MODE
case GEOMOp::OpWireframe: // POPUP MENU - WIREFRAME case GEOMOp::OpWireframe: // POPUP MENU - WIREFRAME
case GEOMOp::OpShading: // POPUP MENU - SHADING case GEOMOp::OpShading: // POPUP MENU - SHADING
case GEOMOp::OpShadingWithEdges: // POPUP MENU - SHADING WITH EDGES case GEOMOp::OpShadingWithEdges: // POPUP MENU - SHADING WITH EDGES
case GEOMOp::OpTexture: // POPUP MENU - TEXTURE case GEOMOp::OpTexture: // POPUP MENU - TEXTURE
case GEOMOp::OpVectors: // POPUP MENU - VECTORS case GEOMOp::OpVectors: // POPUP MENU - VECTORS
case GEOMOp::OpVertices: // POPUP MENU - VERTICES
libName = "DisplayGUI"; libName = "DisplayGUI";
break; break;
case GEOMOp::OpPoint: // MENU BASIC - POINT case GEOMOp::OpPoint: // MENU BASIC - POINT
@ -1043,6 +1045,7 @@ void GeometryGUI::initialize( CAM_Application* app )
createGeomAction( GEOMOp::OpHideAll, "ERASE_ALL" ); createGeomAction( GEOMOp::OpHideAll, "ERASE_ALL" );
createGeomAction( GEOMOp::OpShow, "DISPLAY" ); createGeomAction( GEOMOp::OpShow, "DISPLAY" );
createGeomAction( GEOMOp::OpSwitchVectors, "VECTOR_MODE"); createGeomAction( GEOMOp::OpSwitchVectors, "VECTOR_MODE");
createGeomAction( GEOMOp::OpSwitchVertices, "VERTICES_MODE");
createGeomAction( GEOMOp::OpSelectVertex, "VERTEX_SEL_ONLY" ,"", 0, true ); createGeomAction( GEOMOp::OpSelectVertex, "VERTEX_SEL_ONLY" ,"", 0, true );
createGeomAction( GEOMOp::OpSelectEdge, "EDGE_SEL_ONLY", "", 0, true ); createGeomAction( GEOMOp::OpSelectEdge, "EDGE_SEL_ONLY", "", 0, true );
createGeomAction( GEOMOp::OpSelectWire, "WIRE_SEL_ONLY", "", 0, true ); createGeomAction( GEOMOp::OpSelectWire, "WIRE_SEL_ONLY", "", 0, true );
@ -1064,6 +1067,7 @@ void GeometryGUI::initialize( CAM_Application* app )
createGeomAction( GEOMOp::OpEdgeWidth, "EDGE_WIDTH"); createGeomAction( GEOMOp::OpEdgeWidth, "EDGE_WIDTH");
createGeomAction( GEOMOp::OpIsosWidth, "ISOS_WIDTH"); createGeomAction( GEOMOp::OpIsosWidth, "ISOS_WIDTH");
createGeomAction( GEOMOp::OpVectors, "POP_VECTORS", "", 0, true ); createGeomAction( GEOMOp::OpVectors, "POP_VECTORS", "", 0, true );
createGeomAction( GEOMOp::OpVertices, "POP_VERTICES", "", 0, true );
createGeomAction( GEOMOp::OpDeflection, "POP_DEFLECTION" ); createGeomAction( GEOMOp::OpDeflection, "POP_DEFLECTION" );
createGeomAction( GEOMOp::OpColor, "POP_COLOR" ); createGeomAction( GEOMOp::OpColor, "POP_COLOR" );
createGeomAction( GEOMOp::OpSetTexture, "POP_SETTEXTURE" ); createGeomAction( GEOMOp::OpSetTexture, "POP_SETTEXTURE" );
@ -1319,6 +1323,7 @@ void GeometryGUI::initialize( CAM_Application* app )
createMenu( GEOMOp::OpDMTexture, dispmodeId, -1 ); createMenu( GEOMOp::OpDMTexture, dispmodeId, -1 );
createMenu( separator(), dispmodeId, -1 ); createMenu( separator(), dispmodeId, -1 );
createMenu( GEOMOp::OpSwitchVectors, dispmodeId, -1 ); createMenu( GEOMOp::OpSwitchVectors, dispmodeId, -1 );
createMenu( GEOMOp::OpSwitchVertices, dispmodeId, -1 );
createMenu( separator(), viewId, -1 ); createMenu( separator(), viewId, -1 );
createMenu( GEOMOp::OpShowAll, viewId, -1 ); createMenu( GEOMOp::OpShowAll, viewId, -1 );
@ -1520,6 +1525,9 @@ void GeometryGUI::initialize( CAM_Application* app )
mgr->insert( action( GEOMOp::OpVectors ), dispmodeId, -1 ); // vectors mgr->insert( action( GEOMOp::OpVectors ), dispmodeId, -1 ); // vectors
mgr->setRule( action( GEOMOp::OpVectors ), clientOCCorVTK_AndSomeVisible + " and ($component={'GEOM'})", QtxPopupMgr::VisibleRule ); mgr->setRule( action( GEOMOp::OpVectors ), clientOCCorVTK_AndSomeVisible + " and ($component={'GEOM'})", QtxPopupMgr::VisibleRule );
mgr->setRule( action( GEOMOp::OpVectors ), clientOCCorVTK + " and isVectorsMode", QtxPopupMgr::ToggleRule ); mgr->setRule( action( GEOMOp::OpVectors ), clientOCCorVTK + " and isVectorsMode", QtxPopupMgr::ToggleRule );
mgr->insert( action( GEOMOp::OpVertices ), dispmodeId, -1 ); // vertices
mgr->setRule( action( GEOMOp::OpVertices ), clientOCCorVTK_AndSomeVisible + " and ($component={'GEOM'})", QtxPopupMgr::VisibleRule );
mgr->setRule( action( GEOMOp::OpVertices ), clientOCCorVTK + " and isVerticesMode", QtxPopupMgr::ToggleRule );
mgr->insert( separator(), -1, -1 ); // ----------- mgr->insert( separator(), -1, -1 ); // -----------
mgr->insert( action( GEOMOp::OpColor ), -1, -1 ); // color mgr->insert( action( GEOMOp::OpColor ), -1, -1 ); // color
@ -2888,6 +2896,11 @@ void GeometryGUI::storeVisualParameters (int savePoint)
ip->setParameter(entry, param.toStdString(), aProps.value(GEOM::propertyName( GEOM::EdgesDirection )).toString().toStdString()); ip->setParameter(entry, param.toStdString(), aProps.value(GEOM::propertyName( GEOM::EdgesDirection )).toString().toStdString());
} }
if (aProps.contains(GEOM::propertyName( GEOM::Vertices ))) {
param = occParam + GEOM::propertyName( GEOM::Vertices );
ip->setParameter(entry, param.toStdString(), aProps.value(GEOM::propertyName( GEOM::Vertices )).toString().toStdString());
}
if (aProps.contains(GEOM::propertyName( GEOM::Deflection ))) { if (aProps.contains(GEOM::propertyName( GEOM::Deflection ))) {
param = occParam + GEOM::propertyName( GEOM::Deflection ); param = occParam + GEOM::propertyName( GEOM::Deflection );
ip->setParameter(entry, param.toStdString(), aProps.value(GEOM::propertyName( GEOM::Deflection )).toString().toStdString()); ip->setParameter(entry, param.toStdString(), aProps.value(GEOM::propertyName( GEOM::Deflection )).toString().toStdString());
@ -3058,6 +3071,8 @@ void GeometryGUI::restoreVisualParameters (int savePoint)
aListOfMap[viewIndex].insert( GEOM::propertyName( GEOM::Texture ), val ); aListOfMap[viewIndex].insert( GEOM::propertyName( GEOM::Texture ), val );
} else if (paramNameStr == GEOM::propertyName( GEOM::EdgesDirection )) { } else if (paramNameStr == GEOM::propertyName( GEOM::EdgesDirection )) {
aListOfMap[viewIndex].insert( GEOM::propertyName( GEOM::EdgesDirection ), val == "true" || val == "1"); aListOfMap[viewIndex].insert( GEOM::propertyName( GEOM::EdgesDirection ), val == "true" || val == "1");
} else if (paramNameStr == GEOM::propertyName( GEOM::Vertices )) {
aListOfMap[viewIndex].insert( GEOM::propertyName( GEOM::Vertices ), val == "true" || val == "1");
} else if (paramNameStr == GEOM::propertyName( GEOM::Deflection )) { } else if (paramNameStr == GEOM::propertyName( GEOM::Deflection )) {
aListOfMap[viewIndex].insert( GEOM::propertyName( GEOM::Deflection ), val.toDouble()); aListOfMap[viewIndex].insert( GEOM::propertyName( GEOM::Deflection ), val.toDouble());
} else if (paramNameStr == GEOM::propertyName( GEOM::PointMarker )) { } else if (paramNameStr == GEOM::propertyName( GEOM::PointMarker )) {
@ -3111,13 +3126,19 @@ void GeometryGUI::onViewAboutToShow()
{ {
SUIT_ViewWindow* window = application()->desktop()->activeWindow(); SUIT_ViewWindow* window = application()->desktop()->activeWindow();
QAction* a = action( GEOMOp::OpSwitchVectors ); QAction* a = action( GEOMOp::OpSwitchVectors );
QAction* aVerticesAction = action( GEOMOp::OpSwitchVertices );
if ( window ) { if ( window ) {
a->setEnabled(true); a->setEnabled(true);
bool vmode = window->property("VectorsMode").toBool(); bool vmode = window->property("VectorsMode").toBool();
a->setText ( vmode == 1 ? tr( "MEN_VECTOR_MODE_OFF" ) : tr("MEN_VECTOR_MODE_ON") ); a->setText ( vmode == 1 ? tr( "MEN_VECTOR_MODE_OFF" ) : tr("MEN_VECTOR_MODE_ON") );
aVerticesAction->setEnabled(true);
vmode = window->property("VerticesMode").toBool();
aVerticesAction->setText ( vmode == 1 ? tr( "MEN_VERTICES_MODE_OFF" ) : tr("MEN_VERTICES_MODE_ON") );
} else { } else {
a->setText ( tr("MEN_VECTOR_MODE_ON") ); a->setText ( tr("MEN_VECTOR_MODE_ON") );
a->setEnabled(false); a->setEnabled(false);
aVerticesAction->setText ( tr("MEN_VERTICES_MODE_ON") );
aVerticesAction->setEnabled(false);
} }
} }

View File

@ -71,6 +71,7 @@ namespace GEOMOp {
OpDMShading = 2011, // MENU VIEW - DISPLAY MODE - SHADING OpDMShading = 2011, // MENU VIEW - DISPLAY MODE - SHADING
OpDMShadingWithEdges = 2012, // MENU VIEW - DISPLAY MODE - SHADING WITH EDGES OpDMShadingWithEdges = 2012, // MENU VIEW - DISPLAY MODE - SHADING WITH EDGES
OpDMTexture = 2013, // MENU VIEW - DISPLAY MODE - TEXTURE OpDMTexture = 2013, // MENU VIEW - DISPLAY MODE - TEXTURE
OpSwitchVertices = 2014, // MENU VIEW - DISPLAY MODE - SHOW/HIDE VERTICES
OpShow = 2100, // POPUP MENU - SHOW OpShow = 2100, // POPUP MENU - SHOW
OpShowOnly = 2101, // POPUP MENU - SHOW ONLY OpShowOnly = 2101, // POPUP MENU - SHOW ONLY
OpHide = 2102, // POPUP MENU - HIDE OpHide = 2102, // POPUP MENU - HIDE
@ -82,6 +83,7 @@ namespace GEOMOp {
OpTexture = 2204, // POPUP MENU - DISPLAY MODE - TEXTURE OpTexture = 2204, // POPUP MENU - DISPLAY MODE - TEXTURE
OpBringToFront = 2205, // POPUP MENU - BRING TO FRONT OpBringToFront = 2205, // POPUP MENU - BRING TO FRONT
OpClsBringToFront = 2206, OpClsBringToFront = 2206,
OpVertices = 2208, // POPUP MENU - DISPLAY MODE - SHOW VERTICES
// BasicGUI --------------------//-------------------------------- // BasicGUI --------------------//--------------------------------
OpPoint = 3000, // MENU NEW ENTITY - BASIC - POINT OpPoint = 3000, // MENU NEW ENTITY - BASIC - POINT
OpLine = 3001, // MENU NEW ENTITY - BASIC - LINE OpLine = 3001, // MENU NEW ENTITY - BASIC - LINE

View File

@ -113,6 +113,7 @@ if not isinstance(gg, type(salome_ComponentGUI)):
gg.setDisplayMode(id_torus1,1) gg.setDisplayMode(id_torus1,1)
gg.setDisplayMode(id_torus2,1) gg.setDisplayMode(id_torus2,1)
gg.setVectorsMode(id_acyl,1,1) gg.setVectorsMode(id_acyl,1,1)
gg.setVerticesMode(id_acyl,1,1)
#gg.setDisplayMode(id_cage,1) #gg.setDisplayMode(id_cage,1)
gg.setColor(id_torus1,0,0,255) gg.setColor(id_torus1,0,0,255)

View File

@ -391,6 +391,18 @@ void GEOM_Swig::setVectorsMode( const char* theEntry, bool theOn, bool theUpdate
theOn, theUpdateViewer ) ); theOn, theUpdateViewer ) );
} }
/*!
\brief Show / hide vertices for the presentation
\param theEntry geometry object's entry
\param theOn \c true to show vertices or \c false otherwise
\param theUpdateViewer \c true to update active view's contents
*/
void GEOM_Swig::setVerticesMode( const char* theEntry, bool theOn, bool theUpdateViewer )
{
ProcessVoidEvent( new TSetPropertyEvent( theEntry, GEOM::propertyName( GEOM::Vertices ),
theOn, theUpdateViewer ) );
}
/*! /*!
\brief Change color of the presentation \brief Change color of the presentation
\param theEntry geometry object's entry \param theEntry geometry object's entry

View File

@ -41,6 +41,7 @@ public:
void setDisplayMode( const char* theEntry, int theMode, bool theUpdateViewer = true ); void setDisplayMode( const char* theEntry, int theMode, bool theUpdateViewer = true );
void setVectorsMode( const char* theEntry, bool theOn, bool theUpdateViewer = true ); void setVectorsMode( const char* theEntry, bool theOn, bool theUpdateViewer = true );
void setVerticesMode( const char* theEntry, bool theOn, bool theUpdateViewer = true );
void setColor( const char* theEntry, int theRed, int theGreen, int theBlue, bool theUpdateViewer = true ); void setColor( const char* theEntry, int theRed, int theGreen, int theBlue, bool theUpdateViewer = true );
void setTransparency( const char* theEntry, float theTransparency, bool theUpdateViewer = true ); void setTransparency( const char* theEntry, float theTransparency, bool theUpdateViewer = true );
void setIsos( const char* theEntry, int theNbU, int theNbV, bool theUpdateViewer = true ); void setIsos( const char* theEntry, int theNbU, int theNbV, bool theUpdateViewer = true );

View File

@ -63,6 +63,7 @@ class GEOM_Swig
void setDisplayMode( const char* theEntry, int theMode, bool theUpdateViewer = true ); void setDisplayMode( const char* theEntry, int theMode, bool theUpdateViewer = true );
void setVectorsMode( const char* theEntry, bool theOn, bool theUpdateViewer = true ); void setVectorsMode( const char* theEntry, bool theOn, bool theUpdateViewer = true );
void setVerticesMode( const char* theEntry, bool theOn, bool theUpdateViewer = true );
void setColor( const char* theEntry, int theRed, int theGreen, int theBlue, bool theUpdateViewer = true ); void setColor( const char* theEntry, int theRed, int theGreen, int theBlue, bool theUpdateViewer = true );
void setTransparency( const char* theEntry, float theTransparency, bool theUpdateViewer = true ); void setTransparency( const char* theEntry, float theTransparency, bool theUpdateViewer = true );
void setIsos( const char* theEntry, int theNbU, int theNbV, bool theUpdateViewer = true ); void setIsos( const char* theEntry, int theNbU, int theNbV, bool theUpdateViewer = true );

View File

@ -53,6 +53,7 @@
#include <Prs3d_ShadingAspect.hxx> #include <Prs3d_ShadingAspect.hxx>
#include <Prs3d_Arrow.hxx> #include <Prs3d_Arrow.hxx>
#include <Prs3d_IsoAspect.hxx> #include <Prs3d_IsoAspect.hxx>
#include <Prs3d_VertexDrawMode.hxx>
#include <SelectBasics_SensitiveEntity.hxx> #include <SelectBasics_SensitiveEntity.hxx>
#include <SelectMgr_EntityOwner.hxx> #include <SelectMgr_EntityOwner.hxx>
@ -148,6 +149,7 @@ GEOM_AISShape::GEOM_AISShape(const TopoDS_Shape& shape,
: SALOME_AISShape(shape), : SALOME_AISShape(shape),
myName(aName), myName(aName),
myDisplayVectors(false), myDisplayVectors(false),
myDisplayVertices(false),
myFieldDataType(GEOM::FDT_Double), myFieldDataType(GEOM::FDT_Double),
myFieldDimension(0), myFieldDimension(0),
myFieldStepRangeMin(0), myFieldStepRangeMin(0),
@ -215,6 +217,9 @@ void GEOM_AISShape::Compute(const Handle(PrsMgr_PresentationManager3d)& aPresent
bool anIsColorField = anIsField && myFieldDataType != GEOM::FDT_String; bool anIsColorField = anIsField && myFieldDataType != GEOM::FDT_String;
bool anIsTextField = anIsField && myFieldDataType == GEOM::FDT_String; bool anIsTextField = anIsField && myFieldDataType == GEOM::FDT_String;
if (isShowVertices())
myDrawer->SetVertexDrawMode(Prs3d_VDM_All);
// StdSelect_DisplayMode d = (StdSelect_DisplayMode) aMode; // StdSelect_DisplayMode d = (StdSelect_DisplayMode) aMode;
bool isTopLev = isTopLevel() && switchTopLevel(); bool isTopLev = isTopLevel() && switchTopLevel();
switch (aMode) { switch (aMode) {
@ -359,6 +364,11 @@ void GEOM_AISShape::SetDisplayVectors(bool isDisplayed)
myDisplayVectors = isDisplayed; myDisplayVectors = isDisplayed;
} }
void GEOM_AISShape::SetDisplayVertices(bool isDisplayed)
{
myDisplayVertices = isDisplayed;
}
void GEOM_AISShape::shadingMode(const Handle(PrsMgr_PresentationManager3d)& aPresentationManager, void GEOM_AISShape::shadingMode(const Handle(PrsMgr_PresentationManager3d)& aPresentationManager,
const Handle(Prs3d_Presentation)& aPrs, const Handle(Prs3d_Presentation)& aPrs,
const Standard_Integer aMode) const Standard_Integer aMode)

View File

@ -124,12 +124,14 @@ public:
void SetShadingColor(const Quantity_Color &aCol); void SetShadingColor(const Quantity_Color &aCol);
void SetEdgesInShadingColor(const Quantity_Color &aCol); void SetEdgesInShadingColor(const Quantity_Color &aCol);
void SetDisplayVectors(bool isShow); void SetDisplayVectors(bool isShow);
void SetDisplayVertices(bool isShow);
virtual void Compute(const Handle(PrsMgr_PresentationManager3d)& aPresentationManager, virtual void Compute(const Handle(PrsMgr_PresentationManager3d)& aPresentationManager,
const Handle(Prs3d_Presentation)& aPresentation, const Handle(Prs3d_Presentation)& aPresentation,
const Standard_Integer aMode = 0) ; const Standard_Integer aMode = 0) ;
virtual bool isShowVectors () { return myDisplayVectors; } virtual bool isShowVectors () { return myDisplayVectors; }
virtual bool isShowVertices () { return myDisplayVertices; }
virtual Standard_Boolean switchTopLevel(); virtual Standard_Boolean switchTopLevel();
virtual Standard_Boolean toActivate(); virtual Standard_Boolean toActivate();
@ -182,6 +184,7 @@ protected:
private: private:
TCollection_AsciiString myName; TCollection_AsciiString myName;
bool myDisplayVectors; bool myDisplayVectors;
bool myDisplayVertices;
Standard_Boolean myTopLevel; Standard_Boolean myTopLevel;
Standard_Integer myPrevDisplayMode; Standard_Integer myPrevDisplayMode;

View File

@ -82,6 +82,7 @@ GEOM_Actor::GEOM_Actor():
// myDisplayMode(eWireframe), // myDisplayMode(eWireframe),
myIsSelected(false), myIsSelected(false),
myVectorMode(false), myVectorMode(false),
myVerticesMode(false),
myVertexActor(GEOM_DeviceActor::New(),true), myVertexActor(GEOM_DeviceActor::New(),true),
myVertexSource(GEOM_VertexSource::New(),true), myVertexSource(GEOM_VertexSource::New(),true),
@ -129,13 +130,13 @@ GEOM_Actor::GEOM_Actor():
myHighlightProp->SetAmbientColor(1, 1, 1); myHighlightProp->SetAmbientColor(1, 1, 1);
myHighlightProp->SetDiffuseColor(1, 1, 1); myHighlightProp->SetDiffuseColor(1, 1, 1);
myHighlightProp->SetSpecularColor(0.5, 0.5, 0.5); myHighlightProp->SetSpecularColor(0.5, 0.5, 0.5);
myHighlightProp->SetPointSize(SALOME_POINT_SIZE); myHighlightProp->SetPointSize(0);
myHighlightActor->SetProperty(myHighlightProp.GetPointer()); myHighlightActor->SetProperty(myHighlightProp.GetPointer());
this->myHighlightActor->SetInput(myAppendFilter->GetOutputPort(),false); this->myHighlightActor->SetInput(myAppendFilter->GetOutputPort(),false);
myPreHighlightProp->SetColor(0,1,1); myPreHighlightProp->SetColor(0,1,1);
myPreHighlightProp->SetPointSize(SALOME_POINT_SIZE+2); myPreHighlightProp->SetPointSize(0);
myPreHighlightProp->SetLineWidth(SALOME_LINE_WIDTH+1); myPreHighlightProp->SetLineWidth(SALOME_LINE_WIDTH+1);
myPreHighlightProp->SetRepresentationToWireframe(); myPreHighlightProp->SetRepresentationToWireframe();
@ -189,6 +190,7 @@ GEOM_Actor::GEOM_Actor():
// Toggle display mode // Toggle display mode
setDisplayMode(0); // WIRE FRAME setDisplayMode(0); // WIRE FRAME
SetVectorMode(0); // SetVectorMode(0); //
SetVerticesMode(0); //
} }
@ -355,7 +357,7 @@ SetVisibility(int theVisibility)
myOneFaceEdgeActor->SetVisibility(theVisibility && (myDisplayMode == (int)eWireframe || myDisplayMode == (int)eShadingWithEdges) && !myIsSelected); myOneFaceEdgeActor->SetVisibility(theVisibility && (myDisplayMode == (int)eWireframe || myDisplayMode == (int)eShadingWithEdges) && !myIsSelected);
myIsolatedEdgeActor->SetVisibility(theVisibility && !myIsSelected); myIsolatedEdgeActor->SetVisibility(theVisibility && !myIsSelected);
myVertexActor->SetVisibility(theVisibility && myDisplayMode == (int)eWireframe && !myIsSelected);// must be added new mode points myVertexActor->SetVisibility(theVisibility && myVerticesMode && (!myIsSelected && !myIsPreselected));// must be added new mode points
} }
@ -391,6 +393,23 @@ GEOM_Actor
return myVectorMode; return myVectorMode;
} }
void
GEOM_Actor
::SetVerticesMode(bool theMode)
{
myVerticesMode = theMode;
theMode ? myPreHighlightProp->SetPointSize(SALOME_POINT_SIZE+2) : myPreHighlightProp->SetPointSize(0);
theMode ? myHighlightProp->SetPointSize(SALOME_POINT_SIZE) : myHighlightProp->SetPointSize(0);
SetModified();
}
bool
GEOM_Actor
::GetVerticesMode()
{
return myVerticesMode;
}
void void
GEOM_Actor:: GEOM_Actor::
SetDeflection(float theDeflection) SetDeflection(float theDeflection)

View File

@ -202,6 +202,15 @@ public:
bool bool
GetVectorMode(); GetVectorMode();
//! Vertices mode management
virtual
void
SetVerticesMode(const bool theMode);
virtual
bool
GetVerticesMode();
protected: protected:
void SetModified(); void SetModified();
@ -220,6 +229,7 @@ private:
// EDisplayMode myDisplayMode; // EDisplayMode myDisplayMode;
bool myIsSelected; bool myIsSelected;
bool myVectorMode; bool myVectorMode;
bool myVerticesMode;
PDeviceActor myVertexActor; PDeviceActor myVertexActor;
PVertexSource myVertexSource; PVertexSource myVertexSource;

View File

@ -69,6 +69,8 @@ namespace GEOM
"Color", // COLOR_PROP "Color", // COLOR_PROP
// "show edges direction" flag // "show edges direction" flag
"VectorMode", // VECTOR_MODE_PROP "VectorMode", // VECTOR_MODE_PROP
// "show vertices" flag
"VerticesMode", // VERTICES_MODE_PROP
// deflection coefficient // deflection coefficient
"DeflectionCoeff", // DEFLECTION_COEFF_PROP "DeflectionCoeff", // DEFLECTION_COEFF_PROP
// point marker data // point marker data

View File

@ -39,6 +39,7 @@ namespace GEOM
NbIsos, NbIsos,
Color, Color,
EdgesDirection, EdgesDirection,
Vertices,
Deflection, Deflection,
PointMarker, PointMarker,
Material, Material,