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
qgeocoordinate.h
Go to the documentation of this file.
1// Copyright (C) 2016 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
4#ifndef QGEOCOORDINATE_H
5#define QGEOCOORDINATE_H
6
7#include <QtCore/QMetaType>
8#include <QtCore/QString>
9#include <QtCore/QSharedDataPointer>
10#include <QtCore/QDebug>
11#include <QtPositioning/qpositioningglobal.h>
12
13QT_BEGIN_NAMESPACE
14
15class QDebug;
16class QDataStream;
17
18class QGeoCoordinatePrivate;
19QT_DECLARE_QSDP_SPECIALIZATION_DTOR_WITH_EXPORT(QGeoCoordinatePrivate, Q_POSITIONING_EXPORT)
20
21class Q_POSITIONING_EXPORT QGeoCoordinate
22{
23 Q_GADGET
24 Q_ENUMS(CoordinateFormat)
25
26 Q_PROPERTY(double latitude READ latitude WRITE setLatitude)
27 Q_PROPERTY(double longitude READ longitude WRITE setLongitude)
28 Q_PROPERTY(double altitude READ altitude WRITE setAltitude)
29 Q_PROPERTY(bool isValid READ isValid)
30
31public:
32
33 enum CoordinateType {
34 InvalidCoordinate,
35 Coordinate2D,
36 Coordinate3D
37 };
38
39 enum CoordinateFormat {
40 Degrees,
41 DegreesWithHemisphere,
42 DegreesMinutes,
43 DegreesMinutesWithHemisphere,
44 DegreesMinutesSeconds,
45 DegreesMinutesSecondsWithHemisphere
46 };
47
48 QGeoCoordinate();
49 QGeoCoordinate(double latitude, double longitude);
50 QGeoCoordinate(double latitude, double longitude, double altitude);
51 QGeoCoordinate(const QGeoCoordinate &other);
52 QGeoCoordinate(QGeoCoordinate &&other) noexcept = default;
53 ~QGeoCoordinate();
54
55 QGeoCoordinate &operator=(const QGeoCoordinate &other);
56 QT_MOVE_ASSIGNMENT_OPERATOR_IMPL_VIA_PURE_SWAP(QGeoCoordinate)
57
58 void swap(QGeoCoordinate &other) noexcept { d.swap(other.d); }
59
60 friend bool operator==(const QGeoCoordinate &lhs, const QGeoCoordinate &rhs)
61 {
62 return equals(lhs, rhs);
63 }
64 friend bool operator!=(const QGeoCoordinate &lhs, const QGeoCoordinate &rhs)
65 {
66 return !equals(lhs, rhs);
67 }
68
69 bool isValid() const;
70 CoordinateType type() const;
71
72 void setLatitude(double latitude);
73 double latitude() const;
74
75 void setLongitude(double longitude);
76 double longitude() const;
77
78 void setAltitude(double altitude);
79 double altitude() const;
80
81 Q_INVOKABLE qreal distanceTo(const QGeoCoordinate &other) const;
82 Q_INVOKABLE qreal azimuthTo(const QGeoCoordinate &other) const;
83
84 Q_INVOKABLE QGeoCoordinate atDistanceAndAzimuth(qreal distance, qreal azimuth, qreal distanceUp = 0.0) const;
85
86 Q_INVOKABLE QString toString(CoordinateFormat format = DegreesMinutesSecondsWithHemisphere) const;
87
88private:
89 static bool equals(const QGeoCoordinate &lhs, const QGeoCoordinate &rhs);
90 QGeoCoordinate(QGeoCoordinatePrivate &dd);
91 QSharedDataPointer<QGeoCoordinatePrivate> d;
92 friend class QGeoCoordinatePrivate;
93 friend class QQuickGeoCoordinateAnimation;
94#ifndef QT_NO_DEBUG_STREAM
95 friend QDebug operator<<(QDebug dbg, const QGeoCoordinate &coord)
96 {
97 return debugStreaming(dbg, coord);
98 }
99 static QDebug debugStreaming(QDebug dbg, const QGeoCoordinate &coord);
100#endif
101#ifndef QT_NO_DATASTREAM
102 friend QDataStream &operator<<(QDataStream &stream, const QGeoCoordinate &coordinate)
103 {
104 return dataStreamOut(stream, coordinate);
105 }
106 friend QDataStream &operator>>(QDataStream &stream, QGeoCoordinate &coordinate)
107 {
108 return dataStreamIn(stream, coordinate);
109 }
110 static QDataStream &dataStreamOut(QDataStream &stream, const QGeoCoordinate &coordinate);
111 static QDataStream &dataStreamIn(QDataStream &stream, QGeoCoordinate &coordinate);
112#endif
113};
114
116
117
118Q_POSITIONING_EXPORT size_t qHash(const QGeoCoordinate &coordinate, size_t seed = 0);
119
120
121QT_END_NAMESPACE
122
123QT_DECL_METATYPE_EXTERN(QGeoCoordinate, Q_POSITIONING_EXPORT)
124
125#endif
\inmodule QtPositioning
Definition qgeoaddress.h:18
\inmodule QtPositioning