mirror of
https://github.com/Open-Cascade-SAS/OCCT.git
synced 2026-05-15 05:28:47 +08:00
Update empty method guards to new style with regex (see PR). Used clang-format 18.1.8. New actions to validate code formatting is added. Update .clang-format with disabling of include sorting. It is temporary changes, then include will be sorted. Apply formatting for /src and /tools folder. The files with .hxx,.cxx,.lxx,.h,.pxx,.hpp,*.cpp extensions.
147 lines
4.8 KiB
C++
147 lines
4.8 KiB
C++
// Copyright (c) 1999-2014 OPEN CASCADE SAS
|
|
//
|
|
// This file is part of Open CASCADE Technology software library.
|
|
//
|
|
// This library is free software; you can redistribute it and/or modify it under
|
|
// the terms of the GNU Lesser General Public License version 2.1 as published
|
|
// by the Free Software Foundation, with special exception defined in the file
|
|
// OCCT_LGPL_EXCEPTION.txt. Consult the file LICENSE_LGPL_21.txt included in OCCT
|
|
// distribution for complete text of the license and disclaimer of any warranty.
|
|
//
|
|
// Alternatively, this file may be used under the terms of Open CASCADE
|
|
// commercial license or contractual agreement.
|
|
|
|
#include <BRep_Tool.hxx>
|
|
#include <Geom2d_Curve.hxx>
|
|
#include <Geom_Curve.hxx>
|
|
#include <gp.hxx>
|
|
#include <ShapeAnalysis_Edge.hxx>
|
|
#include <ShapeAnalysis_TransferParameters.hxx>
|
|
#include <ShapeBuild_Edge.hxx>
|
|
#include <Standard_Type.hxx>
|
|
#include <TopoDS_Edge.hxx>
|
|
#include <TopoDS_Face.hxx>
|
|
|
|
IMPLEMENT_STANDARD_RTTIEXT(ShapeAnalysis_TransferParameters, Standard_Transient)
|
|
|
|
//=================================================================================================
|
|
|
|
ShapeAnalysis_TransferParameters::ShapeAnalysis_TransferParameters()
|
|
{
|
|
myScale = 1.;
|
|
myShift = 0.;
|
|
}
|
|
|
|
//=================================================================================================
|
|
|
|
ShapeAnalysis_TransferParameters::ShapeAnalysis_TransferParameters(const TopoDS_Edge& E,
|
|
const TopoDS_Face& F)
|
|
{
|
|
Init(E, F);
|
|
}
|
|
|
|
//=================================================================================================
|
|
|
|
void ShapeAnalysis_TransferParameters::Init(const TopoDS_Edge& E, const TopoDS_Face& F)
|
|
{
|
|
myScale = 1.;
|
|
myShift = 0.;
|
|
Standard_Real l, f, l2d = 0.0, f2d = 0.0;
|
|
TopLoc_Location L;
|
|
myEdge = E;
|
|
ShapeAnalysis_Edge sae;
|
|
Handle(Geom_Curve) curve3d; // = BRep_Tool::Curve (E,f,l);
|
|
sae.Curve3d(E, curve3d, f, l, Standard_False);
|
|
myFirst = f;
|
|
myLast = l;
|
|
Handle(Geom2d_Curve) curve2d; // = BRep_Tool::CurveOnSurface (E, F, f2d,l2d);
|
|
// ShapeAnalysis_Edge sae;
|
|
if (!F.IsNull())
|
|
{ // process free edges
|
|
sae.PCurve(E, F, curve2d, f2d, l2d, Standard_False);
|
|
}
|
|
myFirst2d = f2d;
|
|
myLast2d = l2d;
|
|
myFace = F;
|
|
if (curve3d.IsNull() || curve2d.IsNull())
|
|
return;
|
|
|
|
Standard_Real ln2d = l2d - f2d;
|
|
Standard_Real ln3d = l - f;
|
|
myScale = (ln3d <= gp::Resolution() ? 1. : ln2d / ln3d);
|
|
myShift = f2d - f * myScale;
|
|
}
|
|
|
|
//=================================================================================================
|
|
|
|
void ShapeAnalysis_TransferParameters::SetMaxTolerance(const Standard_Real maxtol)
|
|
{
|
|
myMaxTolerance = maxtol;
|
|
}
|
|
|
|
//=================================================================================================
|
|
|
|
Handle(TColStd_HSequenceOfReal) ShapeAnalysis_TransferParameters::Perform(
|
|
const Handle(TColStd_HSequenceOfReal)& Params,
|
|
const Standard_Boolean To2d)
|
|
{
|
|
Handle(TColStd_HSequenceOfReal) res = new TColStd_HSequenceOfReal;
|
|
for (Standard_Integer i = 1; i <= Params->Length(); i++)
|
|
res->Append(Perform(Params->Value(i), To2d));
|
|
return res;
|
|
}
|
|
|
|
//=================================================================================================
|
|
|
|
Standard_Real ShapeAnalysis_TransferParameters::Perform(const Standard_Real Param,
|
|
const Standard_Boolean To2d)
|
|
{
|
|
Standard_Real NewParam;
|
|
if (To2d)
|
|
NewParam = myShift + Param * myScale;
|
|
else
|
|
NewParam = -myShift / myScale + Param * 1. / myScale;
|
|
return NewParam;
|
|
}
|
|
|
|
//=================================================================================================
|
|
|
|
void ShapeAnalysis_TransferParameters::TransferRange(TopoDS_Edge& newEdge,
|
|
const Standard_Real prevPar,
|
|
const Standard_Real currPar,
|
|
const Standard_Boolean Is2d)
|
|
{
|
|
ShapeBuild_Edge sbe;
|
|
if (Is2d)
|
|
{
|
|
Standard_Real span2d = myLast2d - myFirst2d;
|
|
Standard_Real tmp1, tmp2;
|
|
if (prevPar > currPar)
|
|
{
|
|
tmp1 = currPar;
|
|
tmp2 = prevPar;
|
|
}
|
|
else
|
|
{
|
|
tmp1 = prevPar;
|
|
tmp2 = currPar;
|
|
}
|
|
Standard_Real alpha = (tmp1 - myFirst2d) / span2d;
|
|
Standard_Real beta = (tmp2 - myFirst2d) / span2d;
|
|
sbe.CopyRanges(newEdge, myEdge, alpha, beta);
|
|
}
|
|
else
|
|
{
|
|
Standard_Real alpha = (prevPar - myFirst) / (myLast - myFirst);
|
|
Standard_Real beta = (currPar - myFirst) / (myLast - myFirst);
|
|
sbe.CopyRanges(newEdge, myEdge, alpha, beta);
|
|
}
|
|
}
|
|
|
|
//=================================================================================================
|
|
|
|
Standard_Boolean ShapeAnalysis_TransferParameters::IsSameRange() const
|
|
{
|
|
return myShift == 0. && myScale == 1.;
|
|
}
|