mirror of
https://git.dev.opencascade.org/repos/occt.git
synced 2025-06-10 11:34:06 +03: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.
239 lines
6.4 KiB
C++
239 lines
6.4 KiB
C++
// Created on: 1993-03-10
|
|
// Created by: JCV
|
|
// Copyright (c) 1993-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 <ElCLib.hxx>
|
|
#include <Geom_Line.hxx>
|
|
#include <gp_Ax1.hxx>
|
|
#include <gp_Dir.hxx>
|
|
#include <gp_Lin.hxx>
|
|
#include <gp_Pnt.hxx>
|
|
#include <gp_Trsf.hxx>
|
|
#include <gp_Vec.hxx>
|
|
#include <gp_XYZ.hxx>
|
|
#include <Precision.hxx>
|
|
#include <Standard_RangeError.hxx>
|
|
#include <Standard_Type.hxx>
|
|
|
|
IMPLEMENT_STANDARD_RTTIEXT(Geom_Line, Geom_Curve)
|
|
|
|
//=================================================================================================
|
|
|
|
Handle(Geom_Geometry) Geom_Line::Copy() const
|
|
{
|
|
|
|
Handle(Geom_Line) L;
|
|
L = new Geom_Line(pos);
|
|
return L;
|
|
}
|
|
|
|
//=================================================================================================
|
|
|
|
Geom_Line::Geom_Line(const gp_Ax1& A)
|
|
: pos(A)
|
|
{
|
|
}
|
|
|
|
//=================================================================================================
|
|
|
|
Geom_Line::Geom_Line(const gp_Lin& L)
|
|
: pos(L.Position())
|
|
{
|
|
}
|
|
|
|
//=================================================================================================
|
|
|
|
Geom_Line::Geom_Line(const gp_Pnt& P, const gp_Dir& V)
|
|
: pos(P, V)
|
|
{
|
|
}
|
|
|
|
//=================================================================================================
|
|
|
|
void Geom_Line::Reverse()
|
|
{
|
|
pos.Reverse();
|
|
}
|
|
|
|
//=================================================================================================
|
|
|
|
Standard_Real Geom_Line::ReversedParameter(const Standard_Real U) const
|
|
{
|
|
return (-U);
|
|
}
|
|
|
|
//=================================================================================================
|
|
|
|
void Geom_Line::SetDirection(const gp_Dir& V)
|
|
{
|
|
pos.SetDirection(V);
|
|
}
|
|
|
|
//=================================================================================================
|
|
|
|
void Geom_Line::SetLin(const gp_Lin& L)
|
|
{
|
|
pos = L.Position();
|
|
}
|
|
|
|
//=================================================================================================
|
|
|
|
void Geom_Line::SetLocation(const gp_Pnt& P)
|
|
{
|
|
pos.SetLocation(P);
|
|
}
|
|
|
|
//=================================================================================================
|
|
|
|
void Geom_Line::SetPosition(const gp_Ax1& A1)
|
|
{
|
|
pos = A1;
|
|
}
|
|
|
|
//=================================================================================================
|
|
|
|
const gp_Ax1& Geom_Line::Position() const
|
|
{
|
|
return pos;
|
|
}
|
|
|
|
//=================================================================================================
|
|
|
|
Standard_Boolean Geom_Line::IsClosed() const
|
|
{
|
|
return Standard_False;
|
|
}
|
|
|
|
//=================================================================================================
|
|
|
|
Standard_Boolean Geom_Line::IsPeriodic() const
|
|
{
|
|
return Standard_False;
|
|
}
|
|
|
|
//=================================================================================================
|
|
|
|
GeomAbs_Shape Geom_Line::Continuity() const
|
|
{
|
|
return GeomAbs_CN;
|
|
}
|
|
|
|
//=================================================================================================
|
|
|
|
Standard_Real Geom_Line::FirstParameter() const
|
|
{
|
|
return -Precision::Infinite();
|
|
}
|
|
|
|
//=================================================================================================
|
|
|
|
Standard_Real Geom_Line::LastParameter() const
|
|
{
|
|
return Precision::Infinite();
|
|
}
|
|
|
|
//=================================================================================================
|
|
|
|
gp_Lin Geom_Line::Lin() const
|
|
{
|
|
return gp_Lin(pos);
|
|
}
|
|
|
|
//=================================================================================================
|
|
|
|
Standard_Boolean Geom_Line::IsCN(const Standard_Integer) const
|
|
{
|
|
return Standard_True;
|
|
}
|
|
|
|
//=================================================================================================
|
|
|
|
void Geom_Line::Transform(const gp_Trsf& T)
|
|
{
|
|
pos.Transform(T);
|
|
}
|
|
|
|
//=================================================================================================
|
|
|
|
void Geom_Line::D0(const Standard_Real U, gp_Pnt& P) const
|
|
{
|
|
P = ElCLib::LineValue(U, pos);
|
|
}
|
|
|
|
//=================================================================================================
|
|
|
|
void Geom_Line::D1(const Standard_Real U, gp_Pnt& P, gp_Vec& V1) const
|
|
{
|
|
|
|
ElCLib::LineD1(U, pos, P, V1);
|
|
}
|
|
|
|
//=================================================================================================
|
|
|
|
void Geom_Line::D2(const Standard_Real U, gp_Pnt& P, gp_Vec& V1, gp_Vec& V2) const
|
|
{
|
|
|
|
ElCLib::LineD1(U, pos, P, V1);
|
|
V2.SetCoord(0.0, 0.0, 0.0);
|
|
}
|
|
|
|
//=================================================================================================
|
|
|
|
void Geom_Line::D3(const Standard_Real U, gp_Pnt& P, gp_Vec& V1, gp_Vec& V2, gp_Vec& V3) const
|
|
{
|
|
|
|
ElCLib::LineD1(U, pos, P, V1);
|
|
V2.SetCoord(0.0, 0.0, 0.0);
|
|
V3.SetCoord(0.0, 0.0, 0.0);
|
|
}
|
|
|
|
//=================================================================================================
|
|
|
|
gp_Vec Geom_Line::DN(const Standard_Real, const Standard_Integer N) const
|
|
{
|
|
|
|
Standard_RangeError_Raise_if(N <= 0, " ");
|
|
if (N == 1)
|
|
return gp_Vec(pos.Direction());
|
|
else
|
|
return gp_Vec(0.0, 0.0, 0.0);
|
|
}
|
|
|
|
//=================================================================================================
|
|
|
|
Standard_Real Geom_Line::TransformedParameter(const Standard_Real U, const gp_Trsf& T) const
|
|
{
|
|
if (Precision::IsInfinite(U))
|
|
return U;
|
|
return U * Abs(T.ScaleFactor());
|
|
}
|
|
|
|
//=================================================================================================
|
|
|
|
Standard_Real Geom_Line::ParametricTransformation(const gp_Trsf& T) const
|
|
{
|
|
return Abs(T.ScaleFactor());
|
|
}
|
|
|
|
//=================================================================================================
|
|
|
|
void Geom_Line::DumpJson(Standard_OStream& theOStream, Standard_Integer theDepth) const
|
|
{
|
|
OCCT_DUMP_TRANSIENT_CLASS_BEGIN(theOStream)
|
|
OCCT_DUMP_BASE_CLASS(theOStream, theDepth, Geom_Curve)
|
|
|
|
OCCT_DUMP_FIELD_VALUES_DUMPED(theOStream, theDepth, &pos)
|
|
}
|