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
43
44
45
46
47
48
|
// Copyright (C) 2014 Canonical Ltd.
// SPDX-License-Identifier: LicenseRef-Qt-Commercial OR LGPL-3.0-only OR GPL-2.0-only OR GPL-3.0-only
#include "qgeomapreplymapbox.h"
#include <QtLocation/private/qgeotilespec_p.h>
QGeoMapReplyMapbox::QGeoMapReplyMapbox(QNetworkReply *reply, const QGeoTileSpec &spec, const QString &format, QObject *parent)
: QGeoTiledMapReply(spec, parent), m_format (format)
{
if (!reply) {
setError(UnknownError, QStringLiteral("Null reply"));
return;
}
connect(reply, &QNetworkReply::finished,
this, &QGeoMapReplyMapbox::networkReplyFinished);
connect(reply, &QNetworkReply::errorOccurred,
this, &QGeoMapReplyMapbox::networkReplyError);
connect(this, &QGeoTiledMapReply::aborted, reply, &QNetworkReply::abort);
connect(this, &QObject::destroyed, reply, &QObject::deleteLater);
}
QGeoMapReplyMapbox::~QGeoMapReplyMapbox()
{
}
void QGeoMapReplyMapbox::networkReplyFinished()
{
QNetworkReply *reply = static_cast<QNetworkReply *>(sender());
reply->deleteLater();
if (reply->error() != QNetworkReply::NoError)
return;
setMapImageData(reply->readAll());
setMapImageFormat(m_format);
setFinished(true);
}
void QGeoMapReplyMapbox::networkReplyError(QNetworkReply::NetworkError error)
{
QNetworkReply *reply = static_cast<QNetworkReply *>(sender());
reply->deleteLater();
if (error == QNetworkReply::OperationCanceledError)
setFinished(true);
else
setError(QGeoTiledMapReply::CommunicationError, reply->errorString());
}
|