From 2295213e66a593e9b426e64eb755a3c1141dcd6e Mon Sep 17 00:00:00 2001 From: imn Date: Mon, 29 Jun 2015 19:34:27 +0300 Subject: [PATCH] INT PAL 0052786: 2D algorithm shown when mesh edition invoked --- src/SMESHGUI/SMESHGUI_MeshOp.cxx | 16 ++++++++++++---- 1 file changed, 12 insertions(+), 4 deletions(-) diff --git a/src/SMESHGUI/SMESHGUI_MeshOp.cxx b/src/SMESHGUI/SMESHGUI_MeshOp.cxx index ff9851008..53e1ea98e 100644 --- a/src/SMESHGUI/SMESHGUI_MeshOp.cxx +++ b/src/SMESHGUI/SMESHGUI_MeshOp.cxx @@ -1496,24 +1496,32 @@ void SMESHGUI_MeshOp::onAlgoSelected( const int theIndex, if ( anAvailable.count() == 1 ) soleCompatible = myAvailableHypData[dim][Algo][0]; if ( dim == aTopDim && prevAlgo ) {// all available algoritms should be selectable any way - if (aTopDim == SMESH::DIM_2D) { + if (aTopDim == SMESH::DIM_2D && myFilteredAlgoData[dim].count() > 0) { anAvailable.clear(); for (int i = 0; i < myFilteredAlgoData[dim].count(); ++i) { HypothesisData* aCurAlgo = myFilteredAlgoData[dim][ i ]; anAvailable.append( aCurAlgo->Label ); } } - if (aTopDim == SMESH::DIM_3D) + if (aTopDim == SMESH::DIM_3D && myDlg->currentMeshType() == MT_ANY) availableHyps( dim, Algo, anAvailable, myAvailableHypData[dim][Algo], 0 ); } myDlg->tab( dim )->setAvailableHyps( Algo, anAvailable ); noCompatible = anAvailable.isEmpty(); // restore previously selected algo - if (dim == aTopDim && prevAlgo && aTopDim == SMESH::DIM_2D) + if (dim == aTopDim && prevAlgo && aTopDim == SMESH::DIM_2D && myFilteredAlgoData[dim].count() > 0) { algoIndex = myFilteredAlgoData[dim].indexOf( curAlgo ); - else + setCurrentHyp( dim, Algo, algoIndex); + if (algoIndex >= 0) + prevAlgo = algoByDim[ dim ] = myFilteredAlgoData[dim][algoIndex]; + else + prevAlgo = algoByDim[ dim ] = 0; + continue; + } + else { algoIndex = myAvailableHypData[dim][Algo].indexOf( curAlgo ); + } if ( !isSubmesh && algoIndex < 0 && soleCompatible && !forward && dim != SMESH::DIM_0D) // select the sole compatible algo algoIndex = myAvailableHypData[dim][Algo].indexOf( soleCompatible );