0020168: EDF SMESH 953: uncomplete selection with filter 'belong on geom'

This commit is contained in:
dmv 2009-02-20 11:39:09 +00:00
parent 682a0b6c75
commit 85ce250186

View File

@ -3190,10 +3190,13 @@ void ElementsOnShape::process (const SMDS_MeshElement* theElemPtr)
SMDS_ElemIteratorPtr aNodeItr = theElemPtr->nodesIterator(); SMDS_ElemIteratorPtr aNodeItr = theElemPtr->nodesIterator();
bool isSatisfy = myAllNodesFlag; bool isSatisfy = myAllNodesFlag;
gp_XYZ centerXYZ (0, 0, 0);
while (aNodeItr->more() && (isSatisfy == myAllNodesFlag)) while (aNodeItr->more() && (isSatisfy == myAllNodesFlag))
{ {
SMDS_MeshNode* aNode = (SMDS_MeshNode*)aNodeItr->next(); SMDS_MeshNode* aNode = (SMDS_MeshNode*)aNodeItr->next();
gp_Pnt aPnt (aNode->X(), aNode->Y(), aNode->Z()); gp_Pnt aPnt (aNode->X(), aNode->Y(), aNode->Z());
centerXYZ += aPnt.XYZ();
switch (myCurShapeType) switch (myCurShapeType)
{ {
@ -3236,6 +3239,14 @@ void ElementsOnShape::process (const SMDS_MeshElement* theElemPtr)
} }
} }
if (isSatisfy && myCurShapeType == TopAbs_SOLID) { // Check the center point for volumes MantisBug 0020168
centerXYZ /= theElemPtr->NbNodes();
gp_Pnt aCenterPnt (centerXYZ);
myCurSC.Perform(aCenterPnt, myToler);
if ( !(myCurSC.State() == TopAbs_IN || myCurSC.State() == TopAbs_ON))
isSatisfy = false;
}
if (isSatisfy) if (isSatisfy)
myIds.Add(theElemPtr->GetID()); myIds.Add(theElemPtr->GetID());
} }