X-Git-Url: http://git.salome-platform.org/gitweb/?a=blobdiff_plain;f=src%2FGeomAlgoAPI%2FGeomAlgoAPI_Pipe.cpp;h=819c8d70963bba7aa0da9d4016e3510a580e2c01;hb=fdd802da7683f66ca609cf12b1e11be9642149d6;hp=067a249bd592d27e11cf924b8923f6dcee1b48d2;hpb=aca54238175d75c25fa9b12ade0e274765a1cabd;p=modules%2Fshaper.git diff --git a/src/GeomAlgoAPI/GeomAlgoAPI_Pipe.cpp b/src/GeomAlgoAPI/GeomAlgoAPI_Pipe.cpp index 067a249bd..819c8d709 100644 --- a/src/GeomAlgoAPI/GeomAlgoAPI_Pipe.cpp +++ b/src/GeomAlgoAPI/GeomAlgoAPI_Pipe.cpp @@ -1,4 +1,4 @@ -// Copyright (C) 2014-2019 CEA/DEN, EDF R&D +// Copyright (C) 2014-2020 CEA/DEN, EDF R&D // // This library is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public @@ -35,6 +35,7 @@ #include #include #include +#include #include #include #include @@ -417,6 +418,31 @@ gp_Trsf getPathToBaseTranslation(const TopoDS_Shape& theBase, const TopoDS_Shape if (aDist.IsDone() && aDist.Value() > Precision::Confusion()) { gp_Pnt aPntBase = aDist.PointOnShape1(1); gp_Pnt aPntPath = aDist.PointOnShape2(1); + // get the end point on the path nearest to the found point, + // because the path is almost usually started from the one of the sections + if (!BRep_Tool::IsClosed(thePath)) { + TopoDS_Wire aPathWire = TopoDS::Wire(thePath); + if (!aPathWire.IsNull()) { + TopoDS_Vertex aV1, aV2; + TopExp::Vertices(aPathWire, aV1, aV2); + + gp_Pnt aStart = BRep_Tool::Pnt(aV1); + gp_Pnt anEnd = BRep_Tool::Pnt(aV2); + + // compare 3 distances + double aDistToStart = aPntBase.Distance(aStart); + double aDistToEnd = aPntBase.Distance(anEnd); + double aMinDist = aPntBase.Distance(aPntPath); + + static const double THE_THRESHOLD = 0.01; // threshold for distance ratio + double aDeltaStart = Abs(aDistToStart - aMinDist); + double aDeltaEnd = Abs(aDistToEnd - aMinDist); + if (aDeltaStart < THE_THRESHOLD * aDeltaEnd) + aPntPath = aStart; + else if (aDeltaEnd < THE_THRESHOLD * aDeltaStart) + aPntPath = anEnd; + } + } aTranslation.SetTranslation(aPntPath, aPntBase); }