tesseract  5.0.0-alpha-619-ge9db
fpoint.cpp File Reference
#include "fpoint.h"
#include <cstdio>
#include <cmath>

Go to the source code of this file.

Macros

#define _USE_MATH_DEFINES
 

Functions

float DistanceBetween (FPOINT A, FPOINT B)
 
float NormalizedAngleFrom (FPOINT *Point1, FPOINT *Point2, float FullScale)
 

Macro Definition Documentation

◆ _USE_MATH_DEFINES

#define _USE_MATH_DEFINES

Definition at line 19 of file fpoint.cpp.

Function Documentation

◆ DistanceBetween()

float DistanceBetween ( FPOINT  A,
FPOINT  B 
)

Definition at line 28 of file fpoint.cpp.

29  {
30  const double xd = XDelta(A, B);
31  const double yd = YDelta(A, B);
32  return sqrt(static_cast<double>(xd * xd + yd * yd));

◆ NormalizedAngleFrom()

float NormalizedAngleFrom ( FPOINT Point1,
FPOINT Point2,
float  FullScale 
)

Return the angle from Point1 to Point2 normalized to lie in the range 0 to FullScale (where FullScale corresponds to 2*pi or 360 degrees).

Parameters
Point1points to compute angle between
Point2points to compute angle between
FullScalevalue to associate with 2*pi
Returns
angle

Definition at line 43 of file fpoint.cpp.

44  {
45  float NumRadsInCircle = 2.0 * M_PI;
46 
47  float Angle = AngleFrom (*Point1, *Point2);
48  if (Angle < 0.0)
49  Angle += NumRadsInCircle;
50  Angle *= FullScale / NumRadsInCircle;
51  if (Angle < 0.0 || Angle >= FullScale)
52  Angle = 0.0;
53  return (Angle);
AngleFrom
#define AngleFrom(A, B)
Definition: fpoint.h:40
YDelta
#define YDelta(A, B)
Definition: fpoint.h:38
XDelta
#define XDelta(A, B)
Definition: fpoint.h:37