X-Git-Url: https://sigrok.org/gitweb/?a=blobdiff_plain;f=pv%2Fview%2Fsignal.h;h=aff8c4c427498e54c6eb00dc94dfc05e4c3e4169;hb=0c0218fd70bde15f2ccd20f39f6d3ddddd3e1691;hp=72019032e06a74e221f92c4d9ea0ddf57fa968e6;hpb=1b1ec774978b65209ce2b454cbf81da499b797d2;p=pulseview.git diff --git a/pv/view/signal.h b/pv/view/signal.h index 72019032..aff8c4c4 100644 --- a/pv/view/signal.h +++ b/pv/view/signal.h @@ -21,15 +21,15 @@ #ifndef PULSEVIEW_PV_SIGNAL_H #define PULSEVIEW_PV_SIGNAL_H -#include - -#include -#include -#include -#include +#include +#include #include +#include + +#include "trace.h" + namespace pv { namespace data { @@ -38,20 +38,15 @@ class SignalData; namespace view { -class Signal +class Signal : public Trace { -private: - static const int LabelHitPadding; - static const int LabelHighlightRadius; + Q_OBJECT protected: - Signal(QString name); + Signal(pv::SigSession &session, const sr_probe *const probe); public: - /** - * Gets the name of this signal. - */ - QString get_name() const; + virtual void init_context_bar_actions(QWidget *parent); /** * Sets the name of the signal. @@ -59,93 +54,24 @@ public: void set_name(QString name); /** - * Get the colour of the signal. - */ - QColor get_colour() const; - - /** - * Set the colour of the signal. - */ - void set_colour(QColor colour); - - /** - * Gets the vertical layout offset of this signal. - */ - int get_v_offset() const; - - /** - * Sets the vertical layout offset of this signal. - */ - void set_v_offset(int v_offset); - - /** - * Returns true if the signal has been selected by the user. - */ - bool selected() const; - - /** - * Selects or deselects the signal. - */ - void select(bool select = true); - - /** - * Paints the signal with a QPainter - * @param p the QPainter to paint into. - * @param rect the rectangular area to draw the trace into. - * @param scale the scale in seconds per pixel. - * @param offset the time to show at the left hand edge of - * the view in seconds. - **/ - virtual void paint(QPainter &p, const QRect &rect, double scale, - double offset) = 0; - - - /** - * Paints the signal label into a QGLWidget. - * @param p the QPainter to paint into. - * @param rect the rectangular area to draw the label into. - * @param hover true if the label is being hovered over by the mouse. + * Returns true if the trace is visible and enabled. */ - virtual void paint_label(QPainter &p, const QRect &rect, - bool hover); + bool enabled() const; - /** - * Determines if a point is in the header label rect. - * @param rect the rectangular area to draw the label into. - * @param point the point to test. - */ - bool pt_in_label_rect(const QRect &rect, const QPoint &point); + const sr_probe* probe() const; private: + virtual void populate_popup_form(QWidget *parent, QFormLayout *form); - /** - * Computes an caches the size of the label text. - */ - void compute_text_size(QPainter &p); - - /** - * Computes the outline rectangle of a label. - * @param p the QPainter to lay out text with. - * @param rect The rectangle of the signal header. - * @return Returns the rectangle of the signal label. - */ - QRectF get_label_rect(const QRect &rect); +private slots: + void on_text_changed(const QString &text); protected: - /** - * When painting into the rectangle, calculate the y - * offset of the zero point. - **/ - virtual int get_nominal_offset(const QRect &rect) const = 0; - -protected: - QString _name; - QColor _colour; - int _v_offset; - - bool _selected; + const sr_probe *const _probe; - QSizeF _text_size; + QWidgetAction *_name_action; + QComboBox *_name_widget; + bool _updating_name_widget; }; } // namespace view