+// Copyright (C) 2014-20xx CEA/DEN, EDF R&D
+
// File: GeomAPI_Dir.hxx
// Created: 23 Apr 2014
// Author: Mikhail PONIKAROV
#define GeomAPI_Dir_H_
#include <GeomAPI_Interface.h>
-#include <boost/shared_ptr.hpp>
+#include <memory>
class GeomAPI_XYZ;
/// Creation of direction by coordinates
GeomAPI_Dir(const double theX, const double theY, const double theZ);
/// Creation of direction by coordinates
- GeomAPI_Dir(const boost::shared_ptr<GeomAPI_XYZ>& theCoords);
+ GeomAPI_Dir(const std::shared_ptr<GeomAPI_XYZ>& theCoords);
/// returns X coordinate
double x() const;
double z() const;
/// returns coordinates of the direction
- const boost::shared_ptr<GeomAPI_XYZ> xyz();
+ const std::shared_ptr<GeomAPI_XYZ> xyz();
/// result is a scalar product of directions
- double dot(const boost::shared_ptr<GeomAPI_Dir>& theArg) const;
+ double dot(const std::shared_ptr<GeomAPI_Dir>& theArg) const;
/// result is a cross product of two directions
- const boost::shared_ptr<GeomAPI_XYZ> cross(const boost::shared_ptr<GeomAPI_Dir>& theArg) const;
+ const std::shared_ptr<GeomAPI_XYZ> cross(const std::shared_ptr<GeomAPI_Dir>& theArg) const;
+
+ /// calculates angle between two directions
+ double angle(const std::shared_ptr<GeomAPI_Dir>& theArg) const;
};
#endif