mirror of
https://git.dev.opencascade.org/repos/occt.git
synced 2025-04-03 17:56:21 +03:00
Coding - Resolving C6263 warnings
Reorganizing code to not call alloca inside loop. alloca allocated memory from stack and free after finishing function
This commit is contained in:
parent
33339b0dc2
commit
6cb0b9b4e3
@ -50,6 +50,85 @@
|
|||||||
|
|
||||||
IMPLEMENT_STANDARD_RTTIEXT(MeshVS_MeshPrsBuilder,MeshVS_PrsBuilder)
|
IMPLEMENT_STANDARD_RTTIEXT(MeshVS_MeshPrsBuilder,MeshVS_PrsBuilder)
|
||||||
|
|
||||||
|
namespace
|
||||||
|
{
|
||||||
|
//================================================================
|
||||||
|
// Function : ProcessFace
|
||||||
|
// Purpose : Fill array with triangles for the face
|
||||||
|
//================================================================
|
||||||
|
static void ProcessFace(const Handle(MeshVS_HArray1OfSequenceOfInteger)& theTopo,
|
||||||
|
const TColStd_Array1OfReal& theNodes,
|
||||||
|
const Standard_Real* theCenter,
|
||||||
|
const Standard_Real theShrinkCoef,
|
||||||
|
const Standard_Boolean theIsShrinked,
|
||||||
|
const Standard_Boolean theIsShaded,
|
||||||
|
Handle(Graphic3d_ArrayOfPrimitives) theArray)
|
||||||
|
{
|
||||||
|
for (Standard_Integer aFaceIdx = theTopo->Lower(); aFaceIdx <= theTopo->Upper(); ++aFaceIdx)
|
||||||
|
{
|
||||||
|
const TColStd_SequenceOfInteger& aFaceNodes = theTopo->Value (aFaceIdx);
|
||||||
|
const Standard_Integer aNbPolyNodes = aFaceNodes.Length();
|
||||||
|
|
||||||
|
Standard_Real* aPolyNodesBuf = (Standard_Real*) alloca ((3 * aNbPolyNodes + 1) * sizeof (Standard_Real));
|
||||||
|
TColStd_Array1OfReal aPolyNodes (*aPolyNodesBuf, 0, 3 * aNbPolyNodes);
|
||||||
|
|
||||||
|
for (Standard_Integer aNodeIdx = 0; aNodeIdx < aNbPolyNodes; ++aNodeIdx)
|
||||||
|
{
|
||||||
|
Standard_Integer anIdx = aFaceNodes.Value (aNodeIdx + 1);
|
||||||
|
|
||||||
|
Standard_Real aX = theNodes.Value (theNodes.Lower() + 3 * anIdx + 0);
|
||||||
|
Standard_Real aY = theNodes.Value (theNodes.Lower() + 3 * anIdx + 1);
|
||||||
|
Standard_Real aZ = theNodes.Value (theNodes.Lower() + 3 * anIdx + 2);
|
||||||
|
|
||||||
|
if (theIsShrinked)
|
||||||
|
{
|
||||||
|
aX = theCenter[0] + theShrinkCoef * (aX - theCenter[0]);
|
||||||
|
aY = theCenter[1] + theShrinkCoef * (aY - theCenter[1]);
|
||||||
|
aZ = theCenter[2] + theShrinkCoef * (aZ - theCenter[2]);
|
||||||
|
}
|
||||||
|
|
||||||
|
aPolyNodes.SetValue (3 * aNodeIdx + 1, aX);
|
||||||
|
aPolyNodes.SetValue (3 * aNodeIdx + 2, aY);
|
||||||
|
aPolyNodes.SetValue (3 * aNodeIdx + 3, aZ);
|
||||||
|
}
|
||||||
|
|
||||||
|
gp_Vec aNorm;
|
||||||
|
|
||||||
|
if (theIsShaded)
|
||||||
|
{
|
||||||
|
aPolyNodes.SetValue (0, aNbPolyNodes);
|
||||||
|
|
||||||
|
if (!MeshVS_Tool::GetAverageNormal (aPolyNodes, aNorm))
|
||||||
|
{
|
||||||
|
aNorm.SetCoord (0.0, 0.0, 1.0);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
for (Standard_Integer aNodeIdx = 0; aNodeIdx < aNbPolyNodes - 2; ++aNodeIdx) // triangulate polygon
|
||||||
|
{
|
||||||
|
for (Standard_Integer aSubIdx = 0; aSubIdx < 3; ++aSubIdx) // generate sub-triangle
|
||||||
|
{
|
||||||
|
if (theIsShaded)
|
||||||
|
{
|
||||||
|
theArray->AddVertex (aPolyNodes.Value (3 * (aSubIdx == 0 ? 0 : (aNodeIdx + aSubIdx)) + 1),
|
||||||
|
aPolyNodes.Value (3 * (aSubIdx == 0 ? 0 : (aNodeIdx + aSubIdx)) + 2),
|
||||||
|
aPolyNodes.Value (3 * (aSubIdx == 0 ? 0 : (aNodeIdx + aSubIdx)) + 3),
|
||||||
|
aNorm.X(),
|
||||||
|
aNorm.Y(),
|
||||||
|
aNorm.Z());
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
theArray->AddVertex (aPolyNodes.Value (3 * (aSubIdx == 0 ? 0 : (aNodeIdx + aSubIdx)) + 1),
|
||||||
|
aPolyNodes.Value (3 * (aSubIdx == 0 ? 0 : (aNodeIdx + aSubIdx)) + 2),
|
||||||
|
aPolyNodes.Value (3 * (aSubIdx == 0 ? 0 : (aNodeIdx + aSubIdx)) + 3));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
//================================================================
|
//================================================================
|
||||||
// Function : Constructor MeshVS_MeshPrsBuilder
|
// Function : Constructor MeshVS_MeshPrsBuilder
|
||||||
// Purpose :
|
// Purpose :
|
||||||
@ -838,68 +917,7 @@ void MeshVS_MeshPrsBuilder::AddVolumePrs (const Handle(MeshVS_HArray1OfSequenceO
|
|||||||
|
|
||||||
if (aIsPolygons)
|
if (aIsPolygons)
|
||||||
{
|
{
|
||||||
for (Standard_Integer aFaceIdx = theTopo->Lower(), topoup = theTopo->Upper(); aFaceIdx <= topoup; ++aFaceIdx)
|
ProcessFace (theTopo, theNodes, aCenter, theShrinkCoef, theIsShrinked, theIsShaded, theArray);
|
||||||
{
|
|
||||||
const TColStd_SequenceOfInteger& aFaceNodes = theTopo->Value (aFaceIdx);
|
|
||||||
const Standard_Integer aNbPolyNodes = aFaceNodes.Length();
|
|
||||||
|
|
||||||
Standard_Real* aPolyNodesBuf = (Standard_Real*) alloca ((3 * aNbPolyNodes + 1) * sizeof (Standard_Real));
|
|
||||||
TColStd_Array1OfReal aPolyNodes (*aPolyNodesBuf, 0, 3 * aNbPolyNodes);
|
|
||||||
|
|
||||||
for (Standard_Integer aNodeIdx = 0; aNodeIdx < aNbPolyNodes; ++aNodeIdx)
|
|
||||||
{
|
|
||||||
Standard_Integer anIdx = aFaceNodes.Value (aNodeIdx + 1);
|
|
||||||
|
|
||||||
Standard_Real aX = theNodes.Value (aLow + 3 * anIdx + 0);
|
|
||||||
Standard_Real aY = theNodes.Value (aLow + 3 * anIdx + 1);
|
|
||||||
Standard_Real aZ = theNodes.Value (aLow + 3 * anIdx + 2);
|
|
||||||
|
|
||||||
if (theIsShrinked)
|
|
||||||
{
|
|
||||||
aX = aCenter[0] + theShrinkCoef * (aX - aCenter[0]);
|
|
||||||
aY = aCenter[1] + theShrinkCoef * (aY - aCenter[1]);
|
|
||||||
aZ = aCenter[2] + theShrinkCoef * (aZ - aCenter[2]);
|
|
||||||
}
|
|
||||||
|
|
||||||
aPolyNodes.SetValue (3 * aNodeIdx + 1, aX);
|
|
||||||
aPolyNodes.SetValue (3 * aNodeIdx + 2, aY);
|
|
||||||
aPolyNodes.SetValue (3 * aNodeIdx + 3, aZ);
|
|
||||||
}
|
|
||||||
|
|
||||||
gp_Vec aNorm;
|
|
||||||
|
|
||||||
if (theIsShaded)
|
|
||||||
{
|
|
||||||
aPolyNodes.SetValue (0, aNbPolyNodes);
|
|
||||||
|
|
||||||
if (!MeshVS_Tool::GetAverageNormal (aPolyNodes, aNorm))
|
|
||||||
{
|
|
||||||
aNorm.SetCoord (0.0, 0.0, 1.0);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
for (Standard_Integer aNodeIdx = 0; aNodeIdx < aNbPolyNodes - 2; ++aNodeIdx) // triangulate polygon
|
|
||||||
{
|
|
||||||
for (Standard_Integer aSubIdx = 0; aSubIdx < 3; ++aSubIdx) // generate sub-triangle
|
|
||||||
{
|
|
||||||
if (theIsShaded)
|
|
||||||
{
|
|
||||||
theArray->AddVertex (aPolyNodes.Value (3 * (aSubIdx == 0 ? 0 : (aNodeIdx + aSubIdx)) + 1),
|
|
||||||
aPolyNodes.Value (3 * (aSubIdx == 0 ? 0 : (aNodeIdx + aSubIdx)) + 2),
|
|
||||||
aPolyNodes.Value (3 * (aSubIdx == 0 ? 0 : (aNodeIdx + aSubIdx)) + 3),
|
|
||||||
aNorm.X(),
|
|
||||||
aNorm.Y(),
|
|
||||||
aNorm.Z());
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
theArray->AddVertex (aPolyNodes.Value (3 * (aSubIdx == 0 ? 0 : (aNodeIdx + aSubIdx)) + 1),
|
|
||||||
aPolyNodes.Value (3 * (aSubIdx == 0 ? 0 : (aNodeIdx + aSubIdx)) + 2),
|
|
||||||
aPolyNodes.Value (3 * (aSubIdx == 0 ? 0 : (aNodeIdx + aSubIdx)) + 3));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
else if (theIsSelected)
|
else if (theIsSelected)
|
||||||
{
|
{
|
||||||
|
Loading…
x
Reference in New Issue
Block a user