MIRA
SplashScreen.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 
47 #ifndef _MIRA_SPLASHSCREEN_H_
48 #define _MIRA_SPLASHSCREEN_H_
49 
50 #include <QFrame>
51 
52 class QTimer;
53 
54 namespace mira {
55 
57 
63 class SplashScreen : public QFrame
64 {
65 public:
66  enum SpecialMode {
68  };
69 
72 
73  SplashScreen(QWidget* parent, const QPixmap& pixmap);
74 
75 public:
76 
80  void show();
81 
82 public:
83 
88  void closeTimer(int timeout);
89 
94  void closeOnClick();
95 
96 public:
97  void clearMessage();
98  void showMessage(const QString& message,
99  int alignment = Qt::AlignLeft | Qt::AlignTop,
100  const QColor& color = Qt::black);
101 
102  void setTextRect(const QRect& rect);
103 
104 public:
105  static void closeSplashScreen();
106 
107 protected:
108 
109  virtual void mousePressEvent(QMouseEvent* event);
110 
111 private:
112  virtual void paintEvent(QPaintEvent* pe);
113 
114 private:
115  QPixmap mPixmap;
116  QString mMessage;
117  int mAlignment;
118  QColor mColor;
119  QRect mTextRect;
120 
121  QTimer* mTimer;
122  bool mCloseOnClick;
123 
124  bool mDummy;
125 };
126 
128 
129 }
130 
131 #endif
SplashScreen(SpecialMode mode)
Creates a disabled dummy SplashScreen, which does nothing.
Widget provides a splash screen that can be shown during application startup.
Definition: SplashScreen.h:63
specialize cv::DataType for our ImgPixel and inherit from cv::DataType<Vec>
Definition: IOService.h:67
void show()
Shows the splash screen.
static void closeSplashScreen()
Definition: SplashScreen.h:67
virtual void mousePressEvent(QMouseEvent *event)
void closeTimer(int timeout)
After calling this method the splash screen will hide automatically after the specified timeout has e...
void showMessage(const QString &message, int alignment=Qt::AlignLeft|Qt::AlignTop, const QColor &color=Qt::black)
SpecialMode
Definition: SplashScreen.h:66
void setTextRect(const QRect &rect)
void closeOnClick()
After this method is called, the user can close the splash screen by clicking on it.