diff options
author | Mattes D <github@xoft.cz> | 2015-07-31 16:49:10 +0200 |
---|---|---|
committer | Mattes D <github@xoft.cz> | 2015-07-31 16:49:10 +0200 |
commit | 6e4122e551eeb41d3e950b363dd837d5586fe560 (patch) | |
tree | b5ee221d8a8e63c7d3b7868da1db19bf717a6ffd /src/BoundingBox.h | |
parent | Merge pull request #2400 from cuberite/OffloadBadChunks (diff) | |
download | cuberite-6e4122e551eeb41d3e950b363dd837d5586fe560.tar cuberite-6e4122e551eeb41d3e950b363dd837d5586fe560.tar.gz cuberite-6e4122e551eeb41d3e950b363dd837d5586fe560.tar.bz2 cuberite-6e4122e551eeb41d3e950b363dd837d5586fe560.tar.lz cuberite-6e4122e551eeb41d3e950b363dd837d5586fe560.tar.xz cuberite-6e4122e551eeb41d3e950b363dd837d5586fe560.tar.zst cuberite-6e4122e551eeb41d3e950b363dd837d5586fe560.zip |
Diffstat (limited to 'src/BoundingBox.h')
-rw-r--r-- | src/BoundingBox.h | 33 |
1 files changed, 15 insertions, 18 deletions
diff --git a/src/BoundingBox.h b/src/BoundingBox.h index 8ea758ac7..1f9d0ebee 100644 --- a/src/BoundingBox.h +++ b/src/BoundingBox.h @@ -20,8 +20,7 @@ /** Represents two sets of coords, minimum and maximum for each direction. All the coords within those limits (inclusive the edges) are considered "inside" the box. For intersection purposes, though, if the intersection is "sharp" in any coord (i. e. zero volume), -the boxes are considered non-intersecting. -*/ +the boxes are considered non-intersecting. */ class cBoundingBox { public: @@ -30,54 +29,52 @@ public: cBoundingBox(const Vector3d & a_Pos, double a_Radius, double a_Height); cBoundingBox(const cBoundingBox & a_Orig); - /// Moves the entire boundingbox by the specified offset + /** Moves the entire boundingbox by the specified offset */ void Move(double a_OffX, double a_OffY, double a_OffZ); - /// Moves the entire boundingbox by the specified offset + /** Moves the entire boundingbox by the specified offset */ void Move(const Vector3d & a_Off); - /// Expands the bounding box by the specified amount in each direction (so the box becomes larger by 2 * Expand in each direction) + /** Expands the bounding box by the specified amount in each direction (so the box becomes larger by 2 * Expand in each direction) */ void Expand(double a_ExpandX, double a_ExpandY, double a_ExpandZ); - /// Returns true if the two bounding boxes intersect + /** Returns true if the two bounding boxes intersect */ bool DoesIntersect(const cBoundingBox & a_Other); - /// Returns the union of the two bounding boxes + /** Returns the union of the two bounding boxes */ cBoundingBox Union(const cBoundingBox & a_Other); - /// Returns true if the point is inside the bounding box + /** Returns true if the point is inside the bounding box */ bool IsInside(const Vector3d & a_Point); - /// Returns true if the point is inside the bounding box + /** Returns true if the point is inside the bounding box */ bool IsInside(double a_X, double a_Y, double a_Z); - /// Returns true if a_Other is inside this bounding box + /** Returns true if a_Other is inside this bounding box */ bool IsInside(cBoundingBox & a_Other); - /// Returns true if a boundingbox specified by a_Min and a_Max is inside this bounding box + /** Returns true if a boundingbox specified by a_Min and a_Max is inside this bounding box */ bool IsInside(const Vector3d & a_Min, const Vector3d & a_Max); - /// Returns true if the specified point is inside the bounding box specified by its min / max corners + /** Returns true if the specified point is inside the bounding box specified by its min / max corners */ static bool IsInside(const Vector3d & a_Min, const Vector3d & a_Max, const Vector3d & a_Point); - /// Returns true if the specified point is inside the bounding box specified by its min / max corners + /** Returns true if the specified point is inside the bounding box specified by its min / max corners */ static bool IsInside(const Vector3d & a_Min, const Vector3d & a_Max, double a_X, double a_Y, double a_Z); /** Returns true if this bounding box is intersected by the line specified by its two points Also calculates the distance along the line in which the intersection occurs (0 .. 1) - Only forward collisions (a_LineCoeff >= 0) are returned. - */ + Only forward collisions (a_LineCoeff >= 0) are returned. */ bool CalcLineIntersection(const Vector3d & a_Line1, const Vector3d & a_Line2, double & a_LineCoeff, eBlockFace & a_Face); /** Returns true if the specified bounding box is intersected by the line specified by its two points Also calculates the distance along the line in which the intersection occurs (0 .. 1) and the face hit (BLOCK_FACE_ constants) - Only forward collisions (a_LineCoeff >= 0) are returned. - */ + Only forward collisions (a_LineCoeff >= 0) are returned. */ static bool CalcLineIntersection(const Vector3d & a_Min, const Vector3d & a_Max, const Vector3d & a_Line1, const Vector3d & a_Line2, double & a_LineCoeff, eBlockFace & a_Face); // tolua_end - /// Calculates the intersection of the two bounding boxes; returns true if nonempty + /** Calculates the intersection of the two bounding boxes; returns true if nonempty */ bool Intersect(const cBoundingBox & a_Other, cBoundingBox & a_Intersection); double GetMinX(void) const { return m_Min.x; } |