X-Git-Url: https://sigrok.org/gitweb/?a=blobdiff_plain;f=pv%2Fview%2Fheader.h;h=808de5d5c966aed905da5f2e06a88d5714e3c80a;hb=f0c0b38f812bfbb2bb1978d40e2ce93f1da3f89d;hp=22e8e4dbd2c3dbba58908d6a7a7a1208339bdfb0;hpb=9e40e83daf6a2851f4883468a4237849f984b336;p=pulseview.git diff --git a/pv/view/header.h b/pv/view/header.h index 22e8e4db..808de5d5 100644 --- a/pv/view/header.h +++ b/pv/view/header.h @@ -21,10 +21,8 @@ #ifndef PULSEVIEW_PV_VIEW_HEADER_H #define PULSEVIEW_PV_VIEW_HEADER_H -#include -#include - #include +#include #include #include "marginwidget.h" @@ -32,28 +30,45 @@ namespace pv { namespace view { -class Signal; +class RowItem; class View; class Header : public MarginWidget { Q_OBJECT +private: + static const int Padding; + public: Header(View &parent); + QSize sizeHint() const; + + /** + * The horizontal offset, relative to the left edge of the widget, + * where the arrows of the trace labels end. + */ + static const int BaselineOffset; + + void signals_updated(); + private: - boost::shared_ptr get_mouse_over_signal( + std::shared_ptr get_mouse_over_row_item( const QPoint &pt); void clear_selection(); + void show_popup(const std::shared_ptr &item); + private: void paintEvent(QPaintEvent *event); private: + void mouseLeftPressEvent(QMouseEvent *event); void mousePressEvent(QMouseEvent * event); + void mouseLeftReleaseEvent(QMouseEvent *event); void mouseReleaseEvent(QMouseEvent *event); void mouseMoveEvent(QMouseEvent *event); @@ -62,28 +77,21 @@ private: void contextMenuEvent(QContextMenuEvent *event); -private slots: - void on_signals_changed(); - - void on_action_set_name_triggered(); - - void on_action_set_colour_triggered(); + void keyPressEvent(QKeyEvent *e); +private Q_SLOTS: void on_signals_moved(); -signals: + void on_trace_changed(); + +Q_SIGNALS: void signals_moved(); private: QPoint _mouse_point; QPoint _mouse_down_point; - - std::list, int> > - _drag_sigs; - - boost::shared_ptr _context_signal; - QAction *_action_set_name; - QAction *_action_set_colour; + std::shared_ptr _mouse_down_item; + bool _dragging; }; } // namespace view