1
0
mirror of https://git.dev.opencascade.org/repos/occt.git synced 2025-04-04 18:06:22 +03:00
occt/src/GeomFill/GeomFill_SnglrFunc.cxx
ifv f6b08ecf71 0028346: Function ProjectOnSegments of ShapeAnalysis_Curve returns only single solution leading to projection result far from optimal
Subdivision of curve parametric interval based on deflection criteria is added for curve type OtherCurve in
Extrema_GExtPC.gxx. Algorithm of subdivision is implemented in Extrema_Curve(2d)Tool.cxx

New Draw command projpcurve for projection of point on CurveOnSurface is added in SWDRAW_ShapeAnalysis.cxx
projpcurve is modified to reflect "start parameter" in usage message and Draw help.
2017-06-01 13:55:22 +03:00

184 lines
4.2 KiB
C++

// Created on: 1998-02-26
// Created by: Roman BORISOV
// Copyright (c) 1998-1999 Matra Datavision
// 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 <Adaptor3d_HCurve.hxx>
#include <GeomFill_SnglrFunc.hxx>
#include <gp_Pnt.hxx>
#include <gp_Vec.hxx>
#include <Precision.hxx>
#include <Standard_DomainError.hxx>
#include <Standard_NotImplemented.hxx>
#include <Standard_OutOfRange.hxx>
GeomFill_SnglrFunc::GeomFill_SnglrFunc(const Handle(Adaptor3d_HCurve)& HC) :
myHCurve(HC), ratio(1)
{
}
void GeomFill_SnglrFunc::SetRatio(const Standard_Real Ratio)
{
ratio = Ratio;
}
Standard_Real GeomFill_SnglrFunc::FirstParameter() const
{
return myHCurve->FirstParameter();
}
Standard_Real GeomFill_SnglrFunc::LastParameter() const
{
return myHCurve->LastParameter();
}
Standard_Integer GeomFill_SnglrFunc::NbIntervals(const GeomAbs_Shape S) const
{
GeomAbs_Shape HCS=GeomAbs_C0;
if (S == GeomAbs_C0)
{
HCS = GeomAbs_C2;
}
else if (S == GeomAbs_C1)
{
HCS = GeomAbs_C3;
}
else if (S >= GeomAbs_C2)
{
HCS = GeomAbs_CN;
}
return myHCurve->NbIntervals(HCS);
}
void GeomFill_SnglrFunc::Intervals(TColStd_Array1OfReal& T,const GeomAbs_Shape S) const
{
GeomAbs_Shape HCS=GeomAbs_C0;
if (S == GeomAbs_C0)
{
HCS = GeomAbs_C2;
}
else if (S == GeomAbs_C1)
{
HCS = GeomAbs_C3;
}
else if (S >= GeomAbs_C2)
{
HCS = GeomAbs_CN;
}
myHCurve->Intervals(T, HCS);
}
Standard_Boolean GeomFill_SnglrFunc::IsPeriodic() const
{
return myHCurve->IsPeriodic();
}
Standard_Real GeomFill_SnglrFunc::Period() const
{
return myHCurve->Period();
}
gp_Pnt GeomFill_SnglrFunc::Value(const Standard_Real U) const
{
gp_Pnt C;
gp_Vec DC, D2C;
myHCurve->D2(U, C, DC, D2C);
DC *= ratio;
return gp_Pnt(DC.Crossed(D2C).XYZ());
}
void GeomFill_SnglrFunc::D0(const Standard_Real U,gp_Pnt& P) const
{
gp_Pnt C;
gp_Vec DC, D2C;
myHCurve->D2(U, C, DC, D2C);
DC *= ratio;
P = gp_Pnt(DC.Crossed(D2C).XYZ());
}
void GeomFill_SnglrFunc::D1(const Standard_Real U,gp_Pnt& P,gp_Vec& V) const
{
gp_Pnt C;
gp_Vec DC, D2C, D3C;
myHCurve->D3(U, C, DC, D2C, D3C);
DC *= ratio;
P = gp_Pnt(DC.Crossed(D2C).XYZ());
V = DC.Crossed(D3C);
}
void GeomFill_SnglrFunc::D2(const Standard_Real U,gp_Pnt& P,gp_Vec& V1,gp_Vec& V2) const
{
gp_Pnt C;
gp_Vec DC, D2C, D3C, D4C;
myHCurve->D3(U, C, DC, D2C, D3C);
P = gp_Pnt(DC.Crossed(D2C).XYZ());
V1 = DC.Crossed(D3C);
D4C = myHCurve->DN(U, 4);
V2 = D2C.Crossed(D3C) + DC.Crossed(D4C);
P.ChangeCoord() *= ratio;
V1 *= ratio;
V2 *= ratio;
}
void GeomFill_SnglrFunc::D3(const Standard_Real U,gp_Pnt& P,gp_Vec& V1,gp_Vec& V2,gp_Vec& V3) const
{
gp_Vec DC, D2C, D3C, D4C, D5C;
myHCurve->D3(U, P, DC, D2C, D3C);
D4C = myHCurve->DN(U, 4);
D5C = myHCurve->DN(U, 5);
P = gp_Pnt(DC.Crossed(D2C).XYZ()).ChangeCoord()*ratio;
V1 = DC.Crossed(D3C)*ratio;
V2 = (D2C.Crossed(D3C) + DC.Crossed(D4C))*ratio;
V3 = (DC.Crossed(D5C) + D2C.Crossed(D4C)*2)*ratio;
}
gp_Vec GeomFill_SnglrFunc::DN(const Standard_Real U,const Standard_Integer N) const
{
Standard_RangeError_Raise_if (N < 1, "Exception: Geom2d_OffsetCurve::DN(). N<1.");
gp_Vec D1C, D2C, D3C;
gp_Pnt C;
switch(N)
{
case 1:
D1(U,C,D1C);
return D1C;
case 2:
D2(U,C,D1C,D2C);
return D2C;
case 3:
D3(U,C,D1C,D2C,D3C);
return D3C;
default:
throw Standard_NotImplemented("Exception: Derivative order is greater than 3. "
"Cannot compute of derivative.");
}
}
Standard_Real GeomFill_SnglrFunc::Resolution(const Standard_Real R3D) const
{
return Precision::Parametric(R3D);
}
GeomAbs_CurveType GeomFill_SnglrFunc::GetType() const
{
return GeomAbs_OtherCurve;
}