mirror of
https://git.salome-platform.org/gitpub/modules/geom.git
synced 2025-01-14 10:40:35 +05:00
Additional fix for the '23253: [CEA 1783] The length given by basic properties on a partition of faces is not correct' issue.
This commit is contained in:
parent
ec168c32f8
commit
5d831ce592
@ -988,17 +988,17 @@ void GEOMImpl_IMeasureOperations::GetBasicProperties (Handle(GEOM_Object) theSha
|
|||||||
Standard_Real anEps = theTolerance >= 0 ? theTolerance : 1.e-6;
|
Standard_Real anEps = theTolerance >= 0 ? theTolerance : 1.e-6;
|
||||||
try {
|
try {
|
||||||
OCC_CATCH_SIGNALS;
|
OCC_CATCH_SIGNALS;
|
||||||
BRepGProp::LinearProperties(aShape, LProps);
|
BRepGProp::LinearProperties(aShape, LProps, Standard_True);
|
||||||
theLength = LProps.Mass();
|
theLength = LProps.Mass();
|
||||||
|
|
||||||
BRepGProp::SurfaceProperties(aShape, SProps, anEps);
|
BRepGProp::SurfaceProperties(aShape, SProps, anEps, Standard_True);
|
||||||
theSurfArea = SProps.Mass();
|
theSurfArea = SProps.Mass();
|
||||||
|
|
||||||
theVolume = 0.0;
|
theVolume = 0.0;
|
||||||
if (aShape.ShapeType() < TopAbs_SHELL) {
|
if (aShape.ShapeType() < TopAbs_SHELL) {
|
||||||
for (TopExp_Explorer Exp (aShape, TopAbs_SOLID); Exp.More(); Exp.Next()) {
|
for (TopExp_Explorer Exp (aShape, TopAbs_SOLID); Exp.More(); Exp.Next()) {
|
||||||
GProp_GProps VProps;
|
GProp_GProps VProps;
|
||||||
BRepGProp::VolumeProperties(Exp.Current(), VProps, anEps);
|
BRepGProp::VolumeProperties(Exp.Current(), VProps, anEps, Standard_True);
|
||||||
theVolume += VProps.Mass();
|
theVolume += VProps.Mass();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -1045,12 +1045,12 @@ void GEOMImpl_IMeasureOperations::GetInertia
|
|||||||
if (aShape.ShapeType() == TopAbs_VERTEX ||
|
if (aShape.ShapeType() == TopAbs_VERTEX ||
|
||||||
aShape.ShapeType() == TopAbs_EDGE ||
|
aShape.ShapeType() == TopAbs_EDGE ||
|
||||||
aShape.ShapeType() == TopAbs_WIRE) {
|
aShape.ShapeType() == TopAbs_WIRE) {
|
||||||
BRepGProp::LinearProperties(aShape, System);
|
BRepGProp::LinearProperties(aShape, System, Standard_True);
|
||||||
} else if (aShape.ShapeType() == TopAbs_FACE ||
|
} else if (aShape.ShapeType() == TopAbs_FACE ||
|
||||||
aShape.ShapeType() == TopAbs_SHELL) {
|
aShape.ShapeType() == TopAbs_SHELL) {
|
||||||
BRepGProp::SurfaceProperties(aShape, System);
|
BRepGProp::SurfaceProperties(aShape, System, Standard_True);
|
||||||
} else {
|
} else {
|
||||||
BRepGProp::VolumeProperties(aShape, System);
|
BRepGProp::VolumeProperties(aShape, System, Standard_True);
|
||||||
}
|
}
|
||||||
gp_Mat I = System.MatrixOfInertia();
|
gp_Mat I = System.MatrixOfInertia();
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user