121 int GetnPoints(
void) {
return TrackPoints.size(); }
123 void SetVisible(
bool visible =
true) { m_bVisible = visible; }
127 void AddPointFinalized(
TrackPoint *pNewPoint);
128 TrackPoint *AddNewPoint(vector2D point, wxDateTime time);
130 void SetListed(
bool listed =
true) { m_bListed = listed; }
131 virtual bool IsRunning() {
return false; }
133 bool IsVisible() {
return m_bVisible; }
134 bool IsListed() {
return m_bListed; }
136 int GetCurrentTrackSeg() {
return m_CurrentTrackSeg; }
137 void SetCurrentTrackSeg(
int seg) { m_CurrentTrackSeg = seg; }
140 int Simplify(
double maxDelta);
141 Route *RouteFromTrack(wxGenericProgressDialog *pprog);
143 void ClearHighlights();
147 wxString GetName(
bool auto_if_empty =
false)
const {
148 if (!auto_if_empty || !m_TrackNameString.IsEmpty()) {
149 return m_TrackNameString;
151 return GetDateTime(_(
"(Unnamed Track)"));
154 void SetName(
const wxString name) { m_TrackNameString = name; }
158 wxString GetIsoDateTime(
159 const wxString label_for_invalid_date = _(
"(Unknown Date)"))
const;
163 wxString GetDateTime(
164 const wxString label_for_invalid_date = _(
"(Unknown Date)"))
const;
170 wxString m_TrackDescription;
172 wxString m_TrackStartString;
173 wxString m_TrackEndString;
183 int m_CurrentTrackSeg;
185 HyperlinkList *m_TrackHyperlinkList;
186 int m_HighlightedTrackPoint;
188 void Clone(
Track *psourcetrack,
int start_nPoint,
int end_nPoint,
189 const wxString &suffix);
192 void DouglasPeuckerReducer(std::vector<TrackPoint *> &list,
193 std::vector<bool> &keeplist,
int from,
int to,
196 double GetXTE(
double fm1Lat,
double fm1Lon,
double fm2Lat,
double fm2Lon,
197 double toLat,
double toLon);
199 std::vector<TrackPoint *> TrackPoints;
200 std::vector<std::vector<SubTrack> > SubTracks;
204 double ComputeScale(
int left,
int right);
205 void InsertSubTracks(LLBBox &box,
int level,
int pos);
217 wxString m_TrackNameString;