1
0
mirror of https://git.dev.opencascade.org/repos/occt.git synced 2025-04-21 10:13:43 +03:00
occt/src/BRepLib/BRepLib_MakeEdge2d.cxx
cshorler ecac41a957 0026460: Implicit cast to TopoDS_Shape compilation error due to ambiguous conversion
- make operator TopoDS_Shape() cast a "non-const" member function
- make operator TopoDS_*() cast "non-const" when mutating behaviour is possible
- align derived class methods and overrides with the above changes

fix compilation for CR26460
- make argument for IsWRCase2 (non-const) BRepAlgoAPI_BooleanOperation&
2015-08-13 10:57:04 +03:00

781 lines
21 KiB
C++

// Created on: 1995-01-04
// Created by: Bruno DUMORTIER
// 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 <BRep_Builder.hxx>
#include <BRep_Tool.hxx>
#include <BRepLib.hxx>
#include <BRepLib_MakeEdge2d.hxx>
#include <ElCLib.hxx>
#include <ElSLib.hxx>
#include <Extrema_ExtPC2d.hxx>
#include <Geom2d_Circle.hxx>
#include <Geom2d_Curve.hxx>
#include <Geom2d_Ellipse.hxx>
#include <Geom2d_Hyperbola.hxx>
#include <Geom2d_Line.hxx>
#include <Geom2d_Parabola.hxx>
#include <Geom2d_TrimmedCurve.hxx>
#include <Geom2dAdaptor_Curve.hxx>
#include <Geom_Plane.hxx>
#include <gp.hxx>
#include <gp_Circ2d.hxx>
#include <gp_Elips2d.hxx>
#include <gp_Hypr2d.hxx>
#include <gp_Lin2d.hxx>
#include <gp_Parab2d.hxx>
#include <gp_Pnt2d.hxx>
#include <Precision.hxx>
#include <StdFail_NotDone.hxx>
#include <TopoDS.hxx>
#include <TopoDS_Edge.hxx>
#include <TopoDS_Vertex.hxx>
//=======================================================================
//function : Point
//purpose : make a 3d point on the current plane
//=======================================================================
static gp_Pnt Point(const gp_Pnt2d& P)
{
return BRepLib::Plane()->Value(P.X(),P.Y());
}
//=======================================================================
//function : Project
//purpose : project a vertex on the current plane
//=======================================================================
static gp_Pnt2d Project(const TopoDS_Vertex& Ve)
{
gp_Pnt P = BRep_Tool::Pnt(Ve);
Standard_Real U,V;
ElSLib::Parameters(BRepLib::Plane()->Pln(),P,U,V);
return gp_Pnt2d(U,V);
}
//=======================================================================
//function : Project
//purpose : project a vertex on a curve
//=======================================================================
static Standard_Boolean Project(const Handle(Geom2d_Curve)& C,
const TopoDS_Vertex& V,
Standard_Real& p)
{
gp_Pnt2d P = Project(V);
Geom2dAdaptor_Curve AC(C);
if (AC.GetType() == GeomAbs_Line) {
p = ElCLib::LineParameter(AC.Line().Position(),P);
}
else if (AC.GetType() == GeomAbs_Circle) {
p = ElCLib::CircleParameter(AC.Circle().Position(),P);
}
else {
Extrema_ExtPC2d extrema(P,AC);
if (extrema.IsDone()) {
Standard_Integer i,n = extrema.NbExt();
Standard_Real d2 = RealLast();
for (i = 1; i <= n; i++) {
//OCC16852:if (extrema.IsMin(i)) {
const Standard_Real dd2 = extrema.SquareDistance(i);
if (dd2 < d2) {
d2 = dd2;
p = extrema.Point(i).Parameter();
}
//OCC16852:}
}
}
else
return Standard_False;
}
return Standard_True;
}
//=======================================================================
//function : BRepLib_MakeEdge2d
//purpose :
//=======================================================================
BRepLib_MakeEdge2d::BRepLib_MakeEdge2d(const TopoDS_Vertex& V1,
const TopoDS_Vertex& V2)
{
gp_Pnt2d P1 = Project(V1);
gp_Pnt2d P2 = Project(V2);
Standard_Real l = P1.Distance(P2);
if (l <= gp::Resolution()) {
myError = BRepLib_LineThroughIdenticPoints;
return;
}
gp_Lin2d L(P1,gp_Vec2d(P1,P2));
Handle(Geom2d_Line) GL = new Geom2d_Line(L);
Init(GL,V1,V2,0,l);
}
//=======================================================================
//function : BRepLib_MakeEdge2d
//purpose :
//=======================================================================
BRepLib_MakeEdge2d::BRepLib_MakeEdge2d(const gp_Pnt2d& P1,
const gp_Pnt2d& P2)
{
Standard_Real l = P1.Distance(P2);
if (l <= gp::Resolution()) {
myError = BRepLib_LineThroughIdenticPoints;
return;
}
gp_Lin2d L(P1,gp_Vec2d(P1,P2));
Handle(Geom2d_Line) GL = new Geom2d_Line(L);
Init(GL,P1,P2,0,l);
}
//=======================================================================
//function : BRepLib_MakeEdge2d
//purpose :
//=======================================================================
BRepLib_MakeEdge2d::BRepLib_MakeEdge2d(const gp_Lin2d& L)
{
Handle(Geom2d_Line) GL = new Geom2d_Line(L);
Init(GL);
}
//=======================================================================
//function : BRepLib_MakeEdge2d
//purpose :
//=======================================================================
BRepLib_MakeEdge2d::BRepLib_MakeEdge2d(const gp_Lin2d& L,
const Standard_Real p1,
const Standard_Real p2)
{
Handle(Geom2d_Line) GL = new Geom2d_Line(L);
Init(GL,p1,p2);
}
//=======================================================================
//function : BRepLib_MakeEdge2d
//purpose :
//=======================================================================
BRepLib_MakeEdge2d::BRepLib_MakeEdge2d(const gp_Lin2d& L,
const gp_Pnt2d& P1,
const gp_Pnt2d& P2)
{
Handle(Geom2d_Line) GL = new Geom2d_Line(L);
Init(GL,P1,P2);
}
//=======================================================================
//function : BRepLib_MakeEdge2d
//purpose :
//=======================================================================
BRepLib_MakeEdge2d::BRepLib_MakeEdge2d(const gp_Lin2d& L,
const TopoDS_Vertex& V1,
const TopoDS_Vertex& V2)
{
Handle(Geom2d_Line) GL = new Geom2d_Line(L);
Init(GL,V1,V2);
}
//=======================================================================
//function : BRepLib_MakeEdge2d
//purpose :
//=======================================================================
BRepLib_MakeEdge2d::BRepLib_MakeEdge2d(const gp_Circ2d& C)
{
Handle(Geom2d_Circle) GC = new Geom2d_Circle(C);
Init(GC);
}
//=======================================================================
//function : BRepLib_MakeEdge2d
//purpose :
//=======================================================================
BRepLib_MakeEdge2d::BRepLib_MakeEdge2d(const gp_Circ2d& C,
const Standard_Real p1,
const Standard_Real p2)
{
Handle(Geom2d_Circle) GC = new Geom2d_Circle(C);
Init(GC,p1,p2);
}
//=======================================================================
//function : BRepLib_MakeEdge2d
//purpose :
//=======================================================================
BRepLib_MakeEdge2d::BRepLib_MakeEdge2d(const gp_Circ2d& C,
const gp_Pnt2d& P1,
const gp_Pnt2d& P2)
{
Handle(Geom2d_Circle) GC = new Geom2d_Circle(C);
Init(GC,P1,P2);
}
//=======================================================================
//function : BRepLib_MakeEdge2d
//purpose :
//=======================================================================
BRepLib_MakeEdge2d::BRepLib_MakeEdge2d(const gp_Circ2d& C,
const TopoDS_Vertex& V1,
const TopoDS_Vertex& V2)
{
Handle(Geom2d_Circle) GC = new Geom2d_Circle(C);
Init(GC,V1,V2);
}
//=======================================================================
//function : BRepLib_MakeEdge2d
//purpose :
//=======================================================================
BRepLib_MakeEdge2d::BRepLib_MakeEdge2d(const gp_Elips2d& E)
{
Handle(Geom2d_Ellipse) GE = new Geom2d_Ellipse(E);
Init(GE);
}
//=======================================================================
//function : BRepLib_MakeEdge2d
//purpose :
//=======================================================================
BRepLib_MakeEdge2d::BRepLib_MakeEdge2d(const gp_Elips2d& E,
const Standard_Real p1,
const Standard_Real p2)
{
Handle(Geom2d_Ellipse) GE = new Geom2d_Ellipse(E);
Init(GE,p1,p2);
}
//=======================================================================
//function : BRepLib_MakeEdge2d
//purpose :
//=======================================================================
BRepLib_MakeEdge2d::BRepLib_MakeEdge2d(const gp_Elips2d& E,
const gp_Pnt2d& P1,
const gp_Pnt2d& P2)
{
Handle(Geom2d_Ellipse) GE = new Geom2d_Ellipse(E);
Init(GE,P1,P2);
}
//=======================================================================
//function : BRepLib_MakeEdge2d
//purpose :
//=======================================================================
BRepLib_MakeEdge2d::BRepLib_MakeEdge2d(const gp_Elips2d& E,
const TopoDS_Vertex& V1,
const TopoDS_Vertex& V2)
{
Handle(Geom2d_Ellipse) GE = new Geom2d_Ellipse(E);
Init(GE,V1,V2);
}
//=======================================================================
//function : BRepLib_MakeEdge2d
//purpose :
//=======================================================================
BRepLib_MakeEdge2d::BRepLib_MakeEdge2d(const gp_Hypr2d& H)
{
Handle(Geom2d_Hyperbola) GH = new Geom2d_Hyperbola(H);
Init(GH);
}
//=======================================================================
//function : BRepLib_MakeEdge2d
//purpose :
//=======================================================================
BRepLib_MakeEdge2d::BRepLib_MakeEdge2d(const gp_Hypr2d& H,
const Standard_Real p1,
const Standard_Real p2)
{
Handle(Geom2d_Hyperbola) GH = new Geom2d_Hyperbola(H);
Init(GH,p1,p2);
}
//=======================================================================
//function : BRepLib_MakeEdge2d
//purpose :
//=======================================================================
BRepLib_MakeEdge2d::BRepLib_MakeEdge2d(const gp_Hypr2d& H,
const gp_Pnt2d& P1,
const gp_Pnt2d& P2)
{
Handle(Geom2d_Hyperbola) GH = new Geom2d_Hyperbola(H);
Init(GH,P1,P2);
}
//=======================================================================
//function : BRepLib_MakeEdge2d
//purpose :
//=======================================================================
BRepLib_MakeEdge2d::BRepLib_MakeEdge2d(const gp_Hypr2d& H,
const TopoDS_Vertex& V1,
const TopoDS_Vertex& V2)
{
Handle(Geom2d_Hyperbola) GH = new Geom2d_Hyperbola(H);
Init(GH,V1,V2);
}
//=======================================================================
//function : BRepLib_MakeEdge2d
//purpose :
//=======================================================================
BRepLib_MakeEdge2d::BRepLib_MakeEdge2d(const gp_Parab2d& P)
{
Handle(Geom2d_Parabola) GP = new Geom2d_Parabola(P);
Init(GP);
}
//=======================================================================
//function : BRepLib_MakeEdge2d
//purpose :
//=======================================================================
BRepLib_MakeEdge2d::BRepLib_MakeEdge2d(const gp_Parab2d& P,
const Standard_Real p1,
const Standard_Real p2)
{
Handle(Geom2d_Parabola) GP = new Geom2d_Parabola(P);
Init(GP,p1,p2);
}
//=======================================================================
//function : BRepLib_MakeEdge2d
//purpose :
//=======================================================================
BRepLib_MakeEdge2d::BRepLib_MakeEdge2d(const gp_Parab2d& P,
const gp_Pnt2d& P1,
const gp_Pnt2d& P2)
{
Handle(Geom2d_Parabola) GP = new Geom2d_Parabola(P);
Init(GP,P1,P2);
}
//=======================================================================
//function : BRepLib_MakeEdge2d
//purpose :
//=======================================================================
BRepLib_MakeEdge2d::BRepLib_MakeEdge2d(const gp_Parab2d& P,
const TopoDS_Vertex& V1,
const TopoDS_Vertex& V2)
{
Handle(Geom2d_Parabola) GP = new Geom2d_Parabola(P);
Init(GP,V1,V2);
}
//=======================================================================
//function : BRepLib_MakeEdge2d
//purpose :
//=======================================================================
BRepLib_MakeEdge2d::BRepLib_MakeEdge2d(const Handle(Geom2d_Curve)& L)
{
Init(L);
}
//=======================================================================
//function : BRepLib_MakeEdge2d
//purpose :
//=======================================================================
BRepLib_MakeEdge2d::BRepLib_MakeEdge2d(const Handle(Geom2d_Curve)& L,
const Standard_Real p1,
const Standard_Real p2)
{
Init(L,p1,p2);
}
//=======================================================================
//function : BRepLib_MakeEdge2d
//purpose :
//=======================================================================
BRepLib_MakeEdge2d::BRepLib_MakeEdge2d(const Handle(Geom2d_Curve)& L,
const gp_Pnt2d& P1,
const gp_Pnt2d& P2)
{
Init(L,P1,P2);
}
//=======================================================================
//function : BRepLib_MakeEdge2d
//purpose :
//=======================================================================
BRepLib_MakeEdge2d::BRepLib_MakeEdge2d(const Handle(Geom2d_Curve)& L,
const TopoDS_Vertex& V1,
const TopoDS_Vertex& V2)
{
Init(L,V1,V2);
}
//=======================================================================
//function : BRepLib_MakeEdge2d
//purpose :
//=======================================================================
BRepLib_MakeEdge2d::BRepLib_MakeEdge2d(const Handle(Geom2d_Curve)& L,
const gp_Pnt2d& P1,
const gp_Pnt2d& P2,
const Standard_Real p1,
const Standard_Real p2)
{
Init(L,P1,P2,p1,p2);
}
//=======================================================================
//function : BRepLib_MakeEdge2d
//purpose :
//=======================================================================
BRepLib_MakeEdge2d::BRepLib_MakeEdge2d(const Handle(Geom2d_Curve)& L,
const TopoDS_Vertex& V1,
const TopoDS_Vertex& V2,
const Standard_Real p1,
const Standard_Real p2)
{
Init(L,V1,V2,p1,p2);
}
//=======================================================================
//function : Init
//purpose :
//=======================================================================
void BRepLib_MakeEdge2d::Init(const Handle(Geom2d_Curve)& C)
{
Init(C,C->FirstParameter(),C->LastParameter());
}
//=======================================================================
//function : Init
//purpose :
//=======================================================================
void BRepLib_MakeEdge2d::Init(const Handle(Geom2d_Curve)& C,
const Standard_Real p1,
const Standard_Real p2)
{
// BRep_Builder B;
TopoDS_Vertex V1,V2;
Init(C,V1,V2,p1,p2);
}
//=======================================================================
//function : Init
//purpose :
//=======================================================================
void BRepLib_MakeEdge2d::Init(const Handle(Geom2d_Curve)& C,
const gp_Pnt2d& P1,
const gp_Pnt2d& P2)
{
BRep_Builder B;
TopoDS_Vertex V1,V2;
B.MakeVertex(V1,Point(P1),Precision::Confusion());
if (P1.Distance(P2) < Precision::Confusion())
V2 = V1;
else
B.MakeVertex(V2,Point(P2),Precision::Confusion());
Init(C,V1,V2);
}
//=======================================================================
//function : Init
//purpose :
//=======================================================================
void BRepLib_MakeEdge2d::Init(const Handle(Geom2d_Curve)& C,
const TopoDS_Vertex& V1,
const TopoDS_Vertex& V2)
{
// try projecting the vertices on the curve
Standard_Real p1,p2;
if (V1.IsNull())
p1 = C->FirstParameter();
else
if (!Project(C,V1,p1)) {
myError = BRepLib_PointProjectionFailed;
return;
}
if (V2.IsNull())
p2 = C->LastParameter();
else
if (!Project(C,V2,p2)) {
myError = BRepLib_PointProjectionFailed;
return;
}
Init(C,V1,V2,p1,p2);
}
//=======================================================================
//function : Init
//purpose :
//=======================================================================
void BRepLib_MakeEdge2d::Init(const Handle(Geom2d_Curve)& C,
const gp_Pnt2d& P1,
const gp_Pnt2d& P2,
const Standard_Real p1,
const Standard_Real p2)
{
BRep_Builder B;
TopoDS_Vertex V1,V2;
B.MakeVertex(V1,Point(P1),Precision::Confusion());
if (P1.Distance(P2) < Precision::Confusion())
V2 = V1;
else
B.MakeVertex(V2,Point(P2),Precision::Confusion());
Init(C,V1,V2,p1,p2);
}
//=======================================================================
//function : Init
//purpose : this one really makes the job ...
//=======================================================================
void BRepLib_MakeEdge2d::Init(const Handle(Geom2d_Curve)& CC,
const TopoDS_Vertex& VV1,
const TopoDS_Vertex& VV2,
const Standard_Real pp1,
const Standard_Real pp2)
{
// kill trimmed curves
Handle(Geom2d_Curve) C = CC;
Handle(Geom2d_TrimmedCurve) CT = Handle(Geom2d_TrimmedCurve)::DownCast(C);
while (!CT.IsNull()) {
C = CT->BasisCurve();
CT = Handle(Geom2d_TrimmedCurve)::DownCast(C);
}
// check parameters
Standard_Real p1 = pp1;
Standard_Real p2 = pp2;
Standard_Real cf = C->FirstParameter();
Standard_Real cl = C->LastParameter();
Standard_Real epsilon = Precision::Confusion();
Standard_Boolean periodic = C->IsPeriodic();
TopoDS_Vertex V1,V2;
if (periodic) {
// adjust in period
ElCLib::AdjustPeriodic(cf,cl,epsilon,p1,p2);
V1 = VV1;
V2 = VV2;
}
else {
// reordonate
if (p1 < p2) {
V1 = VV1;
V2 = VV2;
}
else {
V2 = VV1;
V1 = VV2;
Standard_Real x = p1;
p1 = p2;
p2 = x;
}
// check range
if ((cf - p1 > epsilon) || (p2 - cl > epsilon)) {
myError = BRepLib_ParameterOutOfRange;
return;
}
}
// compute points on the curve
Standard_Boolean p1inf = Precision::IsNegativeInfinite(p1);
Standard_Boolean p2inf = Precision::IsPositiveInfinite(p2);
gp_Pnt2d P1,P2;
if (!p1inf) P1 = C->Value(p1);
if (!p2inf) P2 = C->Value(p2);
Standard_Real preci = Precision::Confusion();
BRep_Builder B;
// check for closed curve
Standard_Boolean closed = Standard_False;
if (!p1inf && !p2inf)
closed = (P1.Distance(P2) <= preci);
// check if the vertices are on the curve
if (closed) {
if (V1.IsNull() && V2.IsNull()) {
B.MakeVertex(V1,Point(P1),preci);
V2 = V1;
}
else if (V1.IsNull())
V1 = V2;
else if (V2.IsNull())
V2 = V1;
else {
if (!V1.IsSame(V2)) {
myError = BRepLib_DifferentPointsOnClosedCurve;
return;
}
else if (Point(P1).Distance(BRep_Tool::Pnt(V1)) > preci) {
myError = BRepLib_DifferentPointsOnClosedCurve;
return;
}
}
}
else { // not closed
if (p1inf) {
if (!V1.IsNull()) {
myError = BRepLib_PointWithInfiniteParameter;
return;
}
}
else {
gp_Pnt P = Point(P1);
if (V1.IsNull()) {
B.MakeVertex(V1,P,preci);
}
#if 0
// desctivate control (RLE) for speed in sketcher
else if (P.Distance(BRep_Tool::Pnt(V1)) > preci) {
myError = BRepLib_DifferentsPointAndParameter;
return;
}
#endif
}
if (p2inf) {
if (!V2.IsNull()) {
myError = BRepLib_PointWithInfiniteParameter;
return;
}
}
else {
gp_Pnt P = Point(P2);
if (V2.IsNull()) {
B.MakeVertex(V2,P,preci);
}
#if 0
// desctivate control (RLE) for speed in sketcher
else if (P.Distance(BRep_Tool::Pnt(V2)) > preci){
myError = BRepLib_DifferentsPointAndParameter;
return;
}
#endif
}
}
V1.Orientation(TopAbs_FORWARD);
V2.Orientation(TopAbs_REVERSED);
myVertex1 = V1;
myVertex2 = V2;
TopoDS_Edge& E = TopoDS::Edge(myShape);
B.MakeEdge(E);
B.UpdateEdge(E,C,BRepLib::Plane(),TopLoc_Location(),preci);
if (!V1.IsNull()) {
B.Add(E,V1);
}
if (!V2.IsNull()) {
B.Add(E,V2);
}
B.Range(E,p1,p2);
Done();
}
//=======================================================================
//function : Error
//purpose :
//=======================================================================
BRepLib_EdgeError BRepLib_MakeEdge2d::Error() const
{
return myError;
}
//=======================================================================
//function : Edge
//purpose :
//=======================================================================
const TopoDS_Edge& BRepLib_MakeEdge2d::Edge()
{
return TopoDS::Edge(Shape());
}
//=======================================================================
//function : Vertex1
//purpose :
//=======================================================================
const TopoDS_Vertex& BRepLib_MakeEdge2d::Vertex1()const
{
Check();
return myVertex1;
}
//=======================================================================
//function : Vertex2
//purpose :
//=======================================================================
const TopoDS_Vertex& BRepLib_MakeEdge2d::Vertex2()const
{
Check();
return myVertex2;
}
//=======================================================================
//function : operator
//purpose :
//=======================================================================
BRepLib_MakeEdge2d::operator TopoDS_Edge()
{
return Edge();
}