/usr/include/oce/Bnd_Box.hxx is in liboce-foundation-dev 0.17.2-2.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
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 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 222 223 224 225 226 227 228 229 230 231 232 233 234 235 236 237 238 239 240 241 242 243 244 245 246 247 248 249 250 251 252 253 254 255 256 257 258 259 260 261 262 263 264 265 266 267 268 269 270 271 272 273 | // This file is generated by WOK (CPPExt).
// Please do not edit this file; modify original file instead.
// The copyright and license terms as defined for the original file apply to
// this header file considered to be the "object code" form of the original source.
#ifndef _Bnd_Box_HeaderFile
#define _Bnd_Box_HeaderFile
#include <Standard.hxx>
#include <Standard_DefineAlloc.hxx>
#include <Standard_Macro.hxx>
#include <Standard_Real.hxx>
#include <Standard_Integer.hxx>
#include <Standard_Boolean.hxx>
class Standard_ConstructionError;
class gp_Pnt;
class gp_Dir;
class gp_Trsf;
class gp_Lin;
class gp_Pln;
//! Describes a bounding box in 3D space.
//! A bounding box is parallel to the axes of the coordinates
//! system. If it is finite, it is defined by the three intervals:
//! - [ Xmin,Xmax ],
//! - [ Ymin,Ymax ],
//! - [ Zmin,Zmax ].
//! A bounding box may be infinite (i.e. open) in one or more
//! directions. It is said to be:
//! - OpenXmin if it is infinite on the negative side of the "X Direction";
//! - OpenXmax if it is infinite on the positive side of the "X Direction";
//! - OpenYmin if it is infinite on the negative side of the "Y Direction";
//! - OpenYmax if it is infinite on the positive side of the "Y Direction";
//! - OpenZmin if it is infinite on the negative side of the "Z Direction";
//! - OpenZmax if it is infinite on the positive side of the "Z Direction";
//! - WholeSpace if it is infinite in all six directions. In this
//! case, any point of the space is inside the box;
//! - Void if it is empty. In this case, there is no point included in the box.
//! A bounding box is defined by:
//! - six bounds (Xmin, Xmax, Ymin, Ymax, Zmin and
//! Zmax) which limit the bounding box if it is finite,
//! - eight flags (OpenXmin, OpenXmax, OpenYmin,
//! OpenYmax, OpenZmin, OpenZmax,
//! WholeSpace and Void) which describe the
//! bounding box if it is infinite or empty, and
//! - a gap, which is included on both sides in any direction
//! when consulting the finite bounds of the box.
class Bnd_Box
{
public:
DEFINE_STANDARD_ALLOC
//! Creates an empty Box.
//! The constructed box is qualified Void. Its gap is null.
Standard_EXPORT Bnd_Box();
//! Sets this bounding box so that it covers the whole of 3D space.
//! It is infinitely long in all directions.
Standard_EXPORT void SetWhole() ;
//! Sets this bounding box so that it is empty. All points are outside a void box.
Standard_EXPORT void SetVoid() ;
//! Sets this bounding box so that it bounds
//! - the point P. This involves first setting this bounding box
//! to be void and then adding the point P.
Standard_EXPORT void Set (const gp_Pnt& P) ;
//! Sets this bounding box so that it bounds
//! the half-line defined by point P and direction D, i.e. all
//! points M defined by M=P+u*D, where u is greater than
//! or equal to 0, are inside the bounding volume. This
//! involves first setting this box to be void and then adding the half-line.
Standard_EXPORT void Set (const gp_Pnt& P, const gp_Dir& D) ;
//! Enlarges this bounding box, if required, so that it
//! contains at least:
//! - interval [ aXmin,aXmax ] in the "X Direction",
//! - interval [ aYmin,aYmax ] in the "Y Direction",
//! - interval [ aZmin,aZmax ] in the "Z Direction";
Standard_EXPORT void Update (const Standard_Real aXmin, const Standard_Real aYmin, const Standard_Real aZmin, const Standard_Real aXmax, const Standard_Real aYmax, const Standard_Real aZmax) ;
//! Adds a point of coordinates (X,Y,Z) to this bounding box.
Standard_EXPORT void Update (const Standard_Real X, const Standard_Real Y, const Standard_Real Z) ;
//! Returns the gap of this bounding box.
Standard_EXPORT Standard_Real GetGap() const;
//! Set the gap of this bounding box to abs(Tol).
Standard_EXPORT void SetGap (const Standard_Real Tol) ;
//! Enlarges the box with a tolerance value.
//! (minvalues-Abs(<tol>) and maxvalues+Abs(<tol>))
//! This means that the minimum values of its X, Y and Z
//! intervals of definition, when they are finite, are reduced by
//! the absolute value of Tol, while the maximum values are
//! increased by the same amount.
Standard_EXPORT void Enlarge (const Standard_Real Tol) ;
//! Returns the bounds of this bounding box. The gap is included.
//! If this bounding box is infinite (i.e. "open"), returned values
//! may be equal to +/- Precision::Infinite().
//! Standard_ConstructionError exception will be thrown if the box is void.
//! if IsVoid()
Standard_EXPORT void Get (Standard_Real& theXmin, Standard_Real& theYmin, Standard_Real& theZmin, Standard_Real& theXmax, Standard_Real& theYmax, Standard_Real& theZmax) const;
//! Returns the lower corner of this bounding box. The gap is included.
//! If this bounding box is infinite (i.e. "open"), returned values
//! may be equal to +/- Precision::Infinite().
//! Standard_ConstructionError exception will be thrown if the box is void.
//! if IsVoid()
Standard_EXPORT gp_Pnt CornerMin() const;
//! Returns the upper corner of this bounding box. The gap is included.
//! If this bounding box is infinite (i.e. "open"), returned values
//! may be equal to +/- Precision::Infinite().
//! Standard_ConstructionError exception will be thrown if the box is void.
//! if IsVoid()
Standard_EXPORT gp_Pnt CornerMax() const;
//! The Box will be infinitely long in the Xmin
//! direction.
Standard_EXPORT void OpenXmin() ;
//! The Box will be infinitely long in the Xmax
//! direction.
Standard_EXPORT void OpenXmax() ;
//! The Box will be infinitely long in the Ymin
//! direction.
Standard_EXPORT void OpenYmin() ;
//! The Box will be infinitely long in the Ymax
//! direction.
Standard_EXPORT void OpenYmax() ;
//! The Box will be infinitely long in the Zmin
//! direction.
Standard_EXPORT void OpenZmin() ;
//! The Box will be infinitely long in the Zmax
//! direction.
Standard_EXPORT void OpenZmax() ;
//! Returns true if this bounding box is open in the Xmin direction.
Standard_EXPORT Standard_Boolean IsOpenXmin() const;
//! Returns true if this bounding box is open in the Xmax direction.
Standard_EXPORT Standard_Boolean IsOpenXmax() const;
//! Returns true if this bounding box is open in the Ymix direction.
Standard_EXPORT Standard_Boolean IsOpenYmin() const;
//! Returns true if this bounding box is open in the Ymax direction.
Standard_EXPORT Standard_Boolean IsOpenYmax() const;
//! Returns true if this bounding box is open in the Zmin direction.
Standard_EXPORT Standard_Boolean IsOpenZmin() const;
//! Returns true if this bounding box is open in the Zmax direction.
Standard_EXPORT Standard_Boolean IsOpenZmax() const;
//! Returns true if this bounding box is infinite in all 6 directions (WholeSpace flag).
Standard_EXPORT Standard_Boolean IsWhole() const;
//! Returns true if this bounding box is empty (Void flag).
Standard_EXPORT Standard_Boolean IsVoid() const;
//! true if xmax-xmin < tol.
Standard_EXPORT Standard_Boolean IsXThin (const Standard_Real tol) const;
//! true if ymax-ymin < tol.
Standard_EXPORT Standard_Boolean IsYThin (const Standard_Real tol) const;
//! true if zmax-zmin < tol.
Standard_EXPORT Standard_Boolean IsZThin (const Standard_Real tol) const;
//! Returns true if IsXThin, IsYThin and IsZThin are all true,
//! i.e. if the box is thin in all three dimensions.
Standard_EXPORT Standard_Boolean IsThin (const Standard_Real tol) const;
//! Returns a bounding box which is the result of applying the
//! transformation T to this bounding box.
//! Warning
//! Applying a geometric transformation (for example, a
//! rotation) to a bounding box generally increases its
//! dimensions. This is not optimal for algorithms which use it.
Standard_EXPORT Bnd_Box Transformed (const gp_Trsf& T) const;
//! Adds the box <Other> to <me>.
Standard_EXPORT void Add (const Bnd_Box& Other) ;
//! Adds a Pnt to the box.
Standard_EXPORT void Add (const gp_Pnt& P) ;
//! Extends <me> from the Pnt <P> in the direction <D>.
Standard_EXPORT void Add (const gp_Pnt& P, const gp_Dir& D) ;
//! Extends the Box in the given Direction, i.e. adds
//! an half-line. The box may become infinite in
//! 1,2 or 3 directions.
Standard_EXPORT void Add (const gp_Dir& D) ;
//! Returns True if the Pnt is out the box.
Standard_EXPORT Standard_Boolean IsOut (const gp_Pnt& P) const;
//! Returns False if the line intersects the box.
Standard_EXPORT Standard_Boolean IsOut (const gp_Lin& L) const;
//! Returns False if the plane intersects the box.
Standard_EXPORT Standard_Boolean IsOut (const gp_Pln& P) const;
//! Returns False if the <Box> intersects or is inside <me>.
Standard_EXPORT Standard_Boolean IsOut (const Bnd_Box& Other) const;
//! Returns False if the transformed <Box> intersects
//! or is inside <me>.
Standard_EXPORT Standard_Boolean IsOut (const Bnd_Box& Other, const gp_Trsf& T) const;
//! Returns False if the transformed <Box> intersects
//! or is inside the transformed box <me>.
Standard_EXPORT Standard_Boolean IsOut (const gp_Trsf& T1, const Bnd_Box& Other, const gp_Trsf& T2) const;
//! Returns False if the flat band lying between two parallel
//! lines represented by their reference points <P1>, <P2> and
//! direction <D> intersects the box.
Standard_EXPORT Standard_Boolean IsOut (const gp_Pnt& P1, const gp_Pnt& P2, const gp_Dir& D) const;
//! Computes the minimum distance between two boxes.
Standard_EXPORT Standard_Real Distance (const Bnd_Box& Other) const;
Standard_EXPORT void Dump() const;
//! Computes the squared diagonal of me.
Standard_Real SquareExtent() const;
protected:
private:
Standard_Real Xmin;
Standard_Real Xmax;
Standard_Real Ymin;
Standard_Real Ymax;
Standard_Real Zmin;
Standard_Real Zmax;
Standard_Real Gap;
Standard_Integer Flags;
};
#include <Bnd_Box.lxx>
#endif // _Bnd_Box_HeaderFile
|