Files
OCCT/src/BRepBuilderAPI/BRepBuilderAPI_MakeEdge.cxx
2012-03-05 19:23:40 +04:00

894 lines
23 KiB
C++
Executable File

// File: BRepBuilderAPI_MakeEdge.cxx
// Created: Fri Jul 23 15:51:46 1993
// Author: Remi LEQUETTE
// <rle@nonox>
#include <BRepBuilderAPI_MakeEdge.ixx>
//=======================================================================
//function : BRepBuilderAPI_MakeEdge
//purpose :
//=======================================================================
BRepBuilderAPI_MakeEdge::BRepBuilderAPI_MakeEdge()
{}
//=======================================================================
//function : BRepBuilderAPI_MakeEdge
//purpose :
//=======================================================================
BRepBuilderAPI_MakeEdge::BRepBuilderAPI_MakeEdge(const TopoDS_Vertex& V1,
const TopoDS_Vertex& V2)
: myMakeEdge(V1,V2)
{
if ( myMakeEdge.IsDone()) {
Done();
myShape = myMakeEdge.Shape();
}
}
//=======================================================================
//function : BRepBuilderAPI_MakeEdge
//purpose :
//=======================================================================
BRepBuilderAPI_MakeEdge::BRepBuilderAPI_MakeEdge(const gp_Pnt& P1,
const gp_Pnt& P2)
: myMakeEdge(P1,P2)
{
if ( myMakeEdge.IsDone()) {
Done();
myShape = myMakeEdge.Shape();
}
}
//=======================================================================
//function : BRepBuilderAPI_MakeEdge
//purpose :
//=======================================================================
BRepBuilderAPI_MakeEdge::BRepBuilderAPI_MakeEdge(const gp_Lin& L)
: myMakeEdge(L)
{
if ( myMakeEdge.IsDone()) {
Done();
myShape = myMakeEdge.Shape();
}
}
//=======================================================================
//function : BRepBuilderAPI_MakeEdge
//purpose :
//=======================================================================
BRepBuilderAPI_MakeEdge::BRepBuilderAPI_MakeEdge(const gp_Lin& L,
const Standard_Real p1,
const Standard_Real p2)
: myMakeEdge(L,p1,p2)
{
if ( myMakeEdge.IsDone()) {
Done();
myShape = myMakeEdge.Shape();
}
}
//=======================================================================
//function : BRepBuilderAPI_MakeEdge
//purpose :
//=======================================================================
BRepBuilderAPI_MakeEdge::BRepBuilderAPI_MakeEdge(const gp_Lin& L,
const gp_Pnt& P1,
const gp_Pnt& P2)
: myMakeEdge(L,P1,P2)
{
if ( myMakeEdge.IsDone()) {
Done();
myShape = myMakeEdge.Shape();
}
}
//=======================================================================
//function : BRepBuilderAPI_MakeEdge
//purpose :
//=======================================================================
BRepBuilderAPI_MakeEdge::BRepBuilderAPI_MakeEdge(const gp_Lin& L,
const TopoDS_Vertex& V1,
const TopoDS_Vertex& V2)
: myMakeEdge(L,V1,V2)
{
if ( myMakeEdge.IsDone()) {
Done();
myShape = myMakeEdge.Shape();
}
}
//=======================================================================
//function : BRepBuilderAPI_MakeEdge
//purpose :
//=======================================================================
BRepBuilderAPI_MakeEdge::BRepBuilderAPI_MakeEdge(const gp_Circ& C)
: myMakeEdge(C)
{
if ( myMakeEdge.IsDone()) {
Done();
myShape = myMakeEdge.Shape();
}
}
//=======================================================================
//function : BRepBuilderAPI_MakeEdge
//purpose :
//=======================================================================
BRepBuilderAPI_MakeEdge::BRepBuilderAPI_MakeEdge(const gp_Circ& C,
const Standard_Real p1,
const Standard_Real p2)
: myMakeEdge(C,p1,p2)
{
if ( myMakeEdge.IsDone()) {
Done();
myShape = myMakeEdge.Shape();
}
}
//=======================================================================
//function : BRepBuilderAPI_MakeEdge
//purpose :
//=======================================================================
BRepBuilderAPI_MakeEdge::BRepBuilderAPI_MakeEdge(const gp_Circ& C ,
const gp_Pnt& P1,
const gp_Pnt& P2 )
: myMakeEdge(C,P1,P2)
{
if ( myMakeEdge.IsDone()) {
Done();
myShape = myMakeEdge.Shape();
}
}
//=======================================================================
//function : BRepBuilderAPI_MakeEdge
//purpose :
//=======================================================================
BRepBuilderAPI_MakeEdge::BRepBuilderAPI_MakeEdge(const gp_Circ& C,
const TopoDS_Vertex& V1,
const TopoDS_Vertex& V2)
: myMakeEdge(C,V1,V2)
{
if ( myMakeEdge.IsDone()) {
Done();
myShape = myMakeEdge.Shape();
}
}
//=======================================================================
//function : BRepBuilderAPI_MakeEdge
//purpose :
//=======================================================================
BRepBuilderAPI_MakeEdge::BRepBuilderAPI_MakeEdge(const gp_Elips& E)
:myMakeEdge(E)
{
if ( myMakeEdge.IsDone()) {
Done();
myShape = myMakeEdge.Shape();
}
}
//=======================================================================
//function : BRepBuilderAPI_MakeEdge
//purpose :
//=======================================================================
BRepBuilderAPI_MakeEdge::BRepBuilderAPI_MakeEdge(const gp_Elips& E,
const Standard_Real p1,
const Standard_Real p2)
: myMakeEdge(E,p1,p2)
{
if ( myMakeEdge.IsDone()) {
Done();
myShape = myMakeEdge.Shape();
}
}
//=======================================================================
//function : BRepBuilderAPI_MakeEdge
//purpose :
//=======================================================================
BRepBuilderAPI_MakeEdge::BRepBuilderAPI_MakeEdge(const gp_Elips& E,
const gp_Pnt& P1,
const gp_Pnt& P2)
: myMakeEdge(E,P1,P2)
{
if ( myMakeEdge.IsDone()) {
Done();
myShape = myMakeEdge.Shape();
}
}
//=======================================================================
//function : BRepBuilderAPI_MakeEdge
//purpose :
//=======================================================================
BRepBuilderAPI_MakeEdge::BRepBuilderAPI_MakeEdge(const gp_Elips& E,
const TopoDS_Vertex& V1,
const TopoDS_Vertex& V2)
: myMakeEdge(E,V1,V2)
{
if ( myMakeEdge.IsDone()) {
Done();
myShape = myMakeEdge.Shape();
}
}
//=======================================================================
//function : BRepBuilderAPI_MakeEdge
//purpose :
//=======================================================================
BRepBuilderAPI_MakeEdge::BRepBuilderAPI_MakeEdge(const gp_Hypr& H)
: myMakeEdge(H)
{
if ( myMakeEdge.IsDone()) {
Done();
myShape = myMakeEdge.Shape();
}
}
//=======================================================================
//function : BRepBuilderAPI_MakeEdge
//purpose :
//=======================================================================
BRepBuilderAPI_MakeEdge::BRepBuilderAPI_MakeEdge(const gp_Hypr& H,
const Standard_Real p1,
const Standard_Real p2)
: myMakeEdge(H,p1,p2)
{
if ( myMakeEdge.IsDone()) {
Done();
myShape = myMakeEdge.Shape();
}
}
//=======================================================================
//function : BRepBuilderAPI_MakeEdge
//purpose :
//=======================================================================
BRepBuilderAPI_MakeEdge::BRepBuilderAPI_MakeEdge(const gp_Hypr& H,
const gp_Pnt& P1,
const gp_Pnt& P2)
: myMakeEdge(H,P1,P2)
{
if ( myMakeEdge.IsDone()) {
Done();
myShape = myMakeEdge.Shape();
}
}
//=======================================================================
//function : BRepBuilderAPI_MakeEdge
//purpose :
//=======================================================================
BRepBuilderAPI_MakeEdge::BRepBuilderAPI_MakeEdge(const gp_Hypr& H,
const TopoDS_Vertex& V1,
const TopoDS_Vertex& V2)
: myMakeEdge(H,V1,V2)
{
if ( myMakeEdge.IsDone()) {
Done();
myShape = myMakeEdge.Shape();
}
}
//=======================================================================
//function : BRepBuilderAPI_MakeEdge
//purpose :
//=======================================================================
BRepBuilderAPI_MakeEdge::BRepBuilderAPI_MakeEdge(const gp_Parab& P)
: myMakeEdge(P)
{
if ( myMakeEdge.IsDone()) {
Done();
myShape = myMakeEdge.Shape();
}
}
//=======================================================================
//function : BRepBuilderAPI_MakeEdge
//purpose :
//=======================================================================
BRepBuilderAPI_MakeEdge::BRepBuilderAPI_MakeEdge(const gp_Parab& P,
const Standard_Real p1,
const Standard_Real p2)
: myMakeEdge(P,p1,p2)
{
if ( myMakeEdge.IsDone()) {
Done();
myShape = myMakeEdge.Shape();
}
}
//=======================================================================
//function : BRepBuilderAPI_MakeEdge
//purpose :
//=======================================================================
BRepBuilderAPI_MakeEdge::BRepBuilderAPI_MakeEdge(const gp_Parab& P,
const gp_Pnt& P1,
const gp_Pnt& P2)
: myMakeEdge(P,P1,P2)
{
if ( myMakeEdge.IsDone()) {
Done();
myShape = myMakeEdge.Shape();
}
}
//=======================================================================
//function : BRepBuilderAPI_MakeEdge
//purpose :
//=======================================================================
BRepBuilderAPI_MakeEdge::BRepBuilderAPI_MakeEdge(const gp_Parab& P,
const TopoDS_Vertex& V1,
const TopoDS_Vertex& V2)
: myMakeEdge(P,V1,V2)
{
if ( myMakeEdge.IsDone()) {
Done();
myShape = myMakeEdge.Shape();
}
}
//=======================================================================
//function : BRepBuilderAPI_MakeEdge
//purpose :
//=======================================================================
BRepBuilderAPI_MakeEdge::BRepBuilderAPI_MakeEdge(const Handle(Geom_Curve)& L)
: myMakeEdge(L)
{
if ( myMakeEdge.IsDone()) {
Done();
myShape = myMakeEdge.Shape();
}
}
//=======================================================================
//function : BRepBuilderAPI_MakeEdge
//purpose :
//=======================================================================
BRepBuilderAPI_MakeEdge::BRepBuilderAPI_MakeEdge(const Handle(Geom_Curve)& L,
const Standard_Real p1,
const Standard_Real p2)
: myMakeEdge(L,p1,p2)
{
if ( myMakeEdge.IsDone()) {
Done();
myShape = myMakeEdge.Shape();
}
}
//=======================================================================
//function : BRepBuilderAPI_MakeEdge
//purpose :
//=======================================================================
BRepBuilderAPI_MakeEdge::BRepBuilderAPI_MakeEdge(const Handle(Geom_Curve)& L,
const gp_Pnt& P1,
const gp_Pnt& P2)
: myMakeEdge(L,P1,P2)
{
if ( myMakeEdge.IsDone()) {
Done();
myShape = myMakeEdge.Shape();
}
}
//=======================================================================
//function : BRepBuilderAPI_MakeEdge
//purpose :
//=======================================================================
BRepBuilderAPI_MakeEdge::BRepBuilderAPI_MakeEdge(const Handle(Geom_Curve)& L,
const TopoDS_Vertex& V1,
const TopoDS_Vertex& V2)
: myMakeEdge(L,V1,V2)
{
if ( myMakeEdge.IsDone()) {
Done();
myShape = myMakeEdge.Shape();
}
}
//=======================================================================
//function : BRepBuilderAPI_MakeEdge
//purpose :
//=======================================================================
BRepBuilderAPI_MakeEdge::BRepBuilderAPI_MakeEdge(const Handle(Geom_Curve)& L,
const gp_Pnt& P1,
const gp_Pnt& P2,
const Standard_Real p1,
const Standard_Real p2)
: myMakeEdge(L,P1,P2,p1,p2)
{
if ( myMakeEdge.IsDone()) {
Done();
myShape = myMakeEdge.Shape();
}
}
//=======================================================================
//function : BRepBuilderAPI_MakeEdge
//purpose :
//=======================================================================
BRepBuilderAPI_MakeEdge::BRepBuilderAPI_MakeEdge(const Handle(Geom_Curve)& L,
const TopoDS_Vertex& V1,
const TopoDS_Vertex& V2,
const Standard_Real p1,
const Standard_Real p2)
: myMakeEdge(L,V1,V2,p1,p2)
{
if ( myMakeEdge.IsDone()) {
Done();
myShape = myMakeEdge.Shape();
}
}
//=======================================================================
//function : BRepBuilderAPI_MakeEdge
//purpose :
//=======================================================================
BRepBuilderAPI_MakeEdge::BRepBuilderAPI_MakeEdge(const Handle(Geom2d_Curve)& L,
const Handle(Geom_Surface)& S)
: myMakeEdge(L,S)
{
if ( myMakeEdge.IsDone()) {
Done();
myShape = myMakeEdge.Shape();
}
}
//=======================================================================
//function : BRepBuilderAPI_MakeEdge
//purpose :
//=======================================================================
BRepBuilderAPI_MakeEdge::BRepBuilderAPI_MakeEdge(const Handle(Geom2d_Curve)& L,
const Handle(Geom_Surface)& S,
const Standard_Real p1,
const Standard_Real p2)
: myMakeEdge(L,S,p1,p2)
{
if ( myMakeEdge.IsDone()) {
Done();
myShape = myMakeEdge.Shape();
}
}
//=======================================================================
//function : BRepBuilderAPI_MakeEdge
//purpose :
//=======================================================================
BRepBuilderAPI_MakeEdge::BRepBuilderAPI_MakeEdge(const Handle(Geom2d_Curve)& L,
const Handle(Geom_Surface)& S,
const gp_Pnt& P1,
const gp_Pnt& P2)
: myMakeEdge(L,S,P1,P2)
{
if ( myMakeEdge.IsDone()) {
Done();
myShape = myMakeEdge.Shape();
}
}
//=======================================================================
//function : BRepBuilderAPI_MakeEdge
//purpose :
//=======================================================================
BRepBuilderAPI_MakeEdge::BRepBuilderAPI_MakeEdge(const Handle(Geom2d_Curve)& L,
const Handle(Geom_Surface)& S,
const TopoDS_Vertex& V1,
const TopoDS_Vertex& V2)
: myMakeEdge(L,S,V1,V2)
{
if ( myMakeEdge.IsDone()) {
Done();
myShape = myMakeEdge.Shape();
}
}
//=======================================================================
//function : BRepBuilderAPI_MakeEdge
//purpose :
//=======================================================================
BRepBuilderAPI_MakeEdge::BRepBuilderAPI_MakeEdge(const Handle(Geom2d_Curve)& L,
const Handle(Geom_Surface)& S,
const gp_Pnt& P1,
const gp_Pnt& P2,
const Standard_Real p1,
const Standard_Real p2)
: myMakeEdge(L,S,P1,P2,p1,p2)
{
if ( myMakeEdge.IsDone()) {
Done();
myShape = myMakeEdge.Shape();
}
}
//=======================================================================
//function : BRepBuilderAPI_MakeEdge
//purpose :
//=======================================================================
BRepBuilderAPI_MakeEdge::BRepBuilderAPI_MakeEdge(const Handle(Geom2d_Curve)& L,
const Handle(Geom_Surface)& S,
const TopoDS_Vertex& V1,
const TopoDS_Vertex& V2,
const Standard_Real p1,
const Standard_Real p2)
: myMakeEdge(L,S,V1,V2,p1,p2)
{
if ( myMakeEdge.IsDone()) {
Done();
myShape = myMakeEdge.Shape();
}
}
//=======================================================================
//function : Init
//purpose :
//=======================================================================
void BRepBuilderAPI_MakeEdge::Init(const Handle(Geom_Curve)& C)
{
myMakeEdge.Init(C);
if ( myMakeEdge.IsDone()) {
Done();
myShape = myMakeEdge.Shape();
}
}
//=======================================================================
//function : Init
//purpose :
//=======================================================================
void BRepBuilderAPI_MakeEdge::Init(const Handle(Geom_Curve)& C,
const Standard_Real p1,
const Standard_Real p2)
{
myMakeEdge.Init(C,p1,p2);
if ( myMakeEdge.IsDone()) {
Done();
myShape = myMakeEdge.Shape();
}
}
//=======================================================================
//function : Init
//purpose :
//=======================================================================
void BRepBuilderAPI_MakeEdge::Init(const Handle(Geom_Curve)& C,
const gp_Pnt& P1,
const gp_Pnt& P2)
{
myMakeEdge.Init(C,P1,P2);
if ( myMakeEdge.IsDone()) {
Done();
myShape = myMakeEdge.Shape();
}
}
//=======================================================================
//function : Init
//purpose :
//=======================================================================
void BRepBuilderAPI_MakeEdge::Init(const Handle(Geom_Curve)& C,
const TopoDS_Vertex& V1,
const TopoDS_Vertex& V2)
{
myMakeEdge.Init(C,V1,V2);
if ( myMakeEdge.IsDone()) {
Done();
myShape = myMakeEdge.Shape();
}
}
//=======================================================================
//function : Init
//purpose :
//=======================================================================
void BRepBuilderAPI_MakeEdge::Init(const Handle(Geom_Curve)& C,
const gp_Pnt& P1,
const gp_Pnt& P2,
const Standard_Real p1,
const Standard_Real p2)
{
myMakeEdge.Init(C,P1,P2,p1,p2);
if ( myMakeEdge.IsDone()) {
Done();
myShape = myMakeEdge.Shape();
}
}
//=======================================================================
//function : Init
//purpose :
//=======================================================================
void BRepBuilderAPI_MakeEdge::Init(const Handle(Geom_Curve)& CC,
const TopoDS_Vertex& VV1,
const TopoDS_Vertex& VV2,
const Standard_Real pp1,
const Standard_Real pp2)
{
myMakeEdge.Init(CC,VV1,VV2,pp1,pp2);
if ( myMakeEdge.IsDone()) {
Done();
myShape = myMakeEdge.Shape();
}
}
//=======================================================================
//function : Init
//purpose :
//=======================================================================
void BRepBuilderAPI_MakeEdge::Init(const Handle(Geom2d_Curve)& C,
const Handle(Geom_Surface)& S)
{
myMakeEdge.Init(C,S);
if ( myMakeEdge.IsDone()) {
Done();
myShape = myMakeEdge.Shape();
}
}
//=======================================================================
//function : Init
//purpose :
//=======================================================================
void BRepBuilderAPI_MakeEdge::Init(const Handle(Geom2d_Curve)& C,
const Handle(Geom_Surface)& S,
const Standard_Real p1,
const Standard_Real p2)
{
myMakeEdge.Init(C,S,p1,p2);
if ( myMakeEdge.IsDone()) {
Done();
myShape = myMakeEdge.Shape();
}
}
//=======================================================================
//function : Init
//purpose :
//=======================================================================
void BRepBuilderAPI_MakeEdge::Init(const Handle(Geom2d_Curve)& C,
const Handle(Geom_Surface)& S,
const gp_Pnt& P1,
const gp_Pnt& P2)
{
myMakeEdge.Init(C,S,P1,P2);
if ( myMakeEdge.IsDone()) {
Done();
myShape = myMakeEdge.Shape();
}
}
//=======================================================================
//function : Init
//purpose :
//=======================================================================
void BRepBuilderAPI_MakeEdge::Init(const Handle(Geom2d_Curve)& C,
const Handle(Geom_Surface)& S,
const TopoDS_Vertex& V1,
const TopoDS_Vertex& V2)
{
myMakeEdge.Init(C,S,V1,V2);
if ( myMakeEdge.IsDone()) {
Done();
myShape = myMakeEdge.Shape();
}
}
//=======================================================================
//function : Init
//purpose :
//=======================================================================
void BRepBuilderAPI_MakeEdge::Init(const Handle(Geom2d_Curve)& C,
const Handle(Geom_Surface)& S,
const gp_Pnt& P1,
const gp_Pnt& P2,
const Standard_Real p1,
const Standard_Real p2)
{
myMakeEdge.Init(C,S,P1,P2,p1,p2);
if ( myMakeEdge.IsDone()) {
Done();
myShape = myMakeEdge.Shape();
}
}
//=======================================================================
//function : Init
//purpose :
//=======================================================================
void BRepBuilderAPI_MakeEdge::Init(const Handle(Geom2d_Curve)& CC,
const Handle(Geom_Surface)& S,
const TopoDS_Vertex& VV1,
const TopoDS_Vertex& VV2,
const Standard_Real pp1,
const Standard_Real pp2)
{
myMakeEdge.Init(CC,S,VV1,VV2,pp1,pp2);
if ( myMakeEdge.IsDone()) {
Done();
myShape = myMakeEdge.Shape();
}
}
//=======================================================================
//function : IsDone
//purpose :
//=======================================================================
Standard_Boolean BRepBuilderAPI_MakeEdge::IsDone() const
{
return myMakeEdge.IsDone();
}
//=======================================================================
//function : Error
//purpose :
//=======================================================================
BRepBuilderAPI_EdgeError BRepBuilderAPI_MakeEdge::Error() const
{
switch ( myMakeEdge.Error()) {
case BRepLib_EdgeDone:
return BRepBuilderAPI_EdgeDone;
case BRepLib_PointProjectionFailed:
return BRepBuilderAPI_PointProjectionFailed;
case BRepLib_ParameterOutOfRange:
return BRepBuilderAPI_ParameterOutOfRange;
case BRepLib_DifferentPointsOnClosedCurve:
return BRepBuilderAPI_DifferentPointsOnClosedCurve;
case BRepLib_PointWithInfiniteParameter:
return BRepBuilderAPI_PointWithInfiniteParameter;
case BRepLib_DifferentsPointAndParameter:
return BRepBuilderAPI_DifferentsPointAndParameter;
case BRepLib_LineThroughIdenticPoints:
return BRepBuilderAPI_LineThroughIdenticPoints;
}
// portage WNT
return BRepBuilderAPI_EdgeDone;
}
//=======================================================================
//function : Edge
//purpose :
//=======================================================================
const TopoDS_Edge& BRepBuilderAPI_MakeEdge::Edge()const
{
return myMakeEdge.Edge();
}
//=======================================================================
//function : Vertex1
//purpose :
//=======================================================================
const TopoDS_Vertex& BRepBuilderAPI_MakeEdge::Vertex1()const
{
return myMakeEdge.Vertex1();
}
//=======================================================================
//function : Vertex2
//purpose :
//=======================================================================
const TopoDS_Vertex& BRepBuilderAPI_MakeEdge::Vertex2()const
{
return myMakeEdge.Vertex2();
}
//=======================================================================
//function : operator
//purpose :
//=======================================================================
BRepBuilderAPI_MakeEdge::operator TopoDS_Edge() const
{
return Edge();
}