Cleaned debug prints
[situare] / src / map / maptile.cpp
1 /*
2    Situare - A location system for Facebook
3    Copyright (C) 2010  Ixonos Plc. Authors:
4
5        Sami Rämö - sami.ramo@ixonos.com
6
7    Situare is free software; you can redistribute it and/or
8    modify it under the terms of the GNU General Public License
9    version 2 as published by the Free Software Foundation.
10
11    Situare is distributed in the hope that it will be useful,
12    but WITHOUT ANY WARRANTY; without even the implied warranty of
13    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
14    GNU General Public License for more details.
15
16    You should have received a copy of the GNU General Public License
17    along with Situare; if not, write to the Free Software
18    Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA  02110-1301,
19    USA.
20 */
21
22 #include <QDebug>
23 #include <QTransform>
24
25 #include "coordinates/scenecoordinate.h"
26 #include "mapcommon.h"
27
28 #include "maptile.h"
29
30 MapTile::MapTile()
31     : m_zoomLevel(UNDEFINED)
32     , m_tileNumber(QPoint(UNDEFINED, UNDEFINED))
33 {
34     qDebug() << __PRETTY_FUNCTION__;
35
36     setPos(UNDEFINED, UNDEFINED);
37     setShapeMode(QGraphicsPixmapItem::BoundingRectShape);
38 }
39
40 SceneCoordinate MapTile::convertTileNumberToSceneCoordinate(int zoomLevel, QPoint tileNumber)
41 {
42     qDebug() << __PRETTY_FUNCTION__;
43
44     int pow = 1 << (OSM_MAX_ZOOM_LEVEL - zoomLevel);
45     int x = tileNumber.x() * OSM_TILE_SIZE_X * pow;
46     int y = tileNumber.y() * OSM_TILE_SIZE_Y * pow;
47
48     return SceneCoordinate(x, y);
49 }
50
51 int MapTile::lastTileIndex(int zoomLevel)
52 {
53     qDebug() << __PRETTY_FUNCTION__;
54
55     // subtract one because first tile index is zero
56     return tilesPerSide(zoomLevel) - 1;
57 }
58
59 void MapTile::setSceneLevel(int currentZoomLevel)
60 {
61     qDebug() << __PRETTY_FUNCTION__;
62
63     if (currentZoomLevel < m_zoomLevel) {
64         qreal z = static_cast<qreal>(MAP_SCENE_MIN_NORMAL_LEVEL + currentZoomLevel
65                                      - (m_zoomLevel - currentZoomLevel)) + 0.5;
66         setZValue(z);
67     }
68     else
69         setZValue(static_cast<qreal>(MAP_SCENE_MIN_NORMAL_LEVEL + m_zoomLevel));
70 }
71
72 void MapTile::setTileNumber(QPoint tileNumber)
73 {
74     qDebug() << __PRETTY_FUNCTION__;
75
76     m_tileNumber = tileNumber;
77     setPosition();
78 }
79
80 void MapTile::setPosition()
81 {
82     qDebug() << __PRETTY_FUNCTION__;
83
84     const int MAX_TILE_NUMBER = MapTile::lastTileIndex(m_zoomLevel);
85
86     // calculate min & max horizontal tile index numbers
87     const int INDEX_0_TILE = 1;
88     const int MIN_TILE_NUMBER_X = -tilesPerSide(m_zoomLevel)
89                                   * MAP_SCENE_VERTICAL_OVERSIZE_FACTOR;
90     const int MAX_TILE_NUMBER_X = tilesPerSide(m_zoomLevel)
91                                   * (1 + MAP_SCENE_VERTICAL_OVERSIZE_FACTOR)
92                                   - INDEX_0_TILE;
93
94     if ((m_zoomLevel >= OSM_MIN_ZOOM_LEVEL) && (m_zoomLevel <= OSM_MAX_ZOOM_LEVEL)
95         && (m_tileNumber.x() >= MIN_TILE_NUMBER_X) && (m_tileNumber.x() <= MAX_TILE_NUMBER_X)
96         && (m_tileNumber.y() >= 0) && (m_tileNumber.y() <= MAX_TILE_NUMBER)) {
97             setPos(convertTileNumberToSceneCoordinate(m_zoomLevel, m_tileNumber).toPointF());
98     } else {
99         setPos(UNDEFINED, UNDEFINED);
100     }
101 }
102
103 void MapTile::setZoomLevel(int tileZoomLevel, int currentViewZoomLevel)
104 {
105     qDebug() << __PRETTY_FUNCTION__;
106
107     m_zoomLevel = tileZoomLevel;
108     setPosition();
109
110     setSceneLevel(currentViewZoomLevel);
111
112     qreal zoomFactor = static_cast<qreal>(1 << (OSM_MAX_ZOOM_LEVEL - m_zoomLevel));
113     setScale(zoomFactor);
114 }
115
116 QPoint MapTile::tileNumber()
117 {
118     qDebug() << __PRETTY_FUNCTION__;
119
120     return m_tileNumber;
121 }
122
123 QString MapTile::tilePath(int zoomLevel, int x, int y)
124 {
125     qDebug() << __PRETTY_FUNCTION__;
126
127     QString tilePathString(QString::number(zoomLevel) + "/");
128     tilePathString.append(QString::number(x) + "/");
129     tilePathString.append(QString::number(y));
130
131     return tilePathString;
132 }
133
134 int MapTile::tilesPerSide(int zoomLevel)
135 {
136     return (1 << zoomLevel);
137 }
138
139 int MapTile::zoomLevel()
140 {
141     qDebug() << __PRETTY_FUNCTION__;
142
143     return m_zoomLevel;
144 }