Qt
Internal/Contributor docs for the Qt SDK. Note: These are NOT official API docs; those are found at https://doc.qt.io/
Loading...
Searching...
No Matches
qgeotiledmappingmanagerengine.cpp
Go to the documentation of this file.
1// Copyright (C) 2015 The Qt Company Ltd.
2// SPDX-License-Identifier: LicenseRef-Qt-Commercial OR LGPL-3.0-only OR GPL-2.0-only OR GPL-3.0-only
3
7
8
12#include "qgeotilespec_p.h"
13
14#include <QTimer>
15#include <QLocale>
16#include <QDir>
17#include <QStandardPaths>
18
20
21QGeoTiledMappingManagerEngine::QGeoTiledMappingManagerEngine(QObject *parent)
22 : QGeoMappingManagerEngine(parent),
23 d_ptr(new QGeoTiledMappingManagerEnginePrivate)
24{
25}
26
27/*!
28 Destroys this mapping manager.
29*/
30QGeoTiledMappingManagerEngine::~QGeoTiledMappingManagerEngine()
31{
32 delete d_ptr;
33}
34
35/*!
36 Sets the tile fetcher. Takes ownership of the QObject.
37*/
38void QGeoTiledMappingManagerEngine::setTileFetcher(QGeoTileFetcher *fetcher)
39{
40 Q_D(QGeoTiledMappingManagerEngine);
41
42 if (d->fetcher_)
43 d->fetcher_->deleteLater();
44 fetcher->setParent(this);
45 d->fetcher_ = fetcher;
46
47 qRegisterMetaType<QGeoTileSpec>();
48
49 connect(d->fetcher_, &QGeoTileFetcher::tileFinished,
50 this, &QGeoTiledMappingManagerEngine::engineTileFinished,
51 Qt::QueuedConnection);
52 connect(d->fetcher_, &QGeoTileFetcher::tileError,
53 this, &QGeoTiledMappingManagerEngine::engineTileError,
54 Qt::QueuedConnection);
55
56 engineInitialized();
57}
58
59QGeoTileFetcher *QGeoTiledMappingManagerEngine::tileFetcher()
60{
61 Q_D(QGeoTiledMappingManagerEngine);
62 return d->fetcher_;
63}
64
65QGeoMap *QGeoTiledMappingManagerEngine::createMap()
66{
67 return NULL;
68}
69
70void QGeoTiledMappingManagerEngine::releaseMap(QGeoTiledMap *map)
71{
72 d_ptr->mapHash_.remove(map);
73
74 QHash<QGeoTileSpec, QSet<QGeoTiledMap *> > newTileHash = d_ptr->tileHash_;
75 typedef QHash<QGeoTileSpec, QSet<QGeoTiledMap *> >::const_iterator h_iter;
76 h_iter hi = d_ptr->tileHash_.constBegin();
77 h_iter hend = d_ptr->tileHash_.constEnd();
78 for (; hi != hend; ++hi) {
79 QSet<QGeoTiledMap *> maps = hi.value();
80 if (maps.contains(map)) {
81 maps.remove(map);
82 if (maps.isEmpty())
83 newTileHash.remove(hi.key());
84 else
85 newTileHash.insert(hi.key(), maps);
86 }
87 }
88 d_ptr->tileHash_ = newTileHash;
89}
90
91void QGeoTiledMappingManagerEngine::updateTileRequests(QGeoTiledMap *map,
92 const QSet<QGeoTileSpec> &tilesAdded,
93 const QSet<QGeoTileSpec> &tilesRemoved)
94{
95 Q_D(QGeoTiledMappingManagerEngine);
96
97 typedef QSet<QGeoTileSpec>::const_iterator tile_iter;
98
99 // add and remove tiles from tileset for this map
100
101 QSet<QGeoTileSpec> oldTiles = d->mapHash_.value(map);
102
103 tile_iter rem = tilesRemoved.constBegin();
104 tile_iter remEnd = tilesRemoved.constEnd();
105 for (; rem != remEnd; ++rem) {
106 oldTiles.remove(*rem);
107 }
108
109 tile_iter add = tilesAdded.constBegin();
110 tile_iter addEnd = tilesAdded.constEnd();
111 for (; add != addEnd; ++add) {
112 oldTiles.insert(*add);
113 }
114
115 d->mapHash_.insert(map, oldTiles);
116
117 // add and remove map from mapset for the tiles
118
119 QSet<QGeoTileSpec> reqTiles;
120 QSet<QGeoTileSpec> cancelTiles;
121
122 rem = tilesRemoved.constBegin();
123 for (; rem != remEnd; ++rem) {
124 QSet<QGeoTiledMap *> mapSet = d->tileHash_.value(*rem);
125 mapSet.remove(map);
126 if (mapSet.isEmpty()) {
127 cancelTiles.insert(*rem);
128 d->tileHash_.remove(*rem);
129 } else {
130 d->tileHash_.insert(*rem, mapSet);
131 }
132 }
133
134 add = tilesAdded.constBegin();
135 for (; add != addEnd; ++add) {
136 QSet<QGeoTiledMap *> mapSet = d->tileHash_.value(*add);
137 if (mapSet.isEmpty()) {
138 reqTiles.insert(*add);
139 }
140 mapSet.insert(map);
141 d->tileHash_.insert(*add, mapSet);
142 }
143
144 cancelTiles -= reqTiles;
145
146 QMetaObject::invokeMethod(d->fetcher_, "updateTileRequests",
147 Qt::QueuedConnection,
148 Q_ARG(QSet<QGeoTileSpec>, reqTiles),
149 Q_ARG(QSet<QGeoTileSpec>, cancelTiles));
150}
151
152void QGeoTiledMappingManagerEngine::engineTileFinished(const QGeoTileSpec &spec, const QByteArray &bytes, const QString &format)
153{
154 Q_D(QGeoTiledMappingManagerEngine);
155
156 QSet<QGeoTiledMap *> maps = d->tileHash_.value(spec);
157
158 typedef QSet<QGeoTiledMap *>::const_iterator map_iter;
159
160 map_iter map = maps.constBegin();
161 map_iter mapEnd = maps.constEnd();
162 for (; map != mapEnd; ++map) {
163 QSet<QGeoTileSpec> tileSet = d->mapHash_.value(*map);
164 tileSet.remove(spec);
165 if (tileSet.isEmpty())
166 d->mapHash_.remove(*map);
167 else
168 d->mapHash_.insert(*map, tileSet);
169 }
170
171 d->tileHash_.remove(spec);
172 tileCache()->insert(spec, bytes, format, d->cacheHint_);
173
174 map = maps.constBegin();
175 mapEnd = maps.constEnd();
176 for (; map != mapEnd; ++map) {
177 (*map)->requestManager()->tileFetched(spec);
178 }
179}
180
181void QGeoTiledMappingManagerEngine::engineTileError(const QGeoTileSpec &spec, const QString &errorString)
182{
183 Q_D(QGeoTiledMappingManagerEngine);
184
185 QSet<QGeoTiledMap *> maps = d->tileHash_.value(spec);
186 typedef QSet<QGeoTiledMap *>::const_iterator map_iter;
187 map_iter map = maps.constBegin();
188 map_iter mapEnd = maps.constEnd();
189 for (; map != mapEnd; ++map) {
190 QSet<QGeoTileSpec> tileSet = d->mapHash_.value(*map);
191
192 tileSet.remove(spec);
193 if (tileSet.isEmpty())
194 d->mapHash_.remove(*map);
195 else
196 d->mapHash_.insert(*map, tileSet);
197 }
198 d->tileHash_.remove(spec);
199
200 for (map = maps.constBegin(); map != mapEnd; ++map) {
201 (*map)->requestManager()->tileError(spec, errorString);
202 }
203
204 emit tileError(spec, errorString);
205}
206
207void QGeoTiledMappingManagerEngine::setTileSize(const QSize &tileSize)
208{
209 Q_D(QGeoTiledMappingManagerEngine);
210 d->tileSize_ = tileSize;
211}
212
213void QGeoTiledMappingManagerEngine::setTileVersion(int version)
214{
215 Q_D(QGeoTiledMappingManagerEngine);
216 if (d->m_tileVersion != version) {
217 d->m_tileVersion = version;
218 emit tileVersionChanged();
219 }
220}
221
222QSize QGeoTiledMappingManagerEngine::tileSize() const
223{
224 Q_D(const QGeoTiledMappingManagerEngine);
225 return d->tileSize_;
226}
227
228int QGeoTiledMappingManagerEngine::tileVersion() const
229{
230 Q_D(const QGeoTiledMappingManagerEngine);
231 return d->m_tileVersion;
232}
233
234QAbstractGeoTileCache::CacheAreas QGeoTiledMappingManagerEngine::cacheHint() const
235{
236 Q_D(const QGeoTiledMappingManagerEngine);
237 return d->cacheHint_;
238}
239
240void QGeoTiledMappingManagerEngine::setCacheHint(QAbstractGeoTileCache::CacheAreas cacheHint)
241{
242 Q_D(QGeoTiledMappingManagerEngine);
243 d->cacheHint_ = cacheHint;
244}
245
246/*!
247 Sets the tile cache. Takes ownership of the QObject.
248*/
249void QGeoTiledMappingManagerEngine::setTileCache(QAbstractGeoTileCache *cache)
250{
251 Q_D(QGeoTiledMappingManagerEngine);
252 Q_ASSERT_X(!d->tileCache_, Q_FUNC_INFO, "This should be called only once");
253 cache->setParent(this);
254 d->tileCache_.reset(cache);
255 d->tileCache_->init();
256}
257
258QAbstractGeoTileCache *QGeoTiledMappingManagerEngine::tileCache()
259{
260 Q_D(QGeoTiledMappingManagerEngine);
261 if (!d->tileCache_) {
262 QString cacheDirectory;
263 if (!managerName().isEmpty())
264 cacheDirectory = QAbstractGeoTileCache::baseLocationCacheDirectory() + managerName();
265 d->tileCache_.reset(new QGeoFileTileCache(cacheDirectory));
266 d->tileCache_->init();
267 }
268 return d->tileCache_.get();
269}
270
271QSharedPointer<QGeoTileTexture> QGeoTiledMappingManagerEngine::getTileTexture(const QGeoTileSpec &spec)
272{
273 return d_ptr->tileCache_->get(spec);
274}
275
276QT_END_NAMESPACE