MIRA
TitleBar.h
Go to the documentation of this file.
1 /*
2  * Copyright (C) 2012 by
3  * MetraLabs GmbH (MLAB), GERMANY
4  * and
5  * Neuroinformatics and Cognitive Robotics Labs (NICR) at TU Ilmenau, GERMANY
6  * All rights reserved.
7  *
8  * Contact: info@mira-project.org
9  *
10  * Commercial Usage:
11  * Licensees holding valid commercial licenses may use this file in
12  * accordance with the commercial license agreement provided with the
13  * software or, alternatively, in accordance with the terms contained in
14  * a written agreement between you and MLAB or NICR.
15  *
16  * GNU General Public License Usage:
17  * Alternatively, this file may be used under the terms of the GNU
18  * General Public License version 3.0 as published by the Free Software
19  * Foundation and appearing in the file LICENSE.GPL3 included in the
20  * packaging of this file. Please review the following information to
21  * ensure the GNU General Public License version 3.0 requirements will be
22  * met: http://www.gnu.org/copyleft/gpl.html.
23  * Alternatively you may (at your option) use any later version of the GNU
24  * General Public License if such license has been publicly approved by
25  * MLAB and NICR (or its successors, if any).
26  *
27  * IN NO EVENT SHALL "MLAB" OR "NICR" BE LIABLE TO ANY PARTY FOR DIRECT,
28  * INDIRECT, SPECIAL, INCIDENTAL, OR CONSEQUENTIAL DAMAGES ARISING OUT OF
29  * THE USE OF THIS SOFTWARE AND ITS DOCUMENTATION, EVEN IF "MLAB" OR
30  * "NICR" HAS BEEN ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
31  *
32  * "MLAB" AND "NICR" SPECIFICALLY DISCLAIM ANY WARRANTIES, INCLUDING,
33  * BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND
34  * FITNESS FOR A PARTICULAR PURPOSE. THE SOFTWARE PROVIDED HEREUNDER IS
35  * ON AN "AS IS" BASIS, AND "MLAB" AND "NICR" HAVE NO OBLIGATION TO
36  * PROVIDE MAINTENANCE, SUPPORT, UPDATES, ENHANCEMENTS OR MODIFICATIONS.
37  */
38 
48 #ifndef _MIRA_TITLEBAR_H_
49 #define _MIRA_TITLEBAR_H_
50 
51 #include <QWidget>
52 #include <QToolButton>
53 #include <QHBoxLayout>
54 #include <QMenu>
55 
56 namespace mira
57 {
59 
68 class TitleBar : public QWidget
69 {
70 
71 public:
72 
73  TitleBar(QWidget *parent = 0);
74  virtual ~TitleBar();
75 
76 public:
77 
79  void setHighlight(bool on);
80 
82  void update();
83 
84 public:
85 
94  QWidget* takeRightButtons();
95 
97  void putBackRightButtons();
98 
107  QWidget* takeLeftButtons();
108 
110  void putBackLeftButtons();
111 
118  void insertRightButton(QToolButton* button, int index = 0);
119 
127  void insertLeftButton(QToolButton* button, int index = -1);
128 
129 public:
130 
135  QMenu* getMenu();
136 
137 protected:
138 
139  bool eventFilter( QObject* obj, QEvent* event);
140 
141  void paintEvent(QPaintEvent*);
142  void resizeEvent(QResizeEvent*);
143 
144 protected:
145 
146  void updateBackground();
147 
148 protected:
149 
150  QHBoxLayout* mLayout;
151  QHBoxLayout* mLeftLayout;
152  QHBoxLayout* mRightLayout;
153  QToolButton* mMenuBtn;
154  QToolButton* mClose;
155  QToolButton* mDock;
156  QToolButton* mUndock;
157  QToolButton* mMaximize;
158  QToolButton* mMinimize;
159  QToolButton* mRestore;
160  QWidget* mLeftButtons;
161  QWidget* mRightButtons;
162 
163  QMenu* mMenu;
164 
165  QWidget* mParent;
166  QPixmap *mBackground;
167 
169 };
170 
172 
173 }
174 
175 #endif
bool mIsHighlighted
Definition: TitleBar.h:168
virtual ~TitleBar()
void putBackRightButtons()
Puts back the right buttons, that were taken using the above method.
QMenu * getMenu()
Returns the menu of the menu button in order to add new items to the menu.
specialize cv::DataType for our ImgPixel and inherit from cv::DataType<Vec>
Definition: IOService.h:67
QWidget * mParent
Definition: TitleBar.h:165
void putBackLeftButtons()
Puts back the left buttons, that were taken using the above method.
TitleBar(QWidget *parent=0)
QToolButton * mMenuBtn
Definition: TitleBar.h:153
QWidget * mLeftButtons
Definition: TitleBar.h:160
QToolButton * mDock
Definition: TitleBar.h:155
QHBoxLayout * mLeftLayout
Definition: TitleBar.h:151
QMenu * mMenu
Definition: TitleBar.h:163
Base class for all window title bars (EditorPartTitleBar, ViewPartTitleBar).
Definition: TitleBar.h:68
void setHighlight(bool on)
enables/disables highlighted title bar
void paintEvent(QPaintEvent *)
void resizeEvent(QResizeEvent *)
void updateBackground()
QWidget * takeRightButtons()
Returns a widget containing all buttons of the title bars right side.
QToolButton * mClose
Definition: TitleBar.h:154
QHBoxLayout * mLayout
Definition: TitleBar.h:150
QPixmap * mBackground
Definition: TitleBar.h:166
void update()
updates the TitleBar (e.g. necessary after the title was changed)
QToolButton * mRestore
Definition: TitleBar.h:159
void insertRightButton(QToolButton *button, int index=0)
Inserts the specified button within the right button group at the given index.
QToolButton * mUndock
Definition: TitleBar.h:156
QHBoxLayout * mRightLayout
Definition: TitleBar.h:152
QToolButton * mMinimize
Definition: TitleBar.h:158
QToolButton * mMaximize
Definition: TitleBar.h:157
QWidget * takeLeftButtons()
Returns a widget containing all buttons of the title bars left side.
bool eventFilter(QObject *obj, QEvent *event)
QWidget * mRightButtons
Definition: TitleBar.h:161
void insertLeftButton(QToolButton *button, int index=-1)
Inserts the specified button within the left button group at the given index.