OpenCAX/entry/src/main/cpp/include/opencascade/ElSLib.lxx
2026-02-19 19:05:41 +08:00

393 lines
13 KiB
Plaintext

// Created by: Jean-Claude Vauthier
// Copyright (c) 1995-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 "gp_Pln.hxx"
#include "gp_Sphere.hxx"
#include "gp_Torus.hxx"
#include "gp_Cylinder.hxx"
#include "gp_Cone.hxx"
#include "gp_Ax3.hxx"
inline gp_Pnt ElSLib::Value(const Standard_Real U, const Standard_Real V, const gp_Pln& Pl)
{
return ElSLib::PlaneValue(U, V, Pl.Position());
}
inline gp_Pnt ElSLib::Value(const Standard_Real U, const Standard_Real V, const gp_Cone& C)
{
return ElSLib::ConeValue(U, V, C.Position(), C.RefRadius(), C.SemiAngle());
}
inline gp_Pnt ElSLib::Value(const Standard_Real U, const Standard_Real V, const gp_Cylinder& C)
{
return ElSLib::CylinderValue(U, V, C.Position(), C.Radius());
}
inline gp_Pnt ElSLib::Value(const Standard_Real U, const Standard_Real V, const gp_Sphere& S)
{
return ElSLib::SphereValue(U, V, S.Position(), S.Radius());
}
inline gp_Pnt ElSLib::Value(const Standard_Real U, const Standard_Real V, const gp_Torus& T)
{
return ElSLib::TorusValue(U, V, T.Position(), T.MajorRadius(), T.MinorRadius());
}
inline gp_Vec ElSLib::DN(const Standard_Real U,
const Standard_Real V,
const gp_Pln& Pl,
const Standard_Integer Nu,
const Standard_Integer Nv)
{
return ElSLib::PlaneDN(U, V, Pl.Position(), Nu, Nv);
}
inline gp_Vec ElSLib::DN(const Standard_Real U,
const Standard_Real V,
const gp_Cone& C,
const Standard_Integer Nu,
const Standard_Integer Nv)
{
return ElSLib::ConeDN(U, V, C.Position(), C.RefRadius(), C.SemiAngle(), Nu, Nv);
}
inline gp_Vec ElSLib::DN(const Standard_Real U,
const Standard_Real V,
const gp_Cylinder& C,
const Standard_Integer Nu,
const Standard_Integer Nv)
{
return ElSLib::CylinderDN(U, V, C.Position(), C.Radius(), Nu, Nv);
}
inline gp_Vec ElSLib::DN(const Standard_Real U,
const Standard_Real V,
const gp_Sphere& S,
const Standard_Integer Nu,
const Standard_Integer Nv)
{
return ElSLib::SphereDN(U, V, S.Position(), S.Radius(), Nu, Nv);
}
inline gp_Vec ElSLib::DN(const Standard_Real U,
const Standard_Real V,
const gp_Torus& T,
const Standard_Integer Nu,
const Standard_Integer Nv)
{
return ElSLib::TorusDN(U, V, T.Position(), T.MajorRadius(), T.MinorRadius(), Nu, Nv);
}
inline void ElSLib::D0(const Standard_Real U, const Standard_Real V, const gp_Pln& Pl, gp_Pnt& P)
{
ElSLib::PlaneD0(U, V, Pl.Position(), P);
}
inline void ElSLib::D0(const Standard_Real U, const Standard_Real V, const gp_Cone& C, gp_Pnt& P)
{
ElSLib::ConeD0(U, V, C.Position(), C.RefRadius(), C.SemiAngle(), P);
}
inline void ElSLib::D0(const Standard_Real U,
const Standard_Real V,
const gp_Cylinder& C,
gp_Pnt& P)
{
ElSLib::CylinderD0(U, V, C.Position(), C.Radius(), P);
}
inline void ElSLib::D0(const Standard_Real U, const Standard_Real V, const gp_Sphere& S, gp_Pnt& P)
{
ElSLib::SphereD0(U, V, S.Position(), S.Radius(), P);
}
inline void ElSLib::D0(const Standard_Real U, const Standard_Real V, const gp_Torus& T, gp_Pnt& P)
{
ElSLib::TorusD0(U, V, T.Position(), T.MajorRadius(), T.MinorRadius(), P);
}
inline void ElSLib::D1(const Standard_Real U,
const Standard_Real V,
const gp_Pln& Pl,
gp_Pnt& P,
gp_Vec& Vu,
gp_Vec& Vv)
{
ElSLib::PlaneD1(U, V, Pl.Position(), P, Vu, Vv);
}
inline void ElSLib::D1(const Standard_Real U,
const Standard_Real V,
const gp_Cone& C,
gp_Pnt& P,
gp_Vec& Vu,
gp_Vec& Vv)
{
ElSLib::ConeD1(U, V, C.Position(), C.RefRadius(), C.SemiAngle(), P, Vu, Vv);
}
inline void ElSLib::D1(const Standard_Real U,
const Standard_Real V,
const gp_Cylinder& C,
gp_Pnt& P,
gp_Vec& Vu,
gp_Vec& Vv)
{
ElSLib::CylinderD1(U, V, C.Position(), C.Radius(), P, Vu, Vv);
}
inline void ElSLib::D1(const Standard_Real U,
const Standard_Real V,
const gp_Sphere& S,
gp_Pnt& P,
gp_Vec& Vu,
gp_Vec& Vv)
{
ElSLib::SphereD1(U, V, S.Position(), S.Radius(), P, Vu, Vv);
}
inline void ElSLib::D1(const Standard_Real U,
const Standard_Real V,
const gp_Torus& T,
gp_Pnt& P,
gp_Vec& Vu,
gp_Vec& Vv)
{
ElSLib::TorusD1(U, V, T.Position(), T.MajorRadius(), T.MinorRadius(), P, Vu, Vv);
}
inline void ElSLib::D2(const Standard_Real U,
const Standard_Real V,
const gp_Cone& C,
gp_Pnt& P,
gp_Vec& Vu,
gp_Vec& Vv,
gp_Vec& Vuu,
gp_Vec& Vvv,
gp_Vec& Vuv)
{
ElSLib::ConeD2(U, V, C.Position(), C.RefRadius(), C.SemiAngle(), P, Vu, Vv, Vuu, Vvv, Vuv);
}
inline void ElSLib::D2(const Standard_Real U,
const Standard_Real V,
const gp_Cylinder& C,
gp_Pnt& P,
gp_Vec& Vu,
gp_Vec& Vv,
gp_Vec& Vuu,
gp_Vec& Vvv,
gp_Vec& Vuv)
{
ElSLib::CylinderD2(U, V, C.Position(), C.Radius(), P, Vu, Vv, Vuu, Vvv, Vuv);
}
inline void ElSLib::D2(const Standard_Real U,
const Standard_Real V,
const gp_Sphere& S,
gp_Pnt& P,
gp_Vec& Vu,
gp_Vec& Vv,
gp_Vec& Vuu,
gp_Vec& Vvv,
gp_Vec& Vuv)
{
ElSLib::SphereD2(U, V, S.Position(), S.Radius(), P, Vu, Vv, Vuu, Vvv, Vuv);
}
inline void ElSLib::D2(const Standard_Real U,
const Standard_Real V,
const gp_Torus& T,
gp_Pnt& P,
gp_Vec& Vu,
gp_Vec& Vv,
gp_Vec& Vuu,
gp_Vec& Vvv,
gp_Vec& Vuv)
{
ElSLib::TorusD2(U, V, T.Position(), T.MajorRadius(), T.MinorRadius(), P, Vu, Vv, Vuu, Vvv, Vuv);
}
inline void ElSLib::D3(const Standard_Real U,
const Standard_Real V,
const gp_Cone& C,
gp_Pnt& P,
gp_Vec& Vu,
gp_Vec& Vv,
gp_Vec& Vuu,
gp_Vec& Vvv,
gp_Vec& Vuv,
gp_Vec& Vuuu,
gp_Vec& Vvvv,
gp_Vec& Vuuv,
gp_Vec& Vuvv)
{
ElSLib::ConeD3(U,
V,
C.Position(),
C.RefRadius(),
C.SemiAngle(),
P,
Vu,
Vv,
Vuu,
Vvv,
Vuv,
Vuuu,
Vvvv,
Vuuv,
Vuvv);
}
inline void ElSLib::D3(const Standard_Real U,
const Standard_Real V,
const gp_Cylinder& C,
gp_Pnt& P,
gp_Vec& Vu,
gp_Vec& Vv,
gp_Vec& Vuu,
gp_Vec& Vvv,
gp_Vec& Vuv,
gp_Vec& Vuuu,
gp_Vec& Vvvv,
gp_Vec& Vuuv,
gp_Vec& Vuvv)
{
ElSLib::
CylinderD3(U, V, C.Position(), C.Radius(), P, Vu, Vv, Vuu, Vvv, Vuv, Vuuu, Vvvv, Vuuv, Vuvv);
}
inline void ElSLib::D3(const Standard_Real U,
const Standard_Real V,
const gp_Sphere& S,
gp_Pnt& P,
gp_Vec& Vu,
gp_Vec& Vv,
gp_Vec& Vuu,
gp_Vec& Vvv,
gp_Vec& Vuv,
gp_Vec& Vuuu,
gp_Vec& Vvvv,
gp_Vec& Vuuv,
gp_Vec& Vuvv)
{
ElSLib::
SphereD3(U, V, S.Position(), S.Radius(), P, Vu, Vv, Vuu, Vvv, Vuv, Vuuu, Vvvv, Vuuv, Vuvv);
}
inline void ElSLib::D3(const Standard_Real U,
const Standard_Real V,
const gp_Torus& T,
gp_Pnt& P,
gp_Vec& Vu,
gp_Vec& Vv,
gp_Vec& Vuu,
gp_Vec& Vvv,
gp_Vec& Vuv,
gp_Vec& Vuuu,
gp_Vec& Vvvv,
gp_Vec& Vuuv,
gp_Vec& Vuvv)
{
ElSLib::TorusD3(U,
V,
T.Position(),
T.MajorRadius(),
T.MinorRadius(),
P,
Vu,
Vv,
Vuu,
Vvv,
Vuv,
Vuuu,
Vvvv,
Vuuv,
Vuvv);
}
inline void ElSLib::Parameters(const gp_Pln& Pl,
const gp_Pnt& P,
Standard_Real& U,
Standard_Real& V)
{
ElSLib::PlaneParameters(Pl.Position(), P, U, V);
}
inline void ElSLib::Parameters(const gp_Cylinder& C,
const gp_Pnt& P,
Standard_Real& U,
Standard_Real& V)
{
ElSLib::CylinderParameters(C.Position(), C.Radius(), P, U, V);
}
inline void ElSLib::Parameters(const gp_Cone& C,
const gp_Pnt& P,
Standard_Real& U,
Standard_Real& V)
{
ElSLib::ConeParameters(C.Position(), C.RefRadius(), C.SemiAngle(), P, U, V);
}
inline void ElSLib::Parameters(const gp_Sphere& S,
const gp_Pnt& P,
Standard_Real& U,
Standard_Real& V)
{
ElSLib::SphereParameters(S.Position(), S.Radius(), P, U, V);
}
inline void ElSLib::Parameters(const gp_Torus& T,
const gp_Pnt& P,
Standard_Real& U,
Standard_Real& V)
{
ElSLib::TorusParameters(T.Position(), T.MajorRadius(), T.MinorRadius(), P, U, V);
}