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: ff22035db56aff22ccbd9006e4004d9b69fd9525 (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
#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)));
}