projects
/
pulseview.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
Untangle the time formatting functions a bit
[pulseview.git]
/
pv
/
view
/
timemarker.hpp
diff --git
a/pv/view/timemarker.hpp
b/pv/view/timemarker.hpp
index 0103fb041dfbdbede975ee4753de759c5d89546b..371b6e4a54ce607edbdfd7dc3ead53c55e9ae447 100644
(file)
--- a/
pv/view/timemarker.hpp
+++ b/
pv/view/timemarker.hpp
@@
-18,8
+18,8
@@
* Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
*/
* Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
*/
-#ifndef PULSEVIEW_PV_VIEW_MARKER_H
-#define PULSEVIEW_PV_VIEW_MARKER_H
+#ifndef PULSEVIEW_PV_VIEW_MARKER_H
PP
+#define PULSEVIEW_PV_VIEW_MARKER_H
PP
#include <QColor>
#include <QDoubleSpinBox>
#include <QColor>
#include <QDoubleSpinBox>
@@
-27,20
+27,27
@@
#include <QRectF>
#include <QWidgetAction>
#include <QRectF>
#include <QWidgetAction>
-#include "
selectabl
eitem.hpp"
+#include "
tim
eitem.hpp"
class QPainter;
class QRect;
namespace pv {
class QPainter;
class QRect;
namespace pv {
+namespace widgets {
+ class TimestampSpinBox;
+}
+
namespace view {
class View;
namespace view {
class View;
-class TimeMarker : public
Selectabl
eItem
+class TimeMarker : public
Tim
eItem
{
Q_OBJECT
{
Q_OBJECT
+public:
+ static const int ArrowSize;
+
protected:
/**
* Constructor.
protected:
/**
* Constructor.
@@
-48,71
+55,79
@@
protected:
* @param colour A reference to the colour of this cursor.
* @param time The time to set the flag to.
*/
* @param colour A reference to the colour of this cursor.
* @param time The time to set the flag to.
*/
- TimeMarker(View &view, const QColor &colour,
double
time);
+ TimeMarker(View &view, const QColor &colour,
const pv::util::Timestamp&
time);
public:
/**
* Gets the time of the marker.
*/
public:
/**
* Gets the time of the marker.
*/
-
double
time() const;
+
const pv::util::Timestamp&
time() const;
/**
* Sets the time of the marker.
*/
/**
* Sets the time of the marker.
*/
- void set_time(
double time)
;
+ void set_time(
const pv::util::Timestamp& time) override
;
float get_x() const;
/**
float get_x() const;
/**
- * Gets the drag point of the row item.
+ * Gets the arrow-tip point of the time marker.
+ * @param rect the rectangle of the ruler area.
*/
*/
- QPoint point() const;
+ QPoint point(
const QRect &rect
) const;
/**
/**
- *
Paints the marker to the viewport
.
- * @param
p The painter to draw with
.
- * @
param rect The rectangle of the viewport client area
.
+ *
Computes the outline rectangle of a label
.
+ * @param
rect the rectangle of the header area
.
+ * @
return Returns the rectangle of the signal label
.
*/
*/
-
virtual void paint(QPainter &p, const QRect &rect)
;
+
QRectF label_rect(const QRectF &rect) const
;
/**
/**
- *
Gets the marker label rectangle
.
- * @param rect
The rectangle of the ruler clien
t area.
- * @return Returns the
label rectangle
.
+ *
Computes the outline rectangle of the viewport hit-box
.
+ * @param rect
the rectangle of the viewpor
t area.
+ * @return Returns the
rectangle of the hit-box
.
*/
*/
- virtual QRectF get_label_rect(const QRect &rect) const = 0;
+ QRectF hit_box_rect(const QRectF &rect) const;
+
+ /**
+ * Gets the text to show in the marker.
+ */
+ virtual QString get_text() const = 0;
/**
* Paints the marker's label to the ruler.
* @param p The painter to draw with.
* @param rect The rectangle of the ruler client area.
/**
* Paints the marker's label to the ruler.
* @param p The painter to draw with.
* @param rect The rectangle of the ruler client area.
- * @param
prefix The SI prefix to paint time value with
.
+ * @param
hover true if the label is being hovered over by the mouse
.
*/
*/
- virtual void paint_label(QPainter &p, const QRect &rect,
- unsigned int prefix) = 0;
+ void paint_label(QPainter &p, const QRect &rect, bool hover);
- pv::widgets::Popup* create_popup(QWidget *parent);
+ /**
+ * Paints the foreground layer of the item with a QPainter
+ * @param p the QPainter to paint into.
+ * @param pp the painting parameters object to paint with.
+ **/
+ void paint_fore(QPainter &p, const ViewItemPaintParams &pp);
-private Q_SLOTS:
- void on_value_changed(double value);
+ virtual pv::widgets::Popup* create_popup(QWidget *parent);
-
Q_SIGNAL
S:
- void
time_changed(
);
+
private Q_SLOT
S:
+ void
on_value_changed(const pv::util::Timestamp& value
);
protected:
protected:
- View &view_;
const QColor &colour_;
const QColor &colour_;
-
double
time_;
+
pv::util::Timestamp
time_;
QSizeF text_size_;
QWidgetAction *value_action_;
QSizeF text_size_;
QWidgetAction *value_action_;
-
QDouble
SpinBox *value_widget_;
+
pv::widgets::Timestamp
SpinBox *value_widget_;
bool updating_value_widget_;
};
} // namespace view
} // namespace pv
bool updating_value_widget_;
};
} // namespace view
} // namespace pv
-#endif // PULSEVIEW_PV_VIEW_MARKER_H
+#endif // PULSEVIEW_PV_VIEW_MARKER_H
PP