X-Git-Url: https://sigrok.org/gitweb/?p=pulseview.git;a=blobdiff_plain;f=pv%2Fview%2Fsignal.h;h=cce9f4694e237da6fd7abd8a99b8f2c3f566fc68;hp=8adee96f9ae765b07d296d7b8b504e260df59578;hb=0715fb8c638b53ac25590841fcbf3a1da3546b68;hpb=8d634081d8b0cc741dd34d8c646474ff6754aea8 diff --git a/pv/view/signal.h b/pv/view/signal.h index 8adee96f..cce9f469 100644 --- a/pv/view/signal.h +++ b/pv/view/signal.h @@ -18,110 +18,75 @@ * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA */ -#ifndef PULSEVIEW_PV_SIGNAL_H -#define PULSEVIEW_PV_SIGNAL_H +#ifndef PULSEVIEW_PV_VIEW_SIGNAL_H +#define PULSEVIEW_PV_VIEW_SIGNAL_H -#include +#include -#include -#include -#include -#include +#include +#include #include +#include "trace.h" + +struct sr_channel; + namespace pv { -namespace view { +namespace data { class SignalData; +} + +namespace device { +class DevInst; +} + +namespace view { -class Signal +class Signal : public Trace { -private: - static const int LabelHitPadding; + Q_OBJECT protected: - Signal(QString name); + Signal(std::shared_ptr dev_inst, + const sr_channel *const channel); public: - /** - * Gets the name of this signal. - */ - QString get_name() const; - /** * Sets the name of the signal. */ void set_name(QString name); - /** - * Get the colour of the signal. - */ - QColor get_colour() const; + virtual std::shared_ptr data() const = 0; /** - * Set the colour of the signal. + * Returns true if the trace is visible and enabled. */ - void set_colour(QColor colour); - - /** - * 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; - + bool enabled() const; - /** - * 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. - */ - virtual void paint_label(QPainter &p, const QRect &rect, - bool hover); + void enable(bool enable = true); - /** - * 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_channel* channel() 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); + QMenu* create_context_menu(QWidget *parent); - /** - * 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); + void delete_pressed(); -protected: - /** - * When painting into the rectangle, calculate the y - * offset of the zero point. - **/ - virtual int get_nominal_offset(const QRect &rect) const = 0; +private Q_SLOTS: + void on_disable(); protected: - QString _name; - QColor _colour; + std::shared_ptr _dev_inst; + const sr_channel *const _channel; - QSizeF _text_size; + QComboBox *_name_widget; + bool _updating_name_widget; }; } // namespace view } // namespace pv -#endif // PULSEVIEW_PV_SIGNAL_H +#endif // PULSEVIEW_PV_VIEW_SIGNAL_H