-
-
Notifications
You must be signed in to change notification settings - Fork 991
/
track.hpp
89 lines (66 loc) · 2.51 KB
/
track.hpp
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
#pragma once
#include "kml/types.hpp"
#include "drape_frontend/user_marks_provider.hpp"
#include <string>
class Track : public df::UserLineMark
{
using Base = df::UserLineMark;
public:
Track(kml::TrackData && data, bool interactive);
kml::MarkGroupId GetGroupId() const override { return m_groupID; }
bool IsDirty() const override { return m_isDirty; }
void ResetChanges() const override { m_isDirty = false; }
kml::TrackData const & GetData() const { return m_data; }
std::string GetName() const;
void SetName(std::string const & name);
m2::RectD GetLimitRect() const;
double GetLengthMeters() const;
bool IsInteractive() const;
std::pair<m2::PointD, double> GetCenterPoint() const;
struct TrackSelectionInfo
{
TrackSelectionInfo() = default;
TrackSelectionInfo(kml::TrackId trackId, m2::PointD const & trackPoint, double distFromBegM)
: m_trackId(trackId)
, m_trackPoint(trackPoint)
, m_distFromBegM(distFromBegM)
{}
kml::TrackId m_trackId = kml::kInvalidTrackId;
m2::PointD m_trackPoint;
// Distance in meters from the beginning to m_trackPoint.
double m_distFromBegM;
// Mercator square distance, used to select nearest track.
double m_squareDist = std::numeric_limits<double>::max();
};
void UpdateSelectionInfo(m2::RectD const & touchRect, TrackSelectionInfo & info) const;
int GetMinZoom() const override { return 1; }
df::DepthLayer GetDepthLayer() const override;
size_t GetLayerCount() const override;
dp::Color GetColor(size_t layerIndex) const override;
void SetColor(dp::Color color);
float GetWidth(size_t layerIndex) const override;
float GetDepth(size_t layerIndex) const override;
void ForEachGeometry(GeometryFnT && fn) const override;
void Attach(kml::MarkGroupId groupId);
void Detach();
bool GetPoint(double distanceInMeters, m2::PointD & pt) const;
/// @name This functions are valid only for the single line geometry.
/// @{
kml::MultiGeometry::LineT const & GetSingleGeometry() const;
private:
std::vector<double> GetLengthsImpl() const;
/// @}
m2::RectD GetLimitRectImpl() const;
void CacheDataForInteraction();
bool HasAltitudes() const;
double GetLengthMetersImpl(kml::MultiGeometry::LineT const & line, size_t ptIdx) const;
kml::TrackData m_data;
kml::MarkGroupId m_groupID = kml::kInvalidMarkGroupId;
struct InteractionData
{
std::vector<double> m_lengths;
m2::RectD m_limitRect;
};
std::optional<InteractionData> m_interactionData;
mutable bool m_isDirty = true;
};