1
0
mirror of https://git.dev.opencascade.org/repos/occt.git synced 2025-04-10 18:51:21 +03:00
occt/src/gp/gp_Dir2d.hxx
nds bc73b00672 0031313: Foundation Classes - Dump improvement for classes
- Provide DumpJson for geometrical, ocaf and visualization classes;
- Change depth parameter of DumpJson (constant is not obligate here)
- Introduce a new macro for transient objects to be called as the first row in DumpJson: OCCT_DUMP_TRANSIENT_CLASS_BEGIN. We need not put the class name in the macro, using get_type_name of Standard_Transient for it.
- change implementation of OCCT_DUMP_CLASS_BEGIN and OCCT_DUMP_TRANSIENT_CLASS_BEGIN. It is not an sentry more and it does not create a new hierarchy level. It appends a new row into the output stream: "className": <className>
- OCCT_DUMP_* does not require semicolon
- class header is included first in source files of TDataStd, TDocStd, TCAFDoc
2020-01-31 17:13:40 +03:00

281 lines
9.3 KiB
C++

// Copyright (c) 1991-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 _gp_Dir2d_HeaderFile
#define _gp_Dir2d_HeaderFile
#include <Standard.hxx>
#include <Standard_DefineAlloc.hxx>
#include <Standard_Handle.hxx>
#include <gp_XY.hxx>
#include <Standard_Real.hxx>
#include <Standard_Integer.hxx>
#include <Standard_Boolean.hxx>
class Standard_ConstructionError;
class Standard_DomainError;
class Standard_OutOfRange;
class gp_Vec2d;
class gp_XY;
class gp_Ax2d;
class gp_Trsf2d;
//! Describes a unit vector in the plane (2D space). This unit
//! vector is also called "Direction".
//! See Also
//! gce_MakeDir2d which provides functions for more
//! complex unit vector constructions
//! Geom2d_Direction which provides additional functions
//! for constructing unit vectors and works, in particular, with
//! the parametric equations of unit vectors
class gp_Dir2d
{
public:
DEFINE_STANDARD_ALLOC
//! Creates a direction corresponding to X axis.
gp_Dir2d();
//! Normalizes the vector V and creates a Direction. Raises ConstructionError if V.Magnitude() <= Resolution from gp.
gp_Dir2d(const gp_Vec2d& V);
//! Creates a Direction from a doublet of coordinates. Raises ConstructionError if Coord.Modulus() <= Resolution from gp.
gp_Dir2d(const gp_XY& Coord);
//! Creates a Direction with its 2 cartesian coordinates. Raises ConstructionError if Sqrt(Xv*Xv + Yv*Yv) <= Resolution from gp.
gp_Dir2d(const Standard_Real Xv, const Standard_Real Yv);
//! For this unit vector, assigns:
//! the value Xi to:
//! - the X coordinate if Index is 1, or
//! - the Y coordinate if Index is 2, and then normalizes it.
//! Warning
//! Remember that all the coordinates of a unit vector are
//! implicitly modified when any single one is changed directly.
//! Exceptions
//! Standard_OutOfRange if Index is not 1 or 2.
//! Standard_ConstructionError if either of the following
//! is less than or equal to gp::Resolution():
//! - Sqrt(Xv*Xv + Yv*Yv), or
//! - the modulus of the number pair formed by the new
//! value Xi and the other coordinate of this vector that
//! was not directly modified.
//! Raises OutOfRange if Index != {1, 2}.
void SetCoord (const Standard_Integer Index, const Standard_Real Xi);
//! For this unit vector, assigns:
//! - the values Xv and Yv to its two coordinates,
//! Warning
//! Remember that all the coordinates of a unit vector are
//! implicitly modified when any single one is changed directly.
//! Exceptions
//! Standard_OutOfRange if Index is not 1 or 2.
//! Standard_ConstructionError if either of the following
//! is less than or equal to gp::Resolution():
//! - Sqrt(Xv*Xv + Yv*Yv), or
//! - the modulus of the number pair formed by the new
//! value Xi and the other coordinate of this vector that
//! was not directly modified.
//! Raises OutOfRange if Index != {1, 2}.
void SetCoord (const Standard_Real Xv, const Standard_Real Yv);
//! Assigns the given value to the X coordinate of this unit vector,
//! and then normalizes it.
//! Warning
//! Remember that all the coordinates of a unit vector are
//! implicitly modified when any single one is changed directly.
//! Exceptions
//! Standard_ConstructionError if either of the following
//! is less than or equal to gp::Resolution():
//! - the modulus of Coord, or
//! - the modulus of the number pair formed from the new
//! X or Y coordinate and the other coordinate of this
//! vector that was not directly modified.
void SetX (const Standard_Real X);
//! Assigns the given value to the Y coordinate of this unit vector,
//! and then normalizes it.
//! Warning
//! Remember that all the coordinates of a unit vector are
//! implicitly modified when any single one is changed directly.
//! Exceptions
//! Standard_ConstructionError if either of the following
//! is less than or equal to gp::Resolution():
//! - the modulus of Coord, or
//! - the modulus of the number pair formed from the new
//! X or Y coordinate and the other coordinate of this
//! vector that was not directly modified.
void SetY (const Standard_Real Y);
//! Assigns:
//! - the two coordinates of Coord to this unit vector,
//! and then normalizes it.
//! Warning
//! Remember that all the coordinates of a unit vector are
//! implicitly modified when any single one is changed directly.
//! Exceptions
//! Standard_ConstructionError if either of the following
//! is less than or equal to gp::Resolution():
//! - the modulus of Coord, or
//! - the modulus of the number pair formed from the new
//! X or Y coordinate and the other coordinate of this
//! vector that was not directly modified.
void SetXY (const gp_XY& Coord);
//! For this unit vector returns the coordinate of range Index :
//! Index = 1 => X is returned
//! Index = 2 => Y is returned
//! Raises OutOfRange if Index != {1, 2}.
Standard_Real Coord (const Standard_Integer Index) const;
//! For this unit vector returns its two coordinates Xv and Yv.
//! Raises OutOfRange if Index != {1, 2}.
void Coord (Standard_Real& Xv, Standard_Real& Yv) const;
//! For this unit vector, returns its X coordinate.
Standard_Real X() const;
//! For this unit vector, returns its Y coordinate.
Standard_Real Y() const;
//! For this unit vector, returns its two coordinates as a number pair.
//! Comparison between Directions
//! The precision value is an input data.
const gp_XY& XY() const;
//! Returns True if the two vectors have the same direction
//! i.e. the angle between this unit vector and the
//! unit vector Other is less than or equal to AngularTolerance.
Standard_Boolean IsEqual (const gp_Dir2d& Other, const Standard_Real AngularTolerance) const;
//! Returns True if the angle between this unit vector and the
//! unit vector Other is equal to Pi/2 or -Pi/2 (normal)
//! i.e. Abs(Abs(<me>.Angle(Other)) - PI/2.) <= AngularTolerance
Standard_Boolean IsNormal (const gp_Dir2d& Other, const Standard_Real AngularTolerance) const;
//! Returns True if the angle between this unit vector and the
//! unit vector Other is equal to Pi or -Pi (opposite).
//! i.e. PI - Abs(<me>.Angle(Other)) <= AngularTolerance
Standard_Boolean IsOpposite (const gp_Dir2d& Other, const Standard_Real AngularTolerance) const;
//! returns true if if the angle between this unit vector and unit
//! vector Other is equal to 0, Pi or -Pi.
//! i.e. Abs(Angle(<me>, Other)) <= AngularTolerance or
//! PI - Abs(Angle(<me>, Other)) <= AngularTolerance
Standard_Boolean IsParallel (const gp_Dir2d& Other, const Standard_Real AngularTolerance) const;
//! Computes the angular value in radians between <me> and
//! <Other>. Returns the angle in the range [-PI, PI].
Standard_EXPORT Standard_Real Angle (const gp_Dir2d& Other) const;
//! Computes the cross product between two directions.
Standard_NODISCARD Standard_Real Crossed (const gp_Dir2d& Right) const;
Standard_NODISCARD Standard_Real operator ^ (const gp_Dir2d& Right) const
{
return Crossed(Right);
}
//! Computes the scalar product
Standard_Real Dot (const gp_Dir2d& Other) const;
Standard_Real operator * (const gp_Dir2d& Other) const
{
return Dot(Other);
}
void Reverse();
//! Reverses the orientation of a direction
Standard_NODISCARD gp_Dir2d Reversed() const;
Standard_NODISCARD gp_Dir2d operator -() const
{
return Reversed();
}
Standard_EXPORT void Mirror (const gp_Dir2d& V);
//! Performs the symmetrical transformation of a direction
//! with respect to the direction V which is the center of
//! the symmetry.
Standard_NODISCARD Standard_EXPORT gp_Dir2d Mirrored (const gp_Dir2d& V) const;
Standard_EXPORT void Mirror (const gp_Ax2d& A);
//! Performs the symmetrical transformation of a direction
//! with respect to an axis placement which is the axis
//! of the symmetry.
Standard_NODISCARD Standard_EXPORT gp_Dir2d Mirrored (const gp_Ax2d& A) const;
void Rotate (const Standard_Real Ang);
//! Rotates a direction. Ang is the angular value of
//! the rotation in radians.
Standard_NODISCARD gp_Dir2d Rotated (const Standard_Real Ang) const;
Standard_EXPORT void Transform (const gp_Trsf2d& T);
//! Transforms a direction with the "Trsf" T.
//! Warnings :
//! If the scale factor of the "Trsf" T is negative then the
//! direction <me> is reversed.
Standard_NODISCARD gp_Dir2d Transformed (const gp_Trsf2d& T) const;
//! Dumps the content of me into the stream
Standard_EXPORT void DumpJson (Standard_OStream& theOStream, Standard_Integer theDepth = -1) const;
protected:
private:
gp_XY coord;
};
#include <gp_Dir2d.lxx>
#endif // _gp_Dir2d_HeaderFile