mirror of
https://git.salome-platform.org/gitpub/modules/geom.git
synced 2025-01-12 17:50:35 +05:00
Tests and debug
This commit is contained in:
parent
3c5b3f14f2
commit
2d6c2bb07d
136
doc/salome/examples/curvature_face.py
Normal file
136
doc/salome/examples/curvature_face.py
Normal file
@ -0,0 +1,136 @@
|
|||||||
|
# Curvature of a Face along given direction
|
||||||
|
|
||||||
|
import salome
|
||||||
|
salome.salome_init_without_session()
|
||||||
|
import GEOM
|
||||||
|
from salome.geom import geomBuilder
|
||||||
|
geompy = geomBuilder.New()
|
||||||
|
import math
|
||||||
|
|
||||||
|
O = geompy.MakeVertex(0, 0, 0, 'O')
|
||||||
|
OX = geompy.MakeVectorDXDYDZ(1, 0, 0, 'OX')
|
||||||
|
OY = geompy.MakeVectorDXDYDZ(0, 1, 0, 'OY')
|
||||||
|
OZ = geompy.MakeVectorDXDYDZ(0, 0, 1, 'OZ')
|
||||||
|
|
||||||
|
pXYZ = geompy.MakeVertex(105, 105, 105, 'pXYZ')
|
||||||
|
pY = geompy.MakeVertex(0, 105, 0, 'pY')
|
||||||
|
pZ = geompy.MakeVertex(0, 0, 105, 'pZ')
|
||||||
|
|
||||||
|
vZ_XY = geompy.MakeVectorDXDYDZ(-1, -1, 1, 'vZ-XY')
|
||||||
|
vZ_XY2 = geompy.MakeVectorDXDYDZ(-1, -1, 10, 'vZ-XY')
|
||||||
|
vZ_XY3 = geompy.MakeVectorDXDYDZ(-1, -1, 100, 'vZ-XY')
|
||||||
|
|
||||||
|
R = 100.0
|
||||||
|
|
||||||
|
# I. Curvature of a Sphere
|
||||||
|
Sphere_1 = geompy.MakeSphereR(R, 'Sphere_1')
|
||||||
|
[Sph] = geompy.ExtractShapes(Sphere_1, geompy.ShapeType["FACE"], True, "Sph")
|
||||||
|
|
||||||
|
curvature_1 = geompy.CurvatureOnFace(Sph, pXYZ, OX, 'curvature_sph_pXYZ_OX')
|
||||||
|
curvature_2 = geompy.CurvatureOnFace(Sph, pXYZ, vZ_XY, 'curvature_sph_pXYZ_vt')
|
||||||
|
curvature_3 = geompy.CurvatureOnFace(Sph, pY, OX, 'curvature_sph_pY_OX')
|
||||||
|
|
||||||
|
# All sphere curvature radiuces = R
|
||||||
|
assert(abs(geompy.BasicProperties(curvature_1)[0] - R) < 1e-07)
|
||||||
|
assert(abs(geompy.BasicProperties(curvature_2)[0] - R) < 1e-07)
|
||||||
|
assert(abs(geompy.BasicProperties(curvature_3)[0] - R) < 1e-07)
|
||||||
|
|
||||||
|
# Normal direction
|
||||||
|
isExcept = False
|
||||||
|
try:
|
||||||
|
geompy.CurvatureOnFace(Sph, pY, OY)
|
||||||
|
except:
|
||||||
|
isExcept = True
|
||||||
|
assert(isExcept)
|
||||||
|
|
||||||
|
# Pole (min and max curvatures are not defined, find via line projection?)
|
||||||
|
isExcept = False
|
||||||
|
try:
|
||||||
|
geompy.CurvatureOnFace(Sph, pZ, OX, 'curvature_sph_pZ_OX')
|
||||||
|
except:
|
||||||
|
isExcept = True
|
||||||
|
print(geompy.MeasuOp.GetErrorCode())
|
||||||
|
assert(isExcept)
|
||||||
|
|
||||||
|
# II. Curvature of a Cylinder
|
||||||
|
Cylinder_1 = geompy.MakeCylinderRH(R, 300, 'Cylinder_1')
|
||||||
|
[Face_1,Face_2,Face_3] = geompy.ExtractShapes(Cylinder_1, geompy.ShapeType["FACE"], True, "Face")
|
||||||
|
|
||||||
|
# Curvature radius of a cylinder along any direction, orthogonal to its Z axis, equal to R
|
||||||
|
curvature_4 = geompy.CurvatureOnFace(Face_2, pY, OX, 'curvature_cyl_pY_OX')
|
||||||
|
assert(abs(geompy.BasicProperties(curvature_4)[0] - R) < 1e-07)
|
||||||
|
|
||||||
|
# Curvature radius of a cylinder along its Z direction is infinite
|
||||||
|
curvature_zero = geompy.CurvatureOnFace(Face_2, pY, OZ)
|
||||||
|
assert(geompy.MeasuOp.GetErrorCode() == "ZERO_CURVATURE")
|
||||||
|
assert(not curvature_zero)
|
||||||
|
|
||||||
|
# Curvature radius of a cylinder along some direction, different from two above
|
||||||
|
curvature_5 = geompy.CurvatureOnFace(Face_2, pY, vZ_XY, 'curvature_cyl_pY_vZ_XY')
|
||||||
|
curvature_6 = geompy.CurvatureOnFace(Face_2, pY, vZ_XY2, 'curvature_cyl_pY_vZ_XY2')
|
||||||
|
curvature_7 = geompy.CurvatureOnFace(Face_2, pY, vZ_XY3, 'curvature_cyl_pY_vZ_XY3')
|
||||||
|
|
||||||
|
# R < r5 < r6 < r7
|
||||||
|
# r5 = 100.01, r6 = 101.0, r7 = 200
|
||||||
|
r5 = geompy.BasicProperties(curvature_5)[0]
|
||||||
|
r6 = geompy.BasicProperties(curvature_6)[0]
|
||||||
|
r7 = geompy.BasicProperties(curvature_7)[0]
|
||||||
|
|
||||||
|
assert(R + 1e-07 < r5)
|
||||||
|
assert(r5 + 1e-07 < r6)
|
||||||
|
assert(r6 + 1e-07 < r7)
|
||||||
|
|
||||||
|
# Projection aborted. Point is out of the face boundaries.
|
||||||
|
isExcept = False
|
||||||
|
try:
|
||||||
|
pXY_Z = geompy.MakeVertex(105, 105, -105, 'pXY_Z')
|
||||||
|
geompy.CurvatureOnFace(Face_2, pXY_Z, OX, 'curvature_cyl_pXY_Z')
|
||||||
|
except:
|
||||||
|
isExcept = True
|
||||||
|
assert(isExcept)
|
||||||
|
|
||||||
|
# Projection aborted (point on axis). Equal distances to many points.
|
||||||
|
isExcept = False
|
||||||
|
try:
|
||||||
|
geompy.CurvatureOnFace(Face_2, O, vZ_XY, 'curvature_cyl_O')
|
||||||
|
except:
|
||||||
|
isExcept = True
|
||||||
|
assert(isExcept)
|
||||||
|
|
||||||
|
# Curvature radius of a planar face is infinite
|
||||||
|
curvature_zero_2 = geompy.CurvatureOnFace(Face_1, pZ, OX)
|
||||||
|
assert(geompy.MeasuOp.GetErrorCode() == "ZERO_CURVATURE")
|
||||||
|
assert(not curvature_zero_2)
|
||||||
|
|
||||||
|
# III. Curvature of a "Horse saddle"
|
||||||
|
[Edge_1,Edge_2,Edge_3] = geompy.ExtractShapes(Sphere_1, geompy.ShapeType["EDGE"], True)
|
||||||
|
geompy.addToStudyInFather( Sphere_1, Edge_1, 'Edge_1' )
|
||||||
|
geompy.addToStudyInFather( Sphere_1, Edge_2, 'Edge_2' )
|
||||||
|
geompy.addToStudyInFather( Sphere_1, Edge_3, 'Edge_3' )
|
||||||
|
|
||||||
|
Rotation_1 = geompy.MakeRotation(Edge_3, OX, 90*math.pi/180.0, 'Rotation_1')
|
||||||
|
Rotation_2 = geompy.MakeRotation(Rotation_1, OY, 180*math.pi/180.0, 'Rotation_2')
|
||||||
|
Translation_1 = geompy.MakeTranslation(Rotation_2, 200, 0, 0, 'Translation_1')
|
||||||
|
Translation_2 = geompy.MakeTranslation(Edge_3, 100, 100, 0, 'Translation_2')
|
||||||
|
Translation_3 = geompy.MakeTranslation(Translation_2, 0, -200, 0, 'Translation_3')
|
||||||
|
Filling_1 = geompy.MakeFilling([Translation_2, Edge_3, Translation_3])
|
||||||
|
geompy.addToStudy(Filling_1, 'Filling_1')
|
||||||
|
Vertex_2 = geompy.MakeVertex(100, 0, 0, 'Vertex_2')
|
||||||
|
|
||||||
|
curvature_Y = geompy.CurvatureOnFace(Filling_1, Vertex_2, OY, 'curvature_Y')
|
||||||
|
curvature_Z = geompy.CurvatureOnFace(Filling_1, Vertex_2, OZ, 'curvature_Z')
|
||||||
|
|
||||||
|
cury = geompy.VectorCoordinates(curvature_Y)
|
||||||
|
curz = geompy.VectorCoordinates(curvature_Z)
|
||||||
|
|
||||||
|
# Vectors should be opposite, scalar product should be negative
|
||||||
|
assert(cury[0]*curz[0] + cury[1]*curz[1] + cury[2]*curz[2] < -1e-07)
|
||||||
|
|
||||||
|
# Normal direction
|
||||||
|
norm_1 = geompy.GetNormal(Filling_1, Vertex_2, "Normal_1")
|
||||||
|
isExcept = False
|
||||||
|
try:
|
||||||
|
geompy.CurvatureOnFace(Filling_1, Vertex_2, norm_1)
|
||||||
|
except:
|
||||||
|
isExcept = True
|
||||||
|
assert(isExcept)
|
@ -76,6 +76,7 @@ SET(GOOD_TESTS
|
|||||||
import_export.py
|
import_export.py
|
||||||
inertia.py
|
inertia.py
|
||||||
min_distance.py
|
min_distance.py
|
||||||
|
curvature_face.py
|
||||||
normal_face.py
|
normal_face.py
|
||||||
notebook_geom.py
|
notebook_geom.py
|
||||||
polyline.py
|
polyline.py
|
||||||
|
@ -108,6 +108,9 @@
|
|||||||
\until geompy.GetSubShapesWithTolerance(Box, GEOM.FACE, GEOM.CC_LE, 1.e-7, "le")
|
\until geompy.GetSubShapesWithTolerance(Box, GEOM.FACE, GEOM.CC_LE, 1.e-7, "le")
|
||||||
|
|
||||||
\anchor swig_MakeExtraction
|
\anchor swig_MakeExtraction
|
||||||
\until print "DONE"
|
\until geompy.MakeExtraction(Box, [16], "Ext_no_vertex")
|
||||||
|
|
||||||
|
\anchor swig_CurvatureOnFace
|
||||||
|
\until print("DONE")
|
||||||
|
|
||||||
*/
|
*/
|
||||||
|
@ -4980,6 +4980,10 @@ Please, select face, shell or solid and try again</translation>
|
|||||||
<source>STB_NORMALE</source>
|
<source>STB_NORMALE</source>
|
||||||
<translation>Compute normal to the face</translation>
|
<translation>Compute normal to the face</translation>
|
||||||
</message>
|
</message>
|
||||||
|
<message>
|
||||||
|
<source>MEN_CURVATURE</source>
|
||||||
|
<translation>Vector of curvature</translation>
|
||||||
|
</message>
|
||||||
<message>
|
<message>
|
||||||
<source>TOP_MEASURE_ANGLE</source>
|
<source>TOP_MEASURE_ANGLE</source>
|
||||||
<translation>Angle</translation>
|
<translation>Angle</translation>
|
||||||
|
@ -4972,6 +4972,10 @@ Choisissez une face, une coque ou un solide et essayez de nouveau</translation>
|
|||||||
<source>STB_NORMALE</source>
|
<source>STB_NORMALE</source>
|
||||||
<translation>Vecteur normal à une face</translation>
|
<translation>Vecteur normal à une face</translation>
|
||||||
</message>
|
</message>
|
||||||
|
<message>
|
||||||
|
<source>MEN_CURVATURE</source>
|
||||||
|
<translation>Vecteur de courbure</translation>
|
||||||
|
</message>
|
||||||
<message>
|
<message>
|
||||||
<source>TOP_MEASURE_ANGLE</source>
|
<source>TOP_MEASURE_ANGLE</source>
|
||||||
<translation>Angle</translation>
|
<translation>Angle</translation>
|
||||||
|
@ -4975,6 +4975,10 @@
|
|||||||
<source>STB_NORMALE</source>
|
<source>STB_NORMALE</source>
|
||||||
<translation>フェースに垂直</translation>
|
<translation>フェースに垂直</translation>
|
||||||
</message>
|
</message>
|
||||||
|
<message>
|
||||||
|
<source>MEN_CURVATURE</source>
|
||||||
|
<translation>Vector_of_curvature</translation>
|
||||||
|
</message>
|
||||||
<message>
|
<message>
|
||||||
<source>TOP_MEASURE_ANGLE</source>
|
<source>TOP_MEASURE_ANGLE</source>
|
||||||
<translation>角度</translation>
|
<translation>角度</translation>
|
||||||
|
@ -38,6 +38,7 @@
|
|||||||
#include <BRepBuilderAPI_MakeEdge.hxx>
|
#include <BRepBuilderAPI_MakeEdge.hxx>
|
||||||
#include <BRepBuilderAPI_MakeVertex.hxx>
|
#include <BRepBuilderAPI_MakeVertex.hxx>
|
||||||
#include <BRepPrimAPI_MakeBox.hxx>
|
#include <BRepPrimAPI_MakeBox.hxx>
|
||||||
|
#include <BRepOffsetAPI_NormalProjection.hxx>
|
||||||
|
|
||||||
#include <TopAbs.hxx>
|
#include <TopAbs.hxx>
|
||||||
#include <TopoDS.hxx>
|
#include <TopoDS.hxx>
|
||||||
@ -50,7 +51,9 @@
|
|||||||
|
|
||||||
#include <GProp_GProps.hxx>
|
#include <GProp_GProps.hxx>
|
||||||
#include <GeomLProp_SLProps.hxx>
|
#include <GeomLProp_SLProps.hxx>
|
||||||
|
#include <GeomLProp_CLProps.hxx>
|
||||||
#include <Geom_Surface.hxx>
|
#include <Geom_Surface.hxx>
|
||||||
|
#include <GeomAPI_ProjectPointOnCurve.hxx>
|
||||||
|
|
||||||
#include <Bnd_Box.hxx>
|
#include <Bnd_Box.hxx>
|
||||||
#include <BRepBndLib.hxx>
|
#include <BRepBndLib.hxx>
|
||||||
@ -91,33 +94,27 @@ TopoDS_Shape EvaluateAlongCurvature(const TopoDS_Shape& theFace,
|
|||||||
const TopoDS_Shape& thePoint,
|
const TopoDS_Shape& thePoint,
|
||||||
const TopoDS_Shape& theDir)
|
const TopoDS_Shape& theDir)
|
||||||
{
|
{
|
||||||
if (theFace.IsNull())
|
// Point
|
||||||
Standard_NullObject::Raise("Face for curvature calculation is null");
|
|
||||||
if (theFace.ShapeType() != TopAbs_FACE)
|
|
||||||
Standard_NullObject::Raise("Shape for curvature calculation is not a face");
|
|
||||||
TopoDS_Face aFace = TopoDS::Face(theFace);
|
|
||||||
Handle(Geom_Surface) aSurf = BRep_Tool::Surface(aFace);
|
|
||||||
if (aSurf.IsNull())
|
|
||||||
Standard_NullObject::Raise("Surface for curvature calculation is null");
|
|
||||||
|
|
||||||
if (thePoint.IsNull())
|
if (thePoint.IsNull())
|
||||||
Standard_NullObject::Raise("Point for curvature measurement is null");
|
Standard_NullObject::Raise("Point for curvature measurement is null");
|
||||||
if (thePoint.ShapeType() != TopAbs_VERTEX)
|
if (thePoint.ShapeType() != TopAbs_VERTEX)
|
||||||
Standard_NullObject::Raise("Point for curvature calculation is not a vertex");
|
Standard_TypeMismatch::Raise("Point for curvature calculation is not a vertex");
|
||||||
gp_Pnt aPnt = BRep_Tool::Pnt(TopoDS::Vertex(thePoint));
|
gp_Pnt aPnt = BRep_Tool::Pnt(TopoDS::Vertex(thePoint));
|
||||||
|
|
||||||
gp_Vec aV = GEOMUtils::GetVector(theDir, Standard_False);
|
// Point projection on the face
|
||||||
|
Standard_Real U, V;
|
||||||
|
aPnt = GEOMUtils::ProjectPointOnFace(aPnt, theFace, U, V);
|
||||||
|
gp_Pnt2d UV (U, V);
|
||||||
|
|
||||||
// Point projection parameters on surface
|
// Face and Vector
|
||||||
ShapeAnalysis_Surface aSAS (aSurf);
|
TopoDS_Face aFace = TopoDS::Face(theFace);
|
||||||
gp_Pnt2d UV = aSAS.ValueOfUV(aPnt, Precision::Confusion());
|
gp_Vec aV = GEOMUtils::GetVector(theDir, Standard_False);
|
||||||
aPnt = aSAS.Value(UV);
|
|
||||||
|
|
||||||
// Calculate differential properties
|
// Calculate differential properties
|
||||||
BRepAdaptor_Surface aSurfAdapt (aFace);
|
BRepAdaptor_Surface aSurfAdapt (aFace);
|
||||||
BRepLProp_SLProps Props (aSurfAdapt, UV.X(), UV.Y(), 2, 1e-7);
|
BRepLProp_SLProps Props (aSurfAdapt, UV.X(), UV.Y(), 2, 1e-7);
|
||||||
if (!Props.IsCurvatureDefined())
|
if (!Props.IsCurvatureDefined())
|
||||||
Standard_NullObject::Raise("Curvature calculation failed");
|
Standard_ConstructionError::Raise("Curvature calculation failed");
|
||||||
|
|
||||||
// Get differential properties
|
// Get differential properties
|
||||||
gp_Vec Xu = Props.D1U();
|
gp_Vec Xu = Props.D1U();
|
||||||
@ -133,7 +130,8 @@ TopoDS_Shape EvaluateAlongCurvature(const TopoDS_Shape& theFace,
|
|||||||
gp_Vec2d T (aV.Dot(aDirU), aV.Dot(aDirV));
|
gp_Vec2d T (aV.Dot(aDirU), aV.Dot(aDirV));
|
||||||
if (Abs(T.X()) < Precision::Confusion() &&
|
if (Abs(T.X()) < Precision::Confusion() &&
|
||||||
Abs(T.Y()) < Precision::Confusion())
|
Abs(T.Y()) < Precision::Confusion())
|
||||||
Standard_NullObject::Raise("Curvature calculation failed: direction is normal to the face");
|
Standard_ConstructionError::Raise
|
||||||
|
("Curvature calculation failed: direction is normal to the face");
|
||||||
|
|
||||||
// Coefficients of the FFF
|
// Coefficients of the FFF
|
||||||
double E = Xu.Dot(Xu);
|
double E = Xu.Dot(Xu);
|
||||||
@ -145,33 +143,29 @@ TopoDS_Shape EvaluateAlongCurvature(const TopoDS_Shape& theFace,
|
|||||||
double M = n.Dot(Xuv);
|
double M = n.Dot(Xuv);
|
||||||
double N = n.Dot(Xvv);
|
double N = n.Dot(Xvv);
|
||||||
|
|
||||||
// Calculate curvature using the coefficients of both fundamental forms
|
// Calculate radius (or -radius) of curvature
|
||||||
double k = 0.;
|
// using the coefficients of both fundamental forms
|
||||||
|
double r = 0.;
|
||||||
if (Abs(T.X()) < Precision::Confusion()) {
|
if (Abs(T.X()) < Precision::Confusion()) {
|
||||||
//if (Abs(G) < Precision::Confusion())
|
|
||||||
// Standard_NullObject::Raise("Curvature calculation failed: G = 0");
|
|
||||||
//k = N / G; // curvature
|
|
||||||
if (Abs(N) < Precision::Confusion())
|
if (Abs(N) < Precision::Confusion())
|
||||||
Standard_NullObject::Raise("Curvature calculation failed: N = 0");
|
Standard_Failure::Raise("ZERO_CURVATURE");
|
||||||
k = G / N; // radius of curvature
|
r = G / N;
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
double lambda = T.Y() / T.X();
|
double lambda = T.Y() / T.X();
|
||||||
double detE = E + 2*F*lambda + G*lambda*lambda;
|
double detE = E + 2*F*lambda + G*lambda*lambda;
|
||||||
double detL = L + 2*M*lambda + N*lambda*lambda;
|
double detL = L + 2*M*lambda + N*lambda*lambda;
|
||||||
//if (Abs(detE) < Precision::Confusion())
|
|
||||||
if (Abs(detL) < Precision::Confusion())
|
if (Abs(detL) < Precision::Confusion())
|
||||||
Standard_NullObject::Raise("Curvature calculation failed: det = 0");
|
Standard_Failure::Raise("ZERO_CURVATURE");
|
||||||
//k = detL / detE; // curvature
|
r = detE / detL;
|
||||||
k = detE / detL; // radius of curvature
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// Result
|
// Result
|
||||||
gp_Dir aNormal (n);
|
gp_Dir aNormal (n);
|
||||||
gp_Pnt aPntEnd (aPnt.XYZ() + aNormal.XYZ() * k);
|
gp_Pnt aPntEnd (aPnt.XYZ() + aNormal.XYZ() * r);
|
||||||
BRepBuilderAPI_MakeEdge aBuilder (aPnt, aPntEnd);
|
BRepBuilderAPI_MakeEdge aBuilder (aPnt, aPntEnd);
|
||||||
if (!aBuilder.IsDone())
|
if (!aBuilder.IsDone())
|
||||||
Standard_NullObject::Raise("Curvature calculation failed: edge is not built");
|
Standard_ConstructionError::Raise("Curvature calculation failed: edge is not built");
|
||||||
|
|
||||||
return aBuilder.Shape();
|
return aBuilder.Shape();
|
||||||
}
|
}
|
||||||
@ -466,6 +460,12 @@ GetCreationInformation(std::string& theOperationName,
|
|||||||
AddParam( theParams, "Face", aCI.GetBase() );
|
AddParam( theParams, "Face", aCI.GetBase() );
|
||||||
AddParam( theParams, "Point", aCI.GetPoint(), "face center" );
|
AddParam( theParams, "Point", aCI.GetPoint(), "face center" );
|
||||||
break;
|
break;
|
||||||
|
case CURVATURE_VEC_MEASURE:
|
||||||
|
theOperationName = "CURVATURE";
|
||||||
|
AddParam( theParams, "Face", aCI.GetBase() );
|
||||||
|
AddParam( theParams, "Point", aCI.GetPoint(), "point of interest" );
|
||||||
|
AddParam( theParams, "Vector", aCI.GetDirection(), "direction of interest" );
|
||||||
|
break;
|
||||||
default:
|
default:
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
@ -127,70 +127,11 @@ Standard_Integer GEOMImpl_ProjectionDriver::Execute(Handle(TFunction_Logbook)& l
|
|||||||
Handle(GEOM_Function) aTargetFunction = TI.GetPlane();
|
Handle(GEOM_Function) aTargetFunction = TI.GetPlane();
|
||||||
if (aTargetFunction.IsNull()) return 0;
|
if (aTargetFunction.IsNull()) return 0;
|
||||||
TopoDS_Shape aFaceShape = aTargetFunction->GetValue();
|
TopoDS_Shape aFaceShape = aTargetFunction->GetValue();
|
||||||
//if (aFaceShape.IsNull() || aFaceShape.ShapeType() != TopAbs_FACE) {
|
|
||||||
// Standard_ConstructionError::Raise
|
|
||||||
// ("Projection aborted : the target shape is not a face");
|
|
||||||
//}
|
|
||||||
|
|
||||||
Standard_Real tol = 1.e-4;
|
|
||||||
|
|
||||||
if (anOriginal.ShapeType() == TopAbs_VERTEX) {
|
if (anOriginal.ShapeType() == TopAbs_VERTEX) {
|
||||||
if (aFaceShape.IsNull() || aFaceShape.ShapeType() != TopAbs_FACE) {
|
|
||||||
Standard_ConstructionError::Raise
|
|
||||||
("Projection aborted : the target shape is not a face");
|
|
||||||
}
|
|
||||||
TopoDS_Face aFace = TopoDS::Face(aFaceShape);
|
|
||||||
Handle(Geom_Surface) surface = BRep_Tool::Surface(aFace);
|
|
||||||
double U1, U2, V1, V2;
|
|
||||||
//surface->Bounds(U1, U2, V1, V2);
|
|
||||||
BRepTools::UVBounds(aFace, U1, U2, V1, V2);
|
|
||||||
|
|
||||||
// projector
|
|
||||||
GeomAPI_ProjectPointOnSurf proj;
|
|
||||||
proj.Init(surface, U1, U2, V1, V2, tol);
|
|
||||||
|
|
||||||
gp_Pnt aPnt = BRep_Tool::Pnt(TopoDS::Vertex(anOriginal));
|
|
||||||
proj.Perform(aPnt);
|
|
||||||
if (!proj.IsDone()) {
|
|
||||||
Standard_ConstructionError::Raise
|
|
||||||
("Projection aborted : the algorithm failed");
|
|
||||||
}
|
|
||||||
int nbPoints = proj.NbPoints();
|
|
||||||
if (nbPoints < 1) {
|
|
||||||
Standard_ConstructionError::Raise("No solution found");
|
|
||||||
}
|
|
||||||
|
|
||||||
Standard_Real U, V;
|
Standard_Real U, V;
|
||||||
proj.LowerDistanceParameters(U, V);
|
gp_Pnt aPnt = BRep_Tool::Pnt(TopoDS::Vertex(anOriginal));
|
||||||
gp_Pnt2d aProjPnt (U, V);
|
gp_Pnt surfPnt = GEOMUtils::ProjectPointOnFace(aPnt, aFaceShape, U, V);
|
||||||
|
|
||||||
// classifier
|
|
||||||
BRepClass_FaceClassifier aClsf (aFace, aProjPnt, tol);
|
|
||||||
if (aClsf.State() != TopAbs_IN && aClsf.State() != TopAbs_ON) {
|
|
||||||
bool isSol = false;
|
|
||||||
double minDist = RealLast();
|
|
||||||
for (int i = 1; i <= nbPoints; i++) {
|
|
||||||
Standard_Real Ui, Vi;
|
|
||||||
proj.Parameters(i, Ui, Vi);
|
|
||||||
aProjPnt = gp_Pnt2d(Ui, Vi);
|
|
||||||
aClsf.Perform(aFace, aProjPnt, tol);
|
|
||||||
if (aClsf.State() == TopAbs_IN || aClsf.State() == TopAbs_ON) {
|
|
||||||
isSol = true;
|
|
||||||
double dist = proj.Distance(i);
|
|
||||||
if (dist < minDist) {
|
|
||||||
minDist = dist;
|
|
||||||
U = Ui;
|
|
||||||
V = Vi;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
if (!isSol) {
|
|
||||||
Standard_ConstructionError::Raise("No solution found");
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
gp_Pnt surfPnt = surface->Value(U, V);
|
|
||||||
|
|
||||||
aShape = BRepBuilderAPI_MakeVertex(surfPnt).Shape();
|
aShape = BRepBuilderAPI_MakeVertex(surfPnt).Shape();
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
|
@ -37,6 +37,7 @@
|
|||||||
#include <BRepGProp.hxx>
|
#include <BRepGProp.hxx>
|
||||||
#include <BRepTools.hxx>
|
#include <BRepTools.hxx>
|
||||||
|
|
||||||
|
#include <BRepClass_FaceClassifier.hxx>
|
||||||
#include <BRepClass3d_SolidClassifier.hxx>
|
#include <BRepClass3d_SolidClassifier.hxx>
|
||||||
|
|
||||||
#include <BRepBuilderAPI_MakeFace.hxx>
|
#include <BRepBuilderAPI_MakeFace.hxx>
|
||||||
@ -64,6 +65,8 @@
|
|||||||
#include <TopTools_ListIteratorOfListOfShape.hxx>
|
#include <TopTools_ListIteratorOfListOfShape.hxx>
|
||||||
#include <TopTools_Array1OfShape.hxx>
|
#include <TopTools_Array1OfShape.hxx>
|
||||||
|
|
||||||
|
#include <GeomAPI_ProjectPointOnSurf.hxx>
|
||||||
|
|
||||||
#include <Geom_Circle.hxx>
|
#include <Geom_Circle.hxx>
|
||||||
#include <Geom_Surface.hxx>
|
#include <Geom_Surface.hxx>
|
||||||
#include <Geom_Plane.hxx>
|
#include <Geom_Plane.hxx>
|
||||||
@ -1021,6 +1024,65 @@ Standard_Real GEOMUtils::GetMinDistance
|
|||||||
return aResult;
|
return aResult;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
//=======================================================================
|
||||||
|
// function : ProjectPointOnFace()
|
||||||
|
// purpose : Returns the projection (3d point) if found, throws an exception otherwise
|
||||||
|
//=======================================================================
|
||||||
|
gp_Pnt GEOMUtils::ProjectPointOnFace(const gp_Pnt& thePoint,
|
||||||
|
const TopoDS_Shape& theFace,
|
||||||
|
double& theU, double& theV)
|
||||||
|
{
|
||||||
|
if (theFace.IsNull() || theFace.ShapeType() != TopAbs_FACE)
|
||||||
|
Standard_TypeMismatch::Raise
|
||||||
|
("Projection aborted : the target shape is not a face");
|
||||||
|
|
||||||
|
TopoDS_Face aFace = TopoDS::Face(theFace);
|
||||||
|
Handle(Geom_Surface) surface = BRep_Tool::Surface(aFace);
|
||||||
|
double U1, U2, V1, V2;
|
||||||
|
BRepTools::UVBounds(aFace, U1, U2, V1, V2);
|
||||||
|
|
||||||
|
// projector
|
||||||
|
Standard_Real tol = 1.e-4;
|
||||||
|
GeomAPI_ProjectPointOnSurf proj;
|
||||||
|
proj.Init(surface, U1, U2, V1, V2, tol);
|
||||||
|
proj.Perform(thePoint);
|
||||||
|
if (!proj.IsDone())
|
||||||
|
StdFail_NotDone::Raise("Projection aborted : the algorithm failed");
|
||||||
|
int nbPoints = proj.NbPoints();
|
||||||
|
if (nbPoints < 1)
|
||||||
|
Standard_ConstructionError::Raise("Projection aborted : No solution found");
|
||||||
|
proj.LowerDistanceParameters(theU, theV);
|
||||||
|
gp_Pnt2d aProjPnt (theU, theV);
|
||||||
|
|
||||||
|
// classifier
|
||||||
|
BRepClass_FaceClassifier aClsf (aFace, aProjPnt, tol);
|
||||||
|
if (aClsf.State() != TopAbs_IN && aClsf.State() != TopAbs_ON) {
|
||||||
|
bool isSol = false;
|
||||||
|
double minDist = RealLast();
|
||||||
|
for (int i = 1; i <= nbPoints; i++) {
|
||||||
|
Standard_Real Ui, Vi;
|
||||||
|
proj.Parameters(i, Ui, Vi);
|
||||||
|
aProjPnt = gp_Pnt2d(Ui, Vi);
|
||||||
|
aClsf.Perform(aFace, aProjPnt, tol);
|
||||||
|
if (aClsf.State() == TopAbs_IN || aClsf.State() == TopAbs_ON) {
|
||||||
|
isSol = true;
|
||||||
|
double dist = proj.Distance(i);
|
||||||
|
if (dist < minDist) {
|
||||||
|
minDist = dist;
|
||||||
|
theU = Ui;
|
||||||
|
theV = Vi;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (!isSol) {
|
||||||
|
Standard_ConstructionError::Raise("Projection aborted : No solution found");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
gp_Pnt surfPnt = surface->Value(theU, theV);
|
||||||
|
return surfPnt;
|
||||||
|
}
|
||||||
|
|
||||||
//=======================================================================
|
//=======================================================================
|
||||||
// function : ConvertClickToPoint()
|
// function : ConvertClickToPoint()
|
||||||
// purpose : Returns the point clicked in 3D view
|
// purpose : Returns the point clicked in 3D view
|
||||||
|
@ -215,6 +215,19 @@ namespace GEOMUtils
|
|||||||
const TopoDS_Shape& theShape2,
|
const TopoDS_Shape& theShape2,
|
||||||
gp_Pnt& thePnt1, gp_Pnt& thePnt2);
|
gp_Pnt& thePnt1, gp_Pnt& thePnt2);
|
||||||
|
|
||||||
|
/*!
|
||||||
|
* \brief Computes normal projection of \a thePoint to \a theFace.
|
||||||
|
*
|
||||||
|
* \param thePoint the 3d point
|
||||||
|
* \param theFace the face shape
|
||||||
|
* \param theU the output U parameter of the point on the face
|
||||||
|
* \param theV the output V parameter of the point on the face
|
||||||
|
* \retval the projection (3d point) if found, throws an exception otherwise
|
||||||
|
*/
|
||||||
|
Standard_EXPORT gp_Pnt ProjectPointOnFace(const gp_Pnt& thePoint,
|
||||||
|
const TopoDS_Shape& theFace,
|
||||||
|
double& theU, double& theV);
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
* \brief Returns the point clicked in 3D view.
|
* \brief Returns the point clicked in 3D view.
|
||||||
*
|
*
|
||||||
|
@ -595,5 +595,17 @@ def TestAll (geompy, math):
|
|||||||
geompy.MakeExtraction(Box, [18], "Ext_no_edge")
|
geompy.MakeExtraction(Box, [18], "Ext_no_edge")
|
||||||
geompy.MakeExtraction(Box, [16], "Ext_no_vertex")
|
geompy.MakeExtraction(Box, [16], "Ext_no_vertex")
|
||||||
|
|
||||||
|
# CurvatureOnFace
|
||||||
|
Cylinder_1 = geompy.MakeCylinderRH(100, 50, 'Cylinder_r100_h150')
|
||||||
|
[Face_1,Face_2,Face_3] = geompy.ExtractShapes(Cylinder_1, geompy.ShapeType["FACE"], True, "Face")
|
||||||
|
curvature_1 = geompy.CurvatureOnFace(Face_2, px, vy, 'curvature_cyl_px_vy')
|
||||||
|
assert(abs(geompy.BasicProperties(curvature_1)[0] - 100) < 1e-07)
|
||||||
|
isExcept = False
|
||||||
|
try:
|
||||||
|
geompy.CurvatureOnFace(Face_2, px, vz)
|
||||||
|
except:
|
||||||
|
isExcept = True
|
||||||
|
assert(geompy.MeasuOp.GetErrorCode() == "Curvature radius is infinite")
|
||||||
|
assert(isExcept)
|
||||||
|
|
||||||
print("DONE")
|
print("DONE")
|
||||||
|
@ -11172,7 +11172,7 @@ class geomBuilder(GEOM._objref_GEOM_Gen):
|
|||||||
return aSurf
|
return aSurf
|
||||||
## @}
|
## @}
|
||||||
|
|
||||||
## Measure curvature of surface in the given point along the given direction.
|
## Measure curvature radius of surface in the given point along the given direction.
|
||||||
# @param theSurf the given face.
|
# @param theSurf the given face.
|
||||||
# @param thePoint given point.
|
# @param thePoint given point.
|
||||||
# @param theDirection given direction.
|
# @param theDirection given direction.
|
||||||
@ -11185,13 +11185,15 @@ class geomBuilder(GEOM._objref_GEOM_Gen):
|
|||||||
# in the given point in case of positive curvature value
|
# in the given point in case of positive curvature value
|
||||||
# and opposite to the normal in case of negative curvature.
|
# and opposite to the normal in case of negative curvature.
|
||||||
# The normal of the returned vector is equal to the
|
# The normal of the returned vector is equal to the
|
||||||
# absolute value of the curvature.
|
# absolute value of the curvature radius.
|
||||||
|
# Null shape is returned in case of infinite radius
|
||||||
|
# (zero curvature), for example, in case of flat face.
|
||||||
#
|
#
|
||||||
## @ref swig_todo "Example"
|
## @ref swig_CurvatureOnFace "Example"
|
||||||
@ManageTransactions("MeasuOp")
|
@ManageTransactions("MeasuOp")
|
||||||
def CurvatureOnFace(self, theSurf, thePoint, theDirection, theName=None):
|
def CurvatureOnFace(self, theSurf, thePoint, theDirection, theName=None):
|
||||||
"""
|
"""
|
||||||
Measure curvature of surface in the given point along the given direction.
|
Measure curvature radius of surface in the given point along the given direction.
|
||||||
|
|
||||||
Parameters:
|
Parameters:
|
||||||
theSurf the given face.
|
theSurf the given face.
|
||||||
@ -11207,14 +11209,17 @@ class geomBuilder(GEOM._objref_GEOM_Gen):
|
|||||||
in the given point in case of positive curvature value
|
in the given point in case of positive curvature value
|
||||||
and opposite to the normal in case of negative curvature.
|
and opposite to the normal in case of negative curvature.
|
||||||
The normal of the returned vector is equal to the
|
The normal of the returned vector is equal to the
|
||||||
absolute value of the curvature.
|
absolute value of the curvature radius.
|
||||||
|
Null shape is returned in case of infinite radius
|
||||||
|
(zero curvature), for example, in case of flat face.
|
||||||
|
|
||||||
Example of usage:
|
Example of usage:
|
||||||
curvature_1 = geompy.CurvatureOnFace(Face_1, Vertex_1, OX)
|
curvature_1 = geompy.CurvatureOnFace(Face_1, Vertex_1, OX)
|
||||||
"""
|
"""
|
||||||
aVec = self.MeasuOp.SurfaceCurvatureByPointAndDirection(theSurf,thePoint,theDirection)
|
aVec = self.MeasuOp.SurfaceCurvatureByPointAndDirection(theSurf,thePoint,theDirection)
|
||||||
RaiseIfFailed("CurvatureOnFace", self.MeasuOp)
|
if self.MeasuOp.GetErrorCode() != "ZERO_CURVATURE":
|
||||||
self._autoPublish(aVec, theName, "curvature")
|
RaiseIfFailed("CurvatureOnFace", self.MeasuOp)
|
||||||
|
self._autoPublish(aVec, theName, "curvature")
|
||||||
return aVec
|
return aVec
|
||||||
|
|
||||||
## Get min and max tolerances of sub-shapes of theShape
|
## Get min and max tolerances of sub-shapes of theShape
|
||||||
|
Loading…
Reference in New Issue
Block a user