mirror of
https://git.salome-platform.org/gitpub/modules/smesh.git
synced 2025-01-14 02:30:33 +05:00
IPAL52860: Free Edges control mis-location and mis-visibility
IPAL19098: Confusing "Precision" of "Average Length" implemented for NPAL17873
This commit is contained in:
parent
1774f77443
commit
18e7b9c752
BIN
doc/salome/gui/SMESH/images/free_borders1.png
Executable file → Normal file
BIN
doc/salome/gui/SMESH/images/free_borders1.png
Executable file → Normal file
Binary file not shown.
Before Width: | Height: | Size: 5.5 KiB After Width: | Height: | Size: 1.8 KiB |
@ -144,12 +144,17 @@ composing your geometrical object. Definition of this hypothesis
|
|||||||
consists of setting the \b length of segments, which will approximate these
|
consists of setting the \b length of segments, which will approximate these
|
||||||
edges, and the \b precision of rounding.
|
edges, and the \b precision of rounding.
|
||||||
|
|
||||||
The \b precision parameter is used to round a number of segments,
|
The \b precision parameter is used to round a <em>number of segments</em>,
|
||||||
calculated by dividing the edge length by the specified \b length of
|
calculated by dividing the <em>edge length</em> by the specified \b length of
|
||||||
segment, to the higher integer if the remainder exceeds the precision
|
segment, to the higher integer if the \a remainder exceeds the \b precision
|
||||||
and to the lower integer otherwise. Use value 0.5 to provide rounding
|
and to the lower integer otherwise. <br>
|
||||||
to the nearest integer, 1.0 for the lower integer, 0.0 for the higher
|
Use value 0.5 to provide rounding to the nearest integer, 1.0 for the lower integer, 0.0 for the higher integer. Default value is 1e-07.
|
||||||
integer. Default value is 1e-07.
|
|
||||||
|
For example: if <em>edge length</em> is 10.0 and the segment \b length
|
||||||
|
is 3.0 then their division gives 10./3. = 3.33(3) and the \a remainder is 0.33(3).
|
||||||
|
If \b precision is less than 0.33(3) then the edge is divided into 3 segments.
|
||||||
|
If \b precision is more than 0.33(3) then the edge is divided into 4 segments.
|
||||||
|
|
||||||
|
|
||||||
\image html image41.gif
|
\image html image41.gif
|
||||||
|
|
||||||
|
@ -24,7 +24,6 @@ Node quality controls:
|
|||||||
|
|
||||||
Edge quality controls:
|
Edge quality controls:
|
||||||
<ul>
|
<ul>
|
||||||
<li>\subpage free_edges_page "Free edges"</li>
|
|
||||||
<li>\subpage free_borders_page "Free borders"</li>
|
<li>\subpage free_borders_page "Free borders"</li>
|
||||||
<li>\subpage length_page "Length"</li>
|
<li>\subpage length_page "Length"</li>
|
||||||
<li>\subpage borders_at_multi_connection_page "Borders at multi-connection"</li>
|
<li>\subpage borders_at_multi_connection_page "Borders at multi-connection"</li>
|
||||||
@ -33,6 +32,7 @@ Edge quality controls:
|
|||||||
|
|
||||||
Face quality controls:
|
Face quality controls:
|
||||||
<ul>
|
<ul>
|
||||||
|
<li>\subpage free_edges_page "Free edges"</li>
|
||||||
<li>\subpage free_faces_page "Free faces"</li>
|
<li>\subpage free_faces_page "Free faces"</li>
|
||||||
<li>\subpage bare_border_faces_page "Bare border faces"</li>
|
<li>\subpage bare_border_faces_page "Bare border faces"</li>
|
||||||
<li>\subpage over_constrained_faces_page "Over-constrained faces"</li>
|
<li>\subpage over_constrained_faces_page "Over-constrained faces"</li>
|
||||||
|
@ -2,12 +2,14 @@
|
|||||||
|
|
||||||
\page free_borders_page Free borders
|
\page free_borders_page Free borders
|
||||||
|
|
||||||
\n This mesh quality control highlights borders of faces consisting of
|
\n This mesh quality control highlights 1D elements (segments)
|
||||||
1D elements (segments) belonging to one face only.
|
belonging to one element (face or volume) only.
|
||||||
|
|
||||||
\image html free_borders1.png
|
\image html free_borders1.png
|
||||||
|
|
||||||
In this picture the free borders are displayed in white.
|
In this picture the free borders are displayed in red. (Faces are
|
||||||
|
explicitly shown via <em>Display Entity</em> menu as all elements but
|
||||||
|
segments are hidden upon this control activation).
|
||||||
|
|
||||||
<br><b>See Also</b> a sample TUI Script of a
|
<br><b>See Also</b> a sample TUI Script of a
|
||||||
\ref tui_free_borders "Free Borders quality control" operation.
|
\ref tui_free_borders "Free Borders quality control" operation.
|
||||||
|
@ -3,7 +3,7 @@
|
|||||||
\page free_edges_page Free edges
|
\page free_edges_page Free edges
|
||||||
|
|
||||||
\n This mesh quality control highlights borders of faces
|
\n This mesh quality control highlights borders of faces
|
||||||
consisting of node links belonging to one face only.
|
(links between nodes, not mesh segments) belonging to one face only.
|
||||||
|
|
||||||
\image html free_edges.png
|
\image html free_edges.png
|
||||||
<center>In this picture some elements of mesh have been deleted and
|
<center>In this picture some elements of mesh have been deleted and
|
||||||
|
@ -2,9 +2,11 @@
|
|||||||
|
|
||||||
\page selection_filter_library_page Selection filter library
|
\page selection_filter_library_page Selection filter library
|
||||||
|
|
||||||
\n Selection filter library is a powerful tool enabling to create
|
\n Selection filter library allows creating and storing in files
|
||||||
filters to be used on meshes. You can access to it from the Main Menu
|
filters that can be later reused for operations on meshes. You can
|
||||||
via <b>Tools / Selection filter library</b>.
|
access to it from the Main Menu via <b>Tools / Selection filter library</b>.
|
||||||
|
It is also possible to save any filter by invoking the filter library
|
||||||
|
from \a Filter dialog launched from any mesh operation.
|
||||||
|
|
||||||
\image html selectionfilterlibrary.png
|
\image html selectionfilterlibrary.png
|
||||||
|
|
||||||
@ -20,7 +22,9 @@ filter. By default it is prefixed with the corresponding entity type.
|
|||||||
|
|
||||||
When we use filters during a group creation or another operation (by
|
When we use filters during a group creation or another operation (by
|
||||||
clicking <b>Set Filter</b> button in the corresponding dialog), the
|
clicking <b>Set Filter</b> button in the corresponding dialog), the
|
||||||
menu for setting filters looks as shown below.
|
dialog for setting filters looks as shown below.
|
||||||
|
|
||||||
|
\image html a-filteronfaces.png
|
||||||
|
|
||||||
The \b Add button creates a new criterion at the end of the list of
|
The \b Add button creates a new criterion at the end of the list of
|
||||||
criteria. The \b Insert button creates a new criterion before the
|
criteria. The \b Insert button creates a new criterion before the
|
||||||
@ -56,8 +60,6 @@ in the Library.
|
|||||||
is no selected mesh in the Object Browser and the filter can not be
|
is no selected mesh in the Object Browser and the filter can not be
|
||||||
created. You have to select the mesh and the button will be enabled.
|
created. You have to select the mesh and the button will be enabled.
|
||||||
|
|
||||||
\image html a-filteronfaces.png
|
|
||||||
|
|
||||||
Some criteria are applicable to all <b>Entity types</b>:
|
Some criteria are applicable to all <b>Entity types</b>:
|
||||||
<ul><li>
|
<ul><li>
|
||||||
<b>Belong to Geom</b> selects entities whose all nodes lie on the
|
<b>Belong to Geom</b> selects entities whose all nodes lie on the
|
||||||
@ -133,7 +135,7 @@ See also \ref tui_double_nodes_control "Double Nodes quality control".
|
|||||||
The following criteria allow selecting mesh <b>Edges</b>:
|
The following criteria allow selecting mesh <b>Edges</b>:
|
||||||
<ul><li>
|
<ul><li>
|
||||||
<b>Free Borders</b> selects free 1D mesh elements, i.e. edges belonging to
|
<b>Free Borders</b> selects free 1D mesh elements, i.e. edges belonging to
|
||||||
one face only. See also a
|
one element (face or volume) only. See also a
|
||||||
\ref free_borders_page "Free Borders quality control".
|
\ref free_borders_page "Free Borders quality control".
|
||||||
</li><li>
|
</li><li>
|
||||||
<b>Double edges</b> selects 1D mesh elements basing on the same set of nodes.
|
<b>Double edges</b> selects 1D mesh elements basing on the same set of nodes.
|
||||||
@ -177,8 +179,8 @@ The following criteria allow selecting mesh <b>Faces</b>:
|
|||||||
\ref area_page "Area quality control"), which is more, less or equal (within a given
|
\ref area_page "Area quality control"), which is more, less or equal (within a given
|
||||||
<b>Tolerance</b>) to the predefined <b>Threshold Value</b>.
|
<b>Tolerance</b>) to the predefined <b>Threshold Value</b>.
|
||||||
</li><li>
|
</li><li>
|
||||||
<b>Free edges</b> selects 2D mesh elements consisting of edges belonging to
|
<b>Free edges</b> selects 2D mesh elements having at least one of its
|
||||||
one element of mesh only. See also a
|
edges not shared with other faces. See also a
|
||||||
\ref free_edges_page "Free Edges quality control".
|
\ref free_edges_page "Free Edges quality control".
|
||||||
</li><li>
|
</li><li>
|
||||||
<b>Free faces</b> selects 2D mesh elements, which belong to less than two volumes.
|
<b>Free faces</b> selects 2D mesh elements, which belong to less than two volumes.
|
||||||
|
@ -135,8 +135,8 @@ namespace {
|
|||||||
int aResult0 = 0, aResult1 = 0;
|
int aResult0 = 0, aResult1 = 0;
|
||||||
// last node, it is a medium one in a quadratic edge
|
// last node, it is a medium one in a quadratic edge
|
||||||
const SMDS_MeshNode* aLastNode = anEdge->GetNode( anEdge->NbNodes() - 1 );
|
const SMDS_MeshNode* aLastNode = anEdge->GetNode( anEdge->NbNodes() - 1 );
|
||||||
const SMDS_MeshNode* aNode0 = anEdge->GetNode( 0 );
|
const SMDS_MeshNode* aNode0 = anEdge->GetNode( 0 );
|
||||||
const SMDS_MeshNode* aNode1 = anEdge->GetNode( 1 );
|
const SMDS_MeshNode* aNode1 = anEdge->GetNode( 1 );
|
||||||
if ( aNode1 == aLastNode ) aNode1 = 0;
|
if ( aNode1 == aLastNode ) aNode1 = 0;
|
||||||
|
|
||||||
SMDS_ElemIteratorPtr anElemIter = aLastNode->GetInverseElementIterator();
|
SMDS_ElemIteratorPtr anElemIter = aLastNode->GetInverseElementIterator();
|
||||||
@ -2429,26 +2429,15 @@ bool FreeEdges::IsSatisfy( long theId )
|
|||||||
if ( aFace == 0 || aFace->GetType() != SMDSAbs_Face || aFace->NbNodes() < 3 )
|
if ( aFace == 0 || aFace->GetType() != SMDSAbs_Face || aFace->NbNodes() < 3 )
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
SMDS_ElemIteratorPtr anIter;
|
SMDS_NodeIteratorPtr anIter = aFace->interlacedNodesIterator();
|
||||||
if ( aFace->IsQuadratic() ) {
|
|
||||||
anIter = dynamic_cast<const SMDS_VtkFace*>
|
|
||||||
(aFace)->interlacedNodesElemIterator();
|
|
||||||
}
|
|
||||||
else {
|
|
||||||
anIter = aFace->nodesIterator();
|
|
||||||
}
|
|
||||||
if ( !anIter )
|
if ( !anIter )
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
int i = 0, nbNodes = aFace->NbNodes();
|
int i = 0, nbNodes = aFace->NbNodes();
|
||||||
std::vector <const SMDS_MeshNode*> aNodes( nbNodes+1 );
|
std::vector <const SMDS_MeshNode*> aNodes( nbNodes+1 );
|
||||||
while( anIter->more() )
|
while( anIter->more() )
|
||||||
{
|
if ( ! ( aNodes[ i++ ] = anIter->next() ))
|
||||||
const SMDS_MeshNode* aNode = (SMDS_MeshNode*)anIter->next();
|
|
||||||
if ( aNode == 0 )
|
|
||||||
return false;
|
return false;
|
||||||
aNodes[ i++ ] = aNode;
|
|
||||||
}
|
|
||||||
aNodes[ nbNodes ] = aNodes[ 0 ];
|
aNodes[ nbNodes ] = aNodes[ 0 ];
|
||||||
|
|
||||||
for ( i = 0; i < nbNodes; i++ )
|
for ( i = 0; i < nbNodes; i++ )
|
||||||
|
@ -1677,7 +1677,7 @@ namespace
|
|||||||
if(!anIO.IsNull()){
|
if(!anIO.IsNull()){
|
||||||
_PTR(SObject) SO = aStudy->FindObjectID( It.Value()->getEntry() );
|
_PTR(SObject) SO = aStudy->FindObjectID( It.Value()->getEntry() );
|
||||||
if ( SO ) {
|
if ( SO ) {
|
||||||
CORBA::Object_var aObject = SMESH::SObjectToObject( SO );
|
CORBA::Object_var aObject = SMESH::SObjectToObject( SO );
|
||||||
SMESH::SMESH_Mesh_var aMesh = SMESH::SMESH_Mesh::_narrow( aObject );
|
SMESH::SMESH_Mesh_var aMesh = SMESH::SMESH_Mesh::_narrow( aObject );
|
||||||
SMESH::SMESH_subMesh_var aSubMesh = SMESH::SMESH_subMesh::_narrow( aObject );
|
SMESH::SMESH_subMesh_var aSubMesh = SMESH::SMESH_subMesh::_narrow( aObject );
|
||||||
SMESH::SMESH_GroupBase_var aGroup = SMESH::SMESH_GroupBase::_narrow( aObject );
|
SMESH::SMESH_GroupBase_var aGroup = SMESH::SMESH_GroupBase::_narrow( aObject );
|
||||||
@ -4366,7 +4366,8 @@ void SMESHGUI::initialize( CAM_Application* app )
|
|||||||
hasElems0d("({'Elem0d'} in elemTypes)"),
|
hasElems0d("({'Elem0d'} in elemTypes)"),
|
||||||
hasEdges("({'Edge'} in elemTypes)"),
|
hasEdges("({'Edge'} in elemTypes)"),
|
||||||
hasFaces("({'Face'} in elemTypes)"),
|
hasFaces("({'Face'} in elemTypes)"),
|
||||||
hasVolumes("({'Volume'} in elemTypes)");
|
hasVolumes("({'Volume'} in elemTypes)"),
|
||||||
|
hasFacesOrVolumes("(({'Face'} in elemTypes) || ({'Volume'} in elemTypes)) ");
|
||||||
|
|
||||||
createPopupItem( SMESHOp::OpFileInformation, OB, mesh, "&& selcount=1 && isImported" );
|
createPopupItem( SMESHOp::OpFileInformation, OB, mesh, "&& selcount=1 && isImported" );
|
||||||
createPopupItem( SMESHOp::OpCreateSubMesh, OB, mesh, "&& isComputable");
|
createPopupItem( SMESHOp::OpCreateSubMesh, OB, mesh, "&& isComputable");
|
||||||
@ -4577,12 +4578,8 @@ void SMESHGUI::initialize( CAM_Application* app )
|
|||||||
|
|
||||||
aSubId = popupMgr()->insert( tr( "MEN_EDGE_CTRL" ), anId, -1 ); // EDGE CONTROLS
|
aSubId = popupMgr()->insert( tr( "MEN_EDGE_CTRL" ), anId, -1 ); // EDGE CONTROLS
|
||||||
|
|
||||||
popupMgr()->insert( action( SMESHOp::OpFreeEdge ), aSubId, -1 );
|
|
||||||
popupMgr()->setRule( action( SMESHOp::OpFreeEdge ), aMeshInVtkHasEdges, QtxPopupMgr::VisibleRule );
|
|
||||||
popupMgr()->setRule( action( SMESHOp::OpFreeEdge ), "controlMode = 'eFreeEdges'", QtxPopupMgr::ToggleRule );
|
|
||||||
|
|
||||||
popupMgr()->insert( action( SMESHOp::OpFreeBorder ), aSubId, -1 );
|
popupMgr()->insert( action( SMESHOp::OpFreeBorder ), aSubId, -1 );
|
||||||
popupMgr()->setRule( action( SMESHOp::OpFreeBorder ), aMeshInVtkHasEdges, QtxPopupMgr::VisibleRule );
|
popupMgr()->setRule( action( SMESHOp::OpFreeBorder ), aMeshInVTK + "&&" + hasEdges + "&&" + hasFacesOrVolumes, QtxPopupMgr::VisibleRule );
|
||||||
popupMgr()->setRule( action( SMESHOp::OpFreeBorder ), "controlMode = 'eFreeBorders'", QtxPopupMgr::ToggleRule );
|
popupMgr()->setRule( action( SMESHOp::OpFreeBorder ), "controlMode = 'eFreeBorders'", QtxPopupMgr::ToggleRule );
|
||||||
|
|
||||||
popupMgr()->insert( action( SMESHOp::OpLength ), aSubId, -1 );
|
popupMgr()->insert( action( SMESHOp::OpLength ), aSubId, -1 );
|
||||||
@ -4598,6 +4595,10 @@ void SMESHGUI::initialize( CAM_Application* app )
|
|||||||
|
|
||||||
aSubId = popupMgr()->insert( tr( "MEN_FACE_CTRL" ), anId, -1 ); // FACE CONTROLS
|
aSubId = popupMgr()->insert( tr( "MEN_FACE_CTRL" ), anId, -1 ); // FACE CONTROLS
|
||||||
|
|
||||||
|
popupMgr()->insert( action( SMESHOp::OpFreeEdge ), aSubId, -1 );
|
||||||
|
popupMgr()->setRule( action( SMESHOp::OpFreeEdge ), aMeshInVtkHasFaces, QtxPopupMgr::VisibleRule );
|
||||||
|
popupMgr()->setRule( action( SMESHOp::OpFreeEdge ), "controlMode = 'eFreeEdges'", QtxPopupMgr::ToggleRule );
|
||||||
|
|
||||||
popupMgr()->insert ( action( SMESHOp::OpFreeFace ), aSubId, -1 );
|
popupMgr()->insert ( action( SMESHOp::OpFreeFace ), aSubId, -1 );
|
||||||
popupMgr()->setRule( action( SMESHOp::OpFreeFace ), aMeshInVtkHasFaces /*aMeshInVtkHasVolumes*/,
|
popupMgr()->setRule( action( SMESHOp::OpFreeFace ), aMeshInVtkHasFaces /*aMeshInVtkHasVolumes*/,
|
||||||
QtxPopupMgr::VisibleRule );
|
QtxPopupMgr::VisibleRule );
|
||||||
|
@ -1260,7 +1260,7 @@ bool AdaptiveAlgo::Compute(SMESH_Mesh & theMesh,
|
|||||||
double maxSegSize = 0;
|
double maxSegSize = 0;
|
||||||
|
|
||||||
// get points to check distance to the face
|
// get points to check distance to the face
|
||||||
EdgeData::TPntIter pIt2 = eData.myPoints.begin(), pIt1 = pIt2++;
|
EdgeData::TPntIter pIt2 = eData.myPoints.begin(), pIt1 = pIt2++, pItLast;
|
||||||
maxSegSize = pIt1->mySegSize = Min( pIt1->mySegSize, sizeTree.GetSize( pIt1->myP ));
|
maxSegSize = pIt1->mySegSize = Min( pIt1->mySegSize, sizeTree.GetSize( pIt1->myP ));
|
||||||
for ( ; pIt2 != eData.myPoints.end(); )
|
for ( ; pIt2 != eData.myPoints.end(); )
|
||||||
{
|
{
|
||||||
@ -1290,6 +1290,7 @@ bool AdaptiveAlgo::Compute(SMESH_Mesh & theMesh,
|
|||||||
//cout << "E " << theMesh.GetMeshDS()->ShapeToIndex( eData.Edge() ) << endl;
|
//cout << "E " << theMesh.GetMeshDS()->ShapeToIndex( eData.Edge() ) << endl;
|
||||||
sizeDecreased = false;
|
sizeDecreased = false;
|
||||||
const gp_Pnt* avoidPnt = & eData.First().myP;
|
const gp_Pnt* avoidPnt = & eData.First().myP;
|
||||||
|
pItLast = --eData.myPoints.end();
|
||||||
for ( pIt1 = eData.myPoints.begin(); pIt1 != eData.myPoints.end(); )
|
for ( pIt1 = eData.myPoints.begin(); pIt1 != eData.myPoints.end(); )
|
||||||
{
|
{
|
||||||
double distToFace =
|
double distToFace =
|
||||||
@ -1316,7 +1317,7 @@ bool AdaptiveAlgo::Compute(SMESH_Mesh & theMesh,
|
|||||||
pIt1->mySegSize = allowedSize;
|
pIt1->mySegSize = allowedSize;
|
||||||
}
|
}
|
||||||
++pIt1;
|
++pIt1;
|
||||||
if ( & (*pIt1) == & eData.Last() )
|
if ( pIt1 == pItLast )
|
||||||
avoidPnt = & eData.Last().myP;
|
avoidPnt = & eData.Last().myP;
|
||||||
else
|
else
|
||||||
avoidPnt = NULL;
|
avoidPnt = NULL;
|
||||||
|
@ -657,7 +657,7 @@ void StdMeshers_Penta_3D::MakeVolumeMesh()
|
|||||||
}
|
}
|
||||||
//
|
//
|
||||||
// 2. Make pentahedrons
|
// 2. Make pentahedrons
|
||||||
int aID0, k , aJ[3];
|
int aID0, k , aJ[4];
|
||||||
vector<const SMDS_MeshNode*> aN;
|
vector<const SMDS_MeshNode*> aN;
|
||||||
//
|
//
|
||||||
SMDS_ElemIteratorPtr itf, aItNodes;
|
SMDS_ElemIteratorPtr itf, aItNodes;
|
||||||
|
@ -5072,8 +5072,10 @@ int StdMeshers_Quadrangle_2D::splitQuad(FaceQuadStruct::Ptr quad, int I, int J)
|
|||||||
// << " L " << &quad->side[ QUAD_LEFT_SIDE ] << " "<< quad->side[ QUAD_LEFT_SIDE].NbPoints()
|
// << " L " << &quad->side[ QUAD_LEFT_SIDE ] << " "<< quad->side[ QUAD_LEFT_SIDE].NbPoints()
|
||||||
// << " R " << &quad->side[ QUAD_RIGHT_SIDE ] << " "<< quad->side[ QUAD_RIGHT_SIDE].NbPoints()<< endl;
|
// << " R " << &quad->side[ QUAD_RIGHT_SIDE ] << " "<< quad->side[ QUAD_RIGHT_SIDE].NbPoints()<< endl;
|
||||||
|
|
||||||
newQuad->side[ QUAD_RIGHT_SIDE ].to = iRgt+1;
|
bool rRev = newQuad->side[ QUAD_RIGHT_SIDE ].IsReversed();
|
||||||
newQuad->side[ QUAD_LEFT_SIDE ].to = iLft+1;
|
bool lRev = newQuad->side[ QUAD_LEFT_SIDE ].IsReversed();
|
||||||
|
newQuad->side[ QUAD_RIGHT_SIDE ].to = iRgt + ( rRev ? -1 : +1 );
|
||||||
|
newQuad->side[ QUAD_LEFT_SIDE ].to = iLft + ( lRev ? -1 : +1 );
|
||||||
newQuad->name = ( TComm("Below J=") << J );
|
newQuad->name = ( TComm("Below J=") << J );
|
||||||
|
|
||||||
quad->side[ QUAD_RIGHT_SIDE ].from = iRgt;
|
quad->side[ QUAD_RIGHT_SIDE ].from = iRgt;
|
||||||
|
@ -930,8 +930,7 @@ bool StdMeshers_RadialQuadrangle_1D2D::Compute(SMESH_Mesh& aMesh,
|
|||||||
//cout<<"Angles.Length() = "<<Angles.Length()<<" Points.Length() = "<<Points.Length()<<endl;
|
//cout<<"Angles.Length() = "<<Angles.Length()<<" Points.Length() = "<<Points.Length()<<endl;
|
||||||
//cout<<"Nodes1.size() = "<<Nodes1.size()<<" Pnts2d1.Length() = "<<Pnts2d1.Length()<<endl;
|
//cout<<"Nodes1.size() = "<<Nodes1.size()<<" Pnts2d1.Length() = "<<Pnts2d1.Length()<<endl;
|
||||||
for(; i<Angles.Length(); i++) {
|
for(; i<Angles.Length(); i++) {
|
||||||
vector< const SMDS_MeshNode* > tmpNodes;
|
vector< const SMDS_MeshNode* > tmpNodes(Nodes1.size());
|
||||||
tmpNodes.reserve(Nodes1.size());
|
|
||||||
gp_Trsf aTrsf;
|
gp_Trsf aTrsf;
|
||||||
gp_Ax1 theAxis(P0,gp_Dir(Axis));
|
gp_Ax1 theAxis(P0,gp_Dir(Axis));
|
||||||
aTrsf.SetRotation( theAxis, Angles.Value(i) );
|
aTrsf.SetRotation( theAxis, Angles.Value(i) );
|
||||||
|
Loading…
Reference in New Issue
Block a user