1
0
mirror of https://github.com/tumic0/GPXSee.git synced 2024-10-07 07:13:21 +02:00
GPXSee/src/trackitem.cpp

54 lines
1.1 KiB
C++
Raw Normal View History

#include <QApplication>
#include <QCursor>
2016-08-09 01:16:19 +02:00
#include <QPainter>
#include "ll.h"
#include "misc.h"
2016-08-02 00:28:56 +02:00
#include "tooltip.h"
#include "trackitem.h"
QString TrackItem::toolTip()
{
2016-08-02 00:28:56 +02:00
ToolTip tt;
tt.insert(qApp->translate("TrackItem", "Distance"),
::distance(_distance, _units));
2016-08-02 00:28:56 +02:00
if (_time > 0)
tt.insert(qApp->translate("TrackItem", "Time"), ::timeSpan(_time));
2016-08-02 00:28:56 +02:00
if (!_date.isNull())
tt.insert(qApp->translate("TrackItem", "Date"),
_date.toString(Qt::SystemLocaleShortDate));
2016-08-02 00:28:56 +02:00
return tt.toString();
}
2016-08-02 00:28:56 +02:00
TrackItem::TrackItem(const Track &track, QGraphicsItem *parent)
2016-09-19 00:56:10 +02:00
: PathItem(parent)
{
2016-08-15 08:20:27 +02:00
const QVector<Trackpoint> &t = track.track();
Q_ASSERT(t.count() >= 2);
2016-08-15 08:20:27 +02:00
const QPointF &p = t.at(0).coordinates();
2016-08-09 01:16:19 +02:00
_path.moveTo(ll2mercator(QPointF(p.x(), -p.y())));
for (int i = 1; i < t.size(); i++) {
2016-08-15 08:20:27 +02:00
const QPointF &p = t.at(i).coordinates();
2016-08-09 01:16:19 +02:00
_path.lineTo(ll2mercator(QPointF(p.x(), -p.y())));
}
2016-09-26 21:01:58 +02:00
updateShape();
_date = track.date();
_distance = track.distance();
_time = track.time();
2016-08-09 01:16:19 +02:00
_marker->setPos(_path.pointAtPercent(0));
2016-09-26 21:01:58 +02:00
setToolTip(toolTip());
}
void TrackItem::setUnits(enum Units units)
{
2016-09-26 21:01:58 +02:00
PathItem::setUnits(units);
setToolTip(toolTip());
}