X-Git-Url: http://sigrok.org/gitweb/?a=blobdiff_plain;f=pv%2Fviews%2Ftrace%2Ftrace.hpp;h=741f346957735c92aa1f62f1dc37e5cc3c85aad4;hb=f6a93932056dab5e2f75207b65197b436d4141a5;hp=758b2e97c46e0142238b842e8b3d42c013fda747;hpb=1931b5f932cf068d073bc798f11dd21ede5389a2;p=pulseview.git
diff --git a/pv/views/trace/trace.hpp b/pv/views/trace/trace.hpp
index 758b2e97..741f3469 100644
--- a/pv/views/trace/trace.hpp
+++ b/pv/views/trace/trace.hpp
@@ -17,8 +17,8 @@
* along with this program; if not, see .
*/
-#ifndef PULSEVIEW_PV_VIEWS_TRACEVIEW_TRACE_HPP
-#define PULSEVIEW_PV_VIEWS_TRACEVIEW_TRACE_HPP
+#ifndef PULSEVIEW_PV_VIEWS_TRACE_TRACE_HPP
+#define PULSEVIEW_PV_VIEWS_TRACE_TRACE_HPP
#include
#include
@@ -91,9 +91,11 @@ private:
static const QColor BrightGrayBGColor;
static const QColor DarkGrayBGColor;
+ static const QColor ErrorBgColor;
protected:
- Trace(shared_ptr channel);
+ Trace(shared_ptr signal);
+ ~Trace();
public:
/**
@@ -101,6 +103,16 @@ public:
*/
shared_ptr base() const;
+ /**
+ * Returns true if the item may be selected.
+ */
+ virtual bool is_selectable(QPoint pos) const;
+
+ /**
+ * Returns true if the item may be dragged/moved.
+ */
+ virtual bool is_draggable(QPoint pos) const;
+
/**
* Configures the segment display mode to use.
*/
@@ -116,7 +128,16 @@ public:
*/
virtual void paint_label(QPainter &p, const QRect &rect, bool hover);
- virtual QMenu* create_context_menu(QWidget *parent);
+ /**
+ * Paints the signal's current error message text.
+ * @param p the QPainter to paint into.
+ * @param pp The painting parameters object to paint with.
+ */
+ virtual void paint_error(QPainter &p, const ViewItemPaintParams &pp);
+
+ virtual QMenu* create_header_context_menu(QWidget *parent);
+
+ virtual QMenu* create_view_context_menu(QWidget *parent, QPoint &click_pos);
pv::widgets::Popup* create_popup(QWidget *parent);
@@ -127,6 +148,14 @@ public:
*/
QRectF label_rect(const QRectF &rect) const;
+ /**
+ * Computes the outline rectangle of the viewport hit-box.
+ * @param pp The painting parameters object to paint with.
+ * @return Returns the rectangle of the hit-box.
+ * @remarks The default implementation returns an empty hit-box.
+ */
+ virtual QRectF hit_box_rect(const ViewItemPaintParams &pp) const;
+
void set_current_segment(const int segment);
int get_current_segment() const;
@@ -163,8 +192,8 @@ protected:
protected Q_SLOTS:
virtual void on_name_changed(const QString &text);
-
virtual void on_color_changed(const QColor &color);
+ virtual void on_error_message_changed(const QString &msg);
void on_popup_closed();
@@ -173,6 +202,8 @@ private Q_SLOTS:
void on_coloredit_changed(const QColor &color);
+ void on_create_marker_here() const;
+
protected:
shared_ptr base_;
QPen axis_pen_;
@@ -180,6 +211,8 @@ protected:
SegmentDisplayMode segment_display_mode_;
bool show_hover_marker_;
+ uint32_t context_menu_x_pos_;
+
/// The ID of the currently displayed segment
int current_segment_;
@@ -192,4 +225,4 @@ private:
} // namespace views
} // namespace pv
-#endif // PULSEVIEW_PV_VIEWS_TRACEVIEW_TRACE_HPP
+#endif // PULSEVIEW_PV_VIEWS_TRACE_TRACE_HPP