| 1 | /***************************************************************************** |
|---|
| 2 | * |
|---|
| 3 | * This file is part of Mapnik (c++ mapping toolkit) |
|---|
| 4 | * |
|---|
| 5 | * Copyright (C) 2006 Artem Pavlenko |
|---|
| 6 | * |
|---|
| 7 | * This library is free software; you can redistribute it and/or |
|---|
| 8 | * modify it under the terms of the GNU Lesser General Public |
|---|
| 9 | * License as published by the Free Software Foundation; either |
|---|
| 10 | * version 2.1 of the License, or (at your option) any later version. |
|---|
| 11 | * |
|---|
| 12 | * This library is distributed in the hope that it will be useful, |
|---|
| 13 | * but WITHOUT ANY WARRANTY; without even the implied warranty of |
|---|
| 14 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU |
|---|
| 15 | * Lesser General Public License for more details. |
|---|
| 16 | * |
|---|
| 17 | * You should have received a copy of the GNU Lesser General Public |
|---|
| 18 | * License along with this library; if not, write to the Free Software |
|---|
| 19 | * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA |
|---|
| 20 | * |
|---|
| 21 | *****************************************************************************/ |
|---|
| 22 | |
|---|
| 23 | //$Id$ |
|---|
| 24 | #include <mapnik/scale_denominator.hpp> |
|---|
| 25 | |
|---|
| 26 | #include <mapnik/map.hpp> |
|---|
| 27 | |
|---|
| 28 | #include <cmath> |
|---|
| 29 | |
|---|
| 30 | namespace mapnik { |
|---|
| 31 | |
|---|
| 32 | static const double pi = 3.14159265359; |
|---|
| 33 | static const double meters_per_degree = 6378137 * 2 * pi/ 360; |
|---|
| 34 | |
|---|
| 35 | double scale_denominator(Map const& map, bool geographic) |
|---|
| 36 | { |
|---|
| 37 | double denom = map.scale() / 0.00028; |
|---|
| 38 | if (geographic) denom *= meters_per_degree; |
|---|
| 39 | return denom; |
|---|
| 40 | } |
|---|
| 41 | } |
|---|