X-Git-Url: https://sigrok.org/gitweb/?p=pulseview.git;a=blobdiff_plain;f=pv%2Fview%2Fheader.h;h=22e8e4dbd2c3dbba58908d6a7a7a1208339bdfb0;hp=f7979c6d2ea2f70b60263ed888971fe5d175bfe5;hb=9e40e83daf6a2851f4883468a4237849f984b336;hpb=b3f22de060b73f15ad3eb2dabee04a0b4f5d947e diff --git a/pv/view/header.h b/pv/view/header.h index f7979c6d..22e8e4db 100644 --- a/pv/view/header.h +++ b/pv/view/header.h @@ -18,31 +18,75 @@ * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA */ -#ifndef PV_VIEW_HEADER_H -#define PV_VIEW_HEADER_H +#ifndef PULSEVIEW_PV_VIEW_HEADER_H +#define PULSEVIEW_PV_VIEW_HEADER_H -#include +#include +#include + +#include +#include + +#include "marginwidget.h" namespace pv { namespace view { +class Signal; class View; -class Header : public QWidget +class Header : public MarginWidget { Q_OBJECT public: Header(View &parent); +private: + boost::shared_ptr get_mouse_over_signal( + const QPoint &pt); + + void clear_selection(); + private: void paintEvent(QPaintEvent *event); private: - View &_view; + void mousePressEvent(QMouseEvent * event); + + void mouseReleaseEvent(QMouseEvent *event); + + void mouseMoveEvent(QMouseEvent *event); + + void leaveEvent(QEvent *event); + + void contextMenuEvent(QContextMenuEvent *event); + +private slots: + void on_signals_changed(); + + void on_action_set_name_triggered(); + + void on_action_set_colour_triggered(); + + void on_signals_moved(); + +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; }; } // namespace view } // namespace pv -#endif // PV_VIEW_HEADER_H +#endif // PULSEVIEW_PV_VIEW_HEADER_H