mirror of
https://git.salome-platform.org/gitpub/modules/smesh.git
synced 2025-01-27 20:30:32 +05:00
0052451: "Assign a set of hypotheses" is disabled by mistake
This commit is contained in:
parent
a6c877f633
commit
0fdf27b77b
@ -1396,7 +1396,6 @@ void SMESHGUI_MeshOp::onAlgoSelected( const int theIndex,
|
|||||||
|
|
||||||
const bool isSubmesh = ( myToCreate ? !myIsMesh : myDlg->isObjectShown( SMESHGUI_MeshDlg::Mesh ));
|
const bool isSubmesh = ( myToCreate ? !myIsMesh : myDlg->isObjectShown( SMESHGUI_MeshDlg::Mesh ));
|
||||||
|
|
||||||
// if ( aDim >= SMESH::DIM_2D ) myAvailableHypData[ aDim ][ Algo ] = myFilteredAlgoData[aDim];
|
|
||||||
HypothesisData* algoData = hypData( aDim, Algo, theIndex );
|
HypothesisData* algoData = hypData( aDim, Algo, theIndex );
|
||||||
HypothesisData* algoByDim[4];
|
HypothesisData* algoByDim[4];
|
||||||
algoByDim[ aDim ] = algoData;
|
algoByDim[ aDim ] = algoData;
|
||||||
@ -2568,7 +2567,7 @@ void SMESHGUI_MeshOp::setFilteredAlgoData( const int theTabIndex, const int theI
|
|||||||
|
|
||||||
if ( anCompareType == "ANY" )
|
if ( anCompareType == "ANY" )
|
||||||
{
|
{
|
||||||
for ( int dim = SMESH::DIM_2D; dim <= SMESH::DIM_3D; dim++ )
|
for ( int dim = SMESH::DIM_3D; dim >= SMESH::DIM_2D; dim-- )
|
||||||
{
|
{
|
||||||
isNone = currentHyp( dim, Algo ) < 0;
|
isNone = currentHyp( dim, Algo ) < 0;
|
||||||
isAvailableChoiceAlgo = false;
|
isAvailableChoiceAlgo = false;
|
||||||
@ -2581,30 +2580,35 @@ void SMESHGUI_MeshOp::setFilteredAlgoData( const int theTabIndex, const int theI
|
|||||||
}
|
}
|
||||||
myAvailableHypData[dim][Algo].clear();
|
myAvailableHypData[dim][Algo].clear();
|
||||||
anAvailableAlgs.clear();
|
anAvailableAlgs.clear();
|
||||||
for (int i = 0 ; i < anAvailableAlgsData.count(); i++)
|
if ( dim != SMESH::DIM_2D || currentHyp( SMESH::DIM_3D, Algo ) < 0 ||
|
||||||
|
myAvailableHypData[SMESH::DIM_3D][Algo].empty() ||
|
||||||
|
!myAvailableHypData[SMESH::DIM_3D][Algo].at( currentHyp( SMESH::DIM_3D, Algo ) )->InputTypes.isEmpty() )
|
||||||
{
|
{
|
||||||
HypothesisData* curAlgo = anAvailableAlgsData.at(i);
|
for (int i = 0 ; i < anAvailableAlgsData.count(); i++)
|
||||||
if ( aGeomVar->_is_nil() ||
|
|
||||||
SMESH::IsApplicable( curAlgo->TypeName, aGeomVar, toCheckIsApplicableToAll ))
|
|
||||||
{
|
{
|
||||||
anAvailableAlgs.append( curAlgo->Label );
|
HypothesisData* curAlgo = anAvailableAlgsData.at(i);
|
||||||
myAvailableHypData[dim][Algo].append( curAlgo );
|
if ( aGeomVar->_is_nil() ||
|
||||||
}
|
SMESH::IsApplicable( curAlgo->TypeName, aGeomVar, toCheckIsApplicableToAll ))
|
||||||
}
|
{
|
||||||
if ( !isNone && algoCur ) {
|
anAvailableAlgs.append( curAlgo->Label );
|
||||||
for (int i = 0 ; i < myAvailableHypData[dim][Algo].count(); i++)
|
myAvailableHypData[dim][Algo].append( curAlgo );
|
||||||
{
|
|
||||||
HypothesisData* algoAny = myAvailableHypData[dim][Algo].at(i);
|
|
||||||
if ( algoAny->Label == algoCur->Label ){
|
|
||||||
isAvailableChoiceAlgo = true;
|
|
||||||
anCurrentAvailableAlgo = i;
|
|
||||||
break;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
if ( !isNone && algoCur ) {
|
||||||
else if ( !isNone ) {
|
for (int i = 0 ; i < myAvailableHypData[dim][Algo].count(); i++)
|
||||||
isAvailableChoiceAlgo = true;
|
{
|
||||||
anCurrentAvailableAlgo = currentHyp( dim, Algo );
|
HypothesisData* algoAny = myAvailableHypData[dim][Algo].at(i);
|
||||||
|
if ( algoAny->Label == algoCur->Label ){
|
||||||
|
isAvailableChoiceAlgo = true;
|
||||||
|
anCurrentAvailableAlgo = i;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else if ( !isNone ) {
|
||||||
|
isAvailableChoiceAlgo = true;
|
||||||
|
anCurrentAvailableAlgo = currentHyp( dim, Algo );
|
||||||
|
}
|
||||||
}
|
}
|
||||||
myDlg->tab( dim )->setAvailableHyps( Algo, anAvailableAlgs );
|
myDlg->tab( dim )->setAvailableHyps( Algo, anAvailableAlgs );
|
||||||
if ( isAvailableChoiceAlgo )
|
if ( isAvailableChoiceAlgo )
|
||||||
@ -2730,11 +2734,24 @@ void SMESHGUI_MeshOp::setFilteredAlgoData( const int theTabIndex, const int theI
|
|||||||
{
|
{
|
||||||
for (int i = SMESH::DIM_0D; i <= myMaxShapeDim; i++)
|
for (int i = SMESH::DIM_0D; i <= myMaxShapeDim; i++)
|
||||||
{
|
{
|
||||||
for (int j = 0; j < myAvailableHypData[i][Algo].count(); ++j) {
|
if ( myAvailableHypData[i][Algo].count() == 0 ) {
|
||||||
HypothesisData* aCurAlgo = hypData( i, Algo, j );
|
availableHyps( i, Algo, anAvailableAlgs, anAvailableAlgsData );
|
||||||
if ( aCurAlgo->Label == algoDataIn->Label ){
|
for ( int i = 0 ; i < anAvailableAlgsData.count(); i++ )
|
||||||
isAvailable = true;
|
{
|
||||||
break;
|
HypothesisData* aCurAlgo = anAvailableAlgsData.at( i );
|
||||||
|
if ( aCurAlgo->Label == algoDataIn->Label ){
|
||||||
|
isAvailable = true;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
for (int j = 0; j < myAvailableHypData[i][Algo].count(); ++j) {
|
||||||
|
HypothesisData* aCurAlgo = hypData( i, Algo, j );
|
||||||
|
if ( aCurAlgo->Label == algoDataIn->Label ){
|
||||||
|
isAvailable = true;
|
||||||
|
break;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if ( isAvailable ) break;
|
if ( isAvailable ) break;
|
||||||
|
Loading…
Reference in New Issue
Block a user