mirror of
https://git.salome-platform.org/gitpub/modules/geom.git
synced 2024-11-11 16:19:17 +05:00
Merge branch 'master' into V7_5_BR
This commit is contained in:
commit
b50d958f35
@ -212,6 +212,10 @@ Standard_Integer GEOMImpl_ShapeDriver::Execute(TFunction_Logbook& log) const
|
||||
}
|
||||
}
|
||||
|
||||
if (aSeqEdgesIn->IsEmpty()) {
|
||||
Standard_ConstructionError::Raise("No edges given");
|
||||
}
|
||||
|
||||
// 2. Connect edges to wires of maximum length
|
||||
Handle(TopTools_HSequenceOfShape) aSeqWiresOut;
|
||||
ShapeAnalysis_FreeBounds::ConnectEdgesToWires(aSeqEdgesIn, Precision::Confusion(),
|
||||
@ -649,6 +653,7 @@ TopoDS_Edge GEOMImpl_ShapeDriver::MakeEdgeFromWire(const TopoDS_Shape& aWire,
|
||||
TColStd_SequenceOfReal TolSeq;
|
||||
GeomAbs_CurveType CurType;
|
||||
TopoDS_Vertex FirstVertex, LastVertex;
|
||||
Standard_Real aPntShiftDist = 0.;
|
||||
|
||||
BRepTools_WireExplorer wexp(theWire) ;
|
||||
for (; wexp.More(); wexp.Next())
|
||||
@ -726,6 +731,18 @@ TopoDS_Edge GEOMImpl_ShapeDriver::MakeEdgeFromWire(const TopoDS_Shape& aWire,
|
||||
gp_Pnt P2 = ElCLib::Value(lpar, aLine);
|
||||
NewFpar = ElCLib::Parameter(PrevLine, P1);
|
||||
NewLpar = ElCLib::Parameter(PrevLine, P2);
|
||||
|
||||
// Compute shift
|
||||
if (ConnectByOrigin == TopAbs_FORWARD) {
|
||||
gp_Pnt aNewP2 = ElCLib::Value(NewLpar, PrevLine);
|
||||
|
||||
aPntShiftDist += P2.Distance(aNewP2);
|
||||
} else {
|
||||
gp_Pnt aNewP1 = ElCLib::Value(NewFpar, PrevLine);
|
||||
|
||||
aPntShiftDist += P1.Distance(aNewP1);
|
||||
}
|
||||
|
||||
if (NewLpar < NewFpar)
|
||||
{
|
||||
Standard_Real MemNewFpar = NewFpar;
|
||||
@ -745,6 +762,8 @@ TopoDS_Edge GEOMImpl_ShapeDriver::MakeEdgeFromWire(const TopoDS_Shape& aWire,
|
||||
Abs(aCircle.Radius() - PrevCircle.Radius()) <= LinTol &&
|
||||
aCircle.Axis().IsParallel(PrevCircle.Axis(), AngTol))
|
||||
{
|
||||
const Standard_Boolean isFwd = ConnectByOrigin == TopAbs_FORWARD;
|
||||
|
||||
if (aCircle.Axis().Direction() * PrevCircle.Axis().Direction() < 0.)
|
||||
{
|
||||
Standard_Real memfpar = fpar;
|
||||
@ -756,6 +775,18 @@ TopoDS_Edge GEOMImpl_ShapeDriver::MakeEdgeFromWire(const TopoDS_Shape& aWire,
|
||||
gp_Pnt P2 = ElCLib::Value(lpar, aCircle);
|
||||
NewFpar = ElCLib::Parameter(PrevCircle, P1);
|
||||
NewLpar = ElCLib::Parameter(PrevCircle, P2);
|
||||
|
||||
// Compute shift
|
||||
if (isFwd) {
|
||||
gp_Pnt aNewP2 = ElCLib::Value(NewLpar, PrevCircle);
|
||||
|
||||
aPntShiftDist += P2.Distance(aNewP2);
|
||||
} else {
|
||||
gp_Pnt aNewP1 = ElCLib::Value(NewFpar, PrevCircle);
|
||||
|
||||
aPntShiftDist += P1.Distance(aNewP1);
|
||||
}
|
||||
|
||||
if (NewLpar < NewFpar)
|
||||
NewLpar += 2.*M_PI;
|
||||
//Standard_Real MemNewFpar = NewFpar, MemNewLpar = NewLpar;
|
||||
@ -781,6 +812,8 @@ TopoDS_Edge GEOMImpl_ShapeDriver::MakeEdgeFromWire(const TopoDS_Shape& aWire,
|
||||
Abs(anEllipse.MinorRadius() - PrevEllipse.MinorRadius()) <= LinTol &&
|
||||
anEllipse.Axis().IsParallel(PrevEllipse.Axis(), AngTol))
|
||||
{
|
||||
const Standard_Boolean isFwd = ConnectByOrigin == TopAbs_FORWARD;
|
||||
|
||||
if (anEllipse.Axis().Direction() * PrevEllipse.Axis().Direction() < 0.)
|
||||
{
|
||||
Standard_Real memfpar = fpar;
|
||||
@ -792,6 +825,18 @@ TopoDS_Edge GEOMImpl_ShapeDriver::MakeEdgeFromWire(const TopoDS_Shape& aWire,
|
||||
gp_Pnt P2 = ElCLib::Value(lpar, anEllipse);
|
||||
NewFpar = ElCLib::Parameter(PrevEllipse, P1);
|
||||
NewLpar = ElCLib::Parameter(PrevEllipse, P2);
|
||||
|
||||
// Compute shift
|
||||
if (isFwd) {
|
||||
gp_Pnt aNewP2 = ElCLib::Value(NewLpar, PrevEllipse);
|
||||
|
||||
aPntShiftDist += P2.Distance(aNewP2);
|
||||
} else {
|
||||
gp_Pnt aNewP1 = ElCLib::Value(NewFpar, PrevEllipse);
|
||||
|
||||
aPntShiftDist += P1.Distance(aNewP1);
|
||||
}
|
||||
|
||||
if (NewLpar < NewFpar)
|
||||
NewLpar += 2.*M_PI;
|
||||
if (ConnectByOrigin == TopAbs_FORWARD)
|
||||
@ -820,6 +865,18 @@ TopoDS_Edge GEOMImpl_ShapeDriver::MakeEdgeFromWire(const TopoDS_Shape& aWire,
|
||||
gp_Pnt P2 = ElCLib::Value(lpar, aHypr);
|
||||
NewFpar = ElCLib::Parameter(PrevHypr, P1);
|
||||
NewLpar = ElCLib::Parameter(PrevHypr, P2);
|
||||
|
||||
// Compute shift
|
||||
if (ConnectByOrigin == TopAbs_FORWARD) {
|
||||
gp_Pnt aNewP2 = ElCLib::Value(NewLpar, PrevHypr);
|
||||
|
||||
aPntShiftDist += P2.Distance(aNewP2);
|
||||
} else {
|
||||
gp_Pnt aNewP1 = ElCLib::Value(NewFpar, PrevHypr);
|
||||
|
||||
aPntShiftDist += P1.Distance(aNewP1);
|
||||
}
|
||||
|
||||
if (NewLpar < NewFpar)
|
||||
{
|
||||
Standard_Real MemNewFpar = NewFpar;
|
||||
@ -844,6 +901,18 @@ TopoDS_Edge GEOMImpl_ShapeDriver::MakeEdgeFromWire(const TopoDS_Shape& aWire,
|
||||
gp_Pnt P2 = ElCLib::Value(lpar, aParab);
|
||||
NewFpar = ElCLib::Parameter(PrevParab, P1);
|
||||
NewLpar = ElCLib::Parameter(PrevParab, P2);
|
||||
|
||||
// Compute shift
|
||||
if (ConnectByOrigin == TopAbs_FORWARD) {
|
||||
gp_Pnt aNewP2 = ElCLib::Value(NewLpar, PrevParab);
|
||||
|
||||
aPntShiftDist += P2.Distance(aNewP2);
|
||||
} else {
|
||||
gp_Pnt aNewP1 = ElCLib::Value(NewFpar, PrevParab);
|
||||
|
||||
aPntShiftDist += P1.Distance(aNewP1);
|
||||
}
|
||||
|
||||
if (NewLpar < NewFpar)
|
||||
{
|
||||
Standard_Real MemNewFpar = NewFpar;
|
||||
@ -873,14 +942,15 @@ TopoDS_Edge GEOMImpl_ShapeDriver::MakeEdgeFromWire(const TopoDS_Shape& aWire,
|
||||
LocSeq.Append(aLocShape);
|
||||
FparSeq.Append(fpar);
|
||||
LparSeq.Append(lpar);
|
||||
TolSeq.Append(BRep_Tool::Tolerance(CurVertex));
|
||||
TolSeq.Append(aPntShiftDist + BRep_Tool::Tolerance(CurVertex));
|
||||
aPntShiftDist = 0.;
|
||||
CurType = aType;
|
||||
}
|
||||
} // end of else (CurveSeq.IsEmpty()) -> not first time
|
||||
} // end for (; wexp.More(); wexp.Next())
|
||||
|
||||
LastVertex = wexp.CurrentVertex();
|
||||
TolSeq.Append(BRep_Tool::Tolerance(LastVertex));
|
||||
TolSeq.Append(aPntShiftDist + BRep_Tool::Tolerance(LastVertex));
|
||||
|
||||
FirstVertex.Orientation(TopAbs_FORWARD);
|
||||
LastVertex.Orientation(TopAbs_REVERSED);
|
||||
|
Loading…
Reference in New Issue
Block a user