2 * This file is part of the PulseView project.
4 * Copyright (C) 2012 Joel Holdsworth <joel@airwebreathe.org.uk>
6 * This program is free software; you can redistribute it and/or modify
7 * it under the terms of the GNU General Public License as published by
8 * the Free Software Foundation; either version 2 of the License, or
9 * (at your option) any later version.
11 * This program is distributed in the hope that it will be useful,
12 * but WITHOUT ANY WARRANTY; without even the implied warranty of
13 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14 * GNU General Public License for more details.
16 * You should have received a copy of the GNU General Public License
17 * along with this program; if not, see <http://www.gnu.org/licenses/>.
20 #ifndef PULSEVIEW_PV_VIEWS_TRACEVIEW_HEADER_HPP
21 #define PULSEVIEW_PV_VIEWS_TRACEVIEW_HEADER_HPP
27 #include "marginwidget.hpp"
29 using std::shared_ptr;
41 * The Header class provides an area for @ref Trace labels to be shown,
42 * trace-related settings to be edited, trace groups to be shown and similar.
43 * Essentially, it is the main management area of the @ref View itself and
44 * shown on the left-hand side of the trace area.
46 class Header : public MarginWidget
51 static const int Padding;
56 QSize sizeHint() const;
59 * The extended area that the header widget would like to be sized to.
60 * @remarks This area is the area specified by sizeHint, extended by
61 * the area to overlap the viewport.
63 QSize extended_size_hint() const;
69 vector< shared_ptr<ViewItem> > items();
72 * Gets the first view item which has a label that contains @c pt .
73 * @param pt the point to search with.
74 * @return the view item that has been found, or and empty
75 * @c shared_ptr if no item was found.
77 shared_ptr<ViewItem> get_mouse_over_item(const QPoint &pt);
80 void paintEvent(QPaintEvent *event);
83 void contextMenuEvent(QContextMenuEvent *event);
85 void keyPressEvent(QKeyEvent *event);
97 #endif // PULSEVIEW_PV_VIEWS_TRACEVIEW_HEADER_HPP