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
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128 | /* ============================================================
*
* This file is a part of digiKam project
* https://www.digikam.org
*
* Date : 2023-05-15
* Description : geolocation engine based on Marble.
* (c) 2007-2022 Marble Team
* https://invent.kde.org/education/marble/-/raw/master/data/credits_authors.html
*
* SPDX-FileCopyrightText: 2023-2026 by Gilles Caulier <caulier dot gilles at gmail dot com>
*
* SPDX-License-Identifier: LGPL-2.1-or-later
*
* ============================================================ */
#include "GeoDataPoint.h"
#include "GeoDataPoint_p.h"
// Local includes
#include "MarbleGlobal.h"
#include "GeoDataTypes.h"
#include "GeoDataLatLonAltBox.h"
#include "digikam_debug.h"
namespace Marble
{
GeoDataPoint::GeoDataPoint(qreal lon, qreal lat, qreal alt,
GeoDataCoordinates::Unit unit)
: GeoDataGeometry(new GeoDataPointPrivate)
{
Q_D(GeoDataPoint);
d->m_coordinates = GeoDataCoordinates(lon, lat, alt, unit);
d->m_latLonAltBox = GeoDataLatLonAltBox(d->m_coordinates);
}
GeoDataPoint::GeoDataPoint(const GeoDataPoint& other)
: GeoDataGeometry(other)
{
Q_D(GeoDataPoint);
const GeoDataPointPrivate* const otherD = other.d_func();
d->m_coordinates = otherD->m_coordinates;
d->m_latLonAltBox = otherD->m_latLonAltBox;
}
GeoDataPoint::GeoDataPoint(const GeoDataCoordinates& other)
: GeoDataGeometry(new GeoDataPointPrivate)
{
Q_D(GeoDataPoint);
d->m_coordinates = other;
d->m_latLonAltBox = GeoDataLatLonAltBox(d->m_coordinates);
}
GeoDataPoint::GeoDataPoint()
: GeoDataGeometry(new GeoDataPointPrivate)
{
// nothing to do
}
GeoDataPoint::~GeoDataPoint()
{
// nothing to do
}
EnumGeometryId GeoDataPoint::geometryId() const
{
return GeoDataPointId;
}
GeoDataGeometry* GeoDataPoint::copy() const
{
return new GeoDataPoint(*this);
}
bool GeoDataPoint::operator==(const GeoDataPoint& other) const
{
return equals(other) &&
coordinates() == other.coordinates();
}
bool GeoDataPoint::operator!=(const GeoDataPoint& other) const
{
return !this->operator==(other);
}
void GeoDataPoint::setCoordinates(const GeoDataCoordinates& coordinates)<--- Shadow argument
{
detach();
Q_D(GeoDataPoint);
d->m_coordinates = coordinates;
d->m_latLonAltBox = GeoDataLatLonAltBox(d->m_coordinates);
}
const GeoDataCoordinates& GeoDataPoint::coordinates() const
{
Q_D(const GeoDataPoint);
return d->m_coordinates;
}
const char* GeoDataPoint::nodeType() const
{
return GeoDataTypes::GeoDataPointType;
}
void GeoDataPoint::detach()
{
GeoDataGeometry::detach();
}
void GeoDataPoint::pack(QDataStream& stream) const
{
Q_D(const GeoDataPoint);
d->m_coordinates.pack(stream);
// TODO: what about m_latLonAltBox and base class?
}
void GeoDataPoint::unpack(QDataStream& stream)
{
Q_D(GeoDataPoint);
d->m_coordinates.unpack(stream);
// TODO: what about m_latLonAltBox and base class?
}
} // namespace Marble
|