mirror of
https://git.dev.opencascade.org/repos/occt.git
synced 2025-04-04 18:06:22 +03:00
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.
184 lines
4.2 KiB
C++
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;
|
|
}
|
|
|
|
|