1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180
|
// File generated by CPPExt (Value)
//
// Copyright (C) 1991 - 2000 by
// Matra Datavision SA. All rights reserved.
//
// Copyright (C) 2001 - 2004 by
// Open CASCADE SA. All rights reserved.
//
// This file is part of the Open CASCADE Technology software.
//
// This software may be distributed and/or modified under the terms and
// conditions of the Open CASCADE Public License as defined by Open CASCADE SA
// and appearing in the file LICENSE included in the packaging of this file.
//
// This software is distributed on an "AS IS" basis, without warranty of any
// kind, and Open CASCADE SA hereby disclaims all such warranties,
// including without limitation, any warranties of merchantability, fitness
// for a particular purpose or non-infringement. Please see the License for
// the specific terms and conditions governing rights and limitations under the
// License.
#ifndef _BRepPrimAPI_MakeRevol_HeaderFile
#define _BRepPrimAPI_MakeRevol_HeaderFile
#ifndef _BRepSweep_Revol_HeaderFile
#include <BRepSweep_Revol.hxx>
#endif
#ifndef _TopTools_ListOfShape_HeaderFile
#include <TopTools_ListOfShape.hxx>
#endif
#ifndef _BRepPrimAPI_MakeSweep_HeaderFile
#include <BRepPrimAPI_MakeSweep.hxx>
#endif
#ifndef _Standard_Real_HeaderFile
#include <Standard_Real.hxx>
#endif
#ifndef _Standard_Boolean_HeaderFile
#include <Standard_Boolean.hxx>
#endif
class TopoDS_Shape;
class gp_Ax1;
class BRepSweep_Revol;
class TopTools_ListOfShape;
#ifndef _Standard_HeaderFile
#include <Standard.hxx>
#endif
#ifndef _Standard_Macro_HeaderFile
#include <Standard_Macro.hxx>
#endif
//! Class to make revolved sweep topologies. <br>
//! <br>
//! a revolved sweep is defined by : <br>
//! <br>
//! * A basis topology which is swept. <br>
//! <br>
//! The basis topology must not contain solids <br>
//! (neither composite solids.). <br>
//! <br>
//! The basis topology may be copied or shared in <br>
//! the result. <br>
//! <br>
//! * A rotation axis and angle : <br>
//! <br>
//! - The axis is an Ax1 from gp. <br>
//! <br>
//! - The angle is in [0, 2*Pi]. <br>
//! <br>
//! - The angle default value is 2*Pi. <br>
//! <br>
//! <br>
//! The result is a topology with a higher dimension : <br>
//! <br>
//! - Vertex -> Edge. <br>
//! - Edge -> Face. <br>
//! - Wire -> Shell. <br>
//! - Face -> Solid. <br>
//! - Shell -> CompSolid. <br>
//! <br>
//! Sweeping a Compound sweeps the elements of the <br>
//! compound and creates a compound with the <br>
//! results. <br>
//! <br>
class BRepPrimAPI_MakeRevol : public BRepPrimAPI_MakeSweep {
public:
void* operator new(size_t,void* anAddress)
{
return anAddress;
}
void* operator new(size_t size)
{
return Standard::Allocate(size);
}
void operator delete(void *anAddress)
{
if (anAddress) Standard::Free((Standard_Address&)anAddress);
}
// Methods PUBLIC
//
//! Builds the Revol of base S, axis A and angle D. If C <br>
//! is true, S is copied. <br>
Standard_EXPORT BRepPrimAPI_MakeRevol(const TopoDS_Shape& S,const gp_Ax1& A,const Standard_Real D,const Standard_Boolean Copy = Standard_False);
//! Builds the Revol of base S, axis A and angle 2*Pi. If <br>
//! C is true, S is copied. <br>
Standard_EXPORT BRepPrimAPI_MakeRevol(const TopoDS_Shape& S,const gp_Ax1& A,const Standard_Boolean Copy = Standard_False);
//! Returns the internal sweeping algorithm. <br>
//! <br>
Standard_EXPORT const BRepSweep_Revol& Revol() const;
//! Builds the resulting shape (redefined from MakeShape). <br>
Standard_EXPORT virtual void Build() ;
//! Returns the first shape of the revol (coinciding with <br>
//! the generating shape). <br>
Standard_EXPORT TopoDS_Shape FirstShape() ;
//! Returns the TopoDS Shape of the end of the revol. <br>
Standard_EXPORT TopoDS_Shape LastShape() ;
Standard_EXPORT virtual const TopTools_ListOfShape& Generated(const TopoDS_Shape& S) ;
//! Returns the TopoDS Shape of the beginning of the revolution, <br>
//! generated with theShape (subShape of the generating shape). <br>
Standard_EXPORT TopoDS_Shape FirstShape(const TopoDS_Shape& theShape) ;
//! Returns the TopoDS Shape of the end of the revolution, <br>
//! generated with theShape (subShape of the generating shape). <br>
Standard_EXPORT TopoDS_Shape LastShape(const TopoDS_Shape& theShape) ;
//! Check if there are degenerated edges in the result. <br>
Standard_EXPORT Standard_Boolean HasDegenerated() const;
Standard_EXPORT const TopTools_ListOfShape& Degenerated() const;
protected:
// Methods PROTECTED
//
// Fields PROTECTED
//
private:
// Methods PRIVATE
//
// Fields PRIVATE
//
BRepSweep_Revol myRevol;
TopTools_ListOfShape myDegenerated;
};
// other Inline functions and methods (like "C++: function call" methods)
//
#endif
|