mirror of
https://git.dev.opencascade.org/repos/occt.git
synced 2025-04-06 18:26:22 +03:00
- 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&
208 lines
8.1 KiB
C++
208 lines
8.1 KiB
C++
// Created on: 1993-07-08
|
|
// Created by: Remi LEQUETTE
|
|
// 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.
|
|
|
|
#ifndef _BRepBuilderAPI_MakeWire_HeaderFile
|
|
#define _BRepBuilderAPI_MakeWire_HeaderFile
|
|
|
|
#include <Standard.hxx>
|
|
#include <Standard_DefineAlloc.hxx>
|
|
#include <Standard_Handle.hxx>
|
|
|
|
#include <BRepLib_MakeWire.hxx>
|
|
#include <BRepBuilderAPI_MakeShape.hxx>
|
|
#include <TopTools_ListOfShape.hxx>
|
|
#include <Standard_Boolean.hxx>
|
|
#include <BRepBuilderAPI_WireError.hxx>
|
|
class StdFail_NotDone;
|
|
class TopoDS_Edge;
|
|
class TopoDS_Wire;
|
|
class TopoDS_Vertex;
|
|
|
|
|
|
//! Describes functions to build wires from edges. A wire can
|
|
//! be built from any number of edges.
|
|
//! To build a wire you first initialize the construction, then
|
|
//! add edges in sequence. An unlimited number of edges
|
|
//! can be added. The initialization of construction is done with:
|
|
//! - no edge (an empty wire), or
|
|
//! - edges of an existing wire, or
|
|
//! - up to four connectable edges.
|
|
//! In order to be added to a wire under construction, an
|
|
//! edge (unless it is the first one) must satisfy the following
|
|
//! condition: one of its vertices must be geometrically
|
|
//! coincident with one of the vertices of the wire (provided
|
|
//! that the highest tolerance factor is assigned to the two
|
|
//! vertices). It could also be the same vertex.
|
|
//! - The given edge is shared by the wire if it contains:
|
|
//! - two vertices, identical to two vertices of the wire
|
|
//! under construction (a general case of the wire closure), or
|
|
//! - one vertex, identical to a vertex of the wire under
|
|
//! construction; the other vertex not being
|
|
//! geometrically coincident with another vertex of the wire.
|
|
//! - In other cases, when one of the vertices of the edge
|
|
//! is simply geometrically coincident with a vertex of the
|
|
//! wire under construction (provided that the highest
|
|
//! tolerance factor is assigned to the two vertices), the
|
|
//! given edge is first copied and the coincident vertex is
|
|
//! replaced in this new edge, by the coincident vertex of the wire.
|
|
//! Note: it is possible to build non manifold wires using this construction tool.
|
|
//! A MakeWire object provides a framework for:
|
|
//! - initializing the construction of a wire,
|
|
//! - adding edges to the wire under construction, and
|
|
//! - consulting the result.
|
|
class BRepBuilderAPI_MakeWire : public BRepBuilderAPI_MakeShape
|
|
{
|
|
public:
|
|
|
|
DEFINE_STANDARD_ALLOC
|
|
|
|
|
|
//! Constructs an empty wire framework, to which edges
|
|
//! are added using the Add function.
|
|
//! As soon as the wire contains one edge, it can return
|
|
//! with the use of the function Wire.
|
|
//! Warning
|
|
//! The function Error will return
|
|
//! BRepBuilderAPI_EmptyWire if it is called before at
|
|
//! least one edge is added to the wire under construction.
|
|
Standard_EXPORT BRepBuilderAPI_MakeWire();
|
|
|
|
//! Make a Wire from an edge.
|
|
Standard_EXPORT BRepBuilderAPI_MakeWire(const TopoDS_Edge& E);
|
|
|
|
//! Make a Wire from two edges.
|
|
Standard_EXPORT BRepBuilderAPI_MakeWire(const TopoDS_Edge& E1, const TopoDS_Edge& E2);
|
|
|
|
//! Make a Wire from three edges.
|
|
Standard_EXPORT BRepBuilderAPI_MakeWire(const TopoDS_Edge& E1, const TopoDS_Edge& E2, const TopoDS_Edge& E3);
|
|
|
|
//! Make a Wire from four edges.
|
|
//! Constructs a wire
|
|
//! - from the TopoDS_Wire W composed of the edge E, or
|
|
//! - from edge E, or
|
|
//! - from two edges E1 and E2, or
|
|
//! - from three edges E1, E2 and E3, or
|
|
//! - from four edges E1, E2, E3 and E4.
|
|
//! Further edges can be added using the function Add.
|
|
//! Given edges are added in a sequence. Each of them
|
|
//! must be connectable to the wire under construction,
|
|
//! and so must satisfy the following condition (unless it is
|
|
//! the first edge of the wire): one of its vertices must be
|
|
//! geometrically coincident with one of the vertices of the
|
|
//! wire (provided that the highest tolerance factor is
|
|
//! assigned to the two vertices). It could also be the same vertex.
|
|
//! Warning
|
|
//! If an edge is not connectable to the wire under
|
|
//! construction it is not added. The function Error will
|
|
//! return BRepBuilderAPI_DisconnectedWire, the
|
|
//! function IsDone will return false and the function Wire
|
|
//! will raise an error, until a new connectable edge is added.
|
|
Standard_EXPORT BRepBuilderAPI_MakeWire(const TopoDS_Edge& E1, const TopoDS_Edge& E2, const TopoDS_Edge& E3, const TopoDS_Edge& E4);
|
|
|
|
//! Make a Wire from a Wire. Usefull for adding later.
|
|
Standard_EXPORT BRepBuilderAPI_MakeWire(const TopoDS_Wire& W);
|
|
|
|
//! Add an edge to a wire.
|
|
Standard_EXPORT BRepBuilderAPI_MakeWire(const TopoDS_Wire& W, const TopoDS_Edge& E);
|
|
|
|
//! Adds the edge E to the wire under construction.
|
|
//! E must be connectable to the wire under construction, and, unless it
|
|
//! is the first edge of the wire, must satisfy the following
|
|
//! condition: one of its vertices must be geometrically coincident
|
|
//! with one of the vertices of the wire (provided that the highest
|
|
//! tolerance factor is assigned to the two vertices). It could also
|
|
//! be the same vertex.
|
|
//! Warning
|
|
//! If E is not connectable to the wire under construction it is not
|
|
//! added. The function Error will return
|
|
//! BRepBuilderAPI_DisconnectedWire, the function IsDone will return
|
|
//! false and the function Wire will raise an error, until a new
|
|
//! connectable edge is added.
|
|
Standard_EXPORT void Add (const TopoDS_Edge& E);
|
|
|
|
//! Add the edges of <W> to the current wire.
|
|
Standard_EXPORT void Add (const TopoDS_Wire& W);
|
|
|
|
//! Adds the edges of <L> to the current wire. The
|
|
//! edges are not to be consecutive. But they are to
|
|
//! be all connected geometrically or topologically.
|
|
//! If some of them are not connected the Status give
|
|
//! DisconnectedWire but the "Maker" is Done() and you
|
|
//! can get the partial result. (ie connected to the
|
|
//! first edgeof the list <L>)
|
|
Standard_EXPORT void Add (const TopTools_ListOfShape& L);
|
|
|
|
//! Returns true if this algorithm contains a valid wire.
|
|
//! IsDone returns false if:
|
|
//! - there are no edges in the wire, or
|
|
//! - the last edge which you tried to add was not connectable.
|
|
Standard_EXPORT virtual Standard_Boolean IsDone() const Standard_OVERRIDE;
|
|
|
|
//! Returns the construction status
|
|
//! - BRepBuilderAPI_WireDone if the wire is built, or
|
|
//! - another value of the BRepBuilderAPI_WireError
|
|
//! enumeration indicating why the construction failed.
|
|
Standard_EXPORT BRepBuilderAPI_WireError Error() const;
|
|
|
|
//! Returns the constructed wire; or the part of the wire
|
|
//! under construction already built.
|
|
//! Exceptions StdFail_NotDone if a wire is not built.
|
|
Standard_EXPORT const TopoDS_Wire& Wire();
|
|
Standard_EXPORT operator TopoDS_Wire();
|
|
|
|
//! Returns the last edge added to the wire under construction.
|
|
//! Warning
|
|
//! - This edge can be different from the original one (the
|
|
//! argument of the function Add, for instance,)
|
|
//! - A null edge is returned if there are no edges in the
|
|
//! wire under construction, or if the last edge which you
|
|
//! tried to add was not connectable..
|
|
Standard_EXPORT const TopoDS_Edge& Edge() const;
|
|
|
|
//! Returns the last vertex of the last edge added to the
|
|
//! wire under construction.
|
|
//! Warning
|
|
//! A null vertex is returned if there are no edges in the wire
|
|
//! under construction, or if the last edge which you tried to
|
|
//! add was not connectableR
|
|
Standard_EXPORT const TopoDS_Vertex& Vertex() const;
|
|
|
|
|
|
|
|
|
|
protected:
|
|
|
|
|
|
|
|
|
|
|
|
private:
|
|
|
|
|
|
|
|
BRepLib_MakeWire myMakeWire;
|
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
#endif // _BRepBuilderAPI_MakeWire_HeaderFile
|