Welcome to mirror list, hosted at ThFree Co, Russian Federation.

mercator.cpp « indexer - github.com/mapsme/omim.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
blob: 7ee65eebbe26294e50e96875cc04f503e112d5e2 (plain)
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
#include "mercator.hpp"

double MercatorBounds::minX = -180;
double MercatorBounds::maxX = 180;
double MercatorBounds::minY = -180;
double MercatorBounds::maxY = 180;
double const MercatorBounds::degreeInMetres = 360.0 / 40008245;

m2::RectD MercatorBounds::MetresToXY(double lon, double lat,
                                     double lonMetresR, double latMetresR)
{
  double const latDegreeOffset = latMetresR * degreeInMetres;
  double const minLat = max(-90.0, lat - latDegreeOffset);
  double const maxLat = min( 90.0, lat + latDegreeOffset);

  double const cosL = max(cos(my::DegToRad(max(fabs(minLat), fabs(maxLat)))), 0.00001);
  ASSERT_GREATER ( cosL, 0.0, () );

  double const lonDegreeOffset = lonMetresR * degreeInMetres / cosL;
  double const minLon = max(-180.0, lon - lonDegreeOffset);
  double const maxLon = min( 180.0, lon + lonDegreeOffset);

  return m2::RectD(m2::PointD(LonToX(minLon), LatToY(minLat)),
                   m2::PointD(LonToX(maxLon), LatToY(maxLat)));
}

m2::PointD MercatorBounds::GetSmPoint(m2::PointD const & pt, double lonMetresR, double latMetresR)
{
  double const lat = YToLat(pt.y);
  double const lon = XToLon(pt.x);

  double const latDegreeOffset = latMetresR * degreeInMetres;
  double const newLat = min(90.0, max(-90.0, lat + latDegreeOffset));

  double const cosL = max(cos(my::DegToRad(newLat)), 0.00001);
  ASSERT_GREATER ( cosL, 0.0, () );

  double const lonDegreeOffset = lonMetresR * degreeInMetres / cosL;
  double const newLon = min(180.0, max(-180.0, lon + lonDegreeOffset));

  return m2::PointD(LonToX(newLon), LatToY(newLat));
}