Developer Documentation
loggerWidget.hh
1 /*===========================================================================*\
2 * *
3 * OpenFlipper *
4  * Copyright (c) 2001-2015, RWTH-Aachen University *
5  * Department of Computer Graphics and Multimedia *
6  * All rights reserved. *
7  * www.openflipper.org *
8  * *
9  *---------------------------------------------------------------------------*
10  * This file is part of OpenFlipper. *
11  *---------------------------------------------------------------------------*
12  * *
13  * Redistribution and use in source and binary forms, with or without *
14  * modification, are permitted provided that the following conditions *
15  * are met: *
16  * *
17  * 1. Redistributions of source code must retain the above copyright notice, *
18  * this list of conditions and the following disclaimer. *
19  * *
20  * 2. Redistributions in binary form must reproduce the above copyright *
21  * notice, this list of conditions and the following disclaimer in the *
22  * documentation and/or other materials provided with the distribution. *
23  * *
24  * 3. Neither the name of the copyright holder nor the names of its *
25  * contributors may be used to endorse or promote products derived from *
26  * this software without specific prior written permission. *
27  * *
28  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS *
29  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED *
30  * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A *
31  * PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER *
32  * OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, *
33  * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, *
34  * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR *
35  * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF *
36  * LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING *
37  * NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS *
38  * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. *
39 * *
40 \*===========================================================================*/
41 
42 
43 
44 
45 
46 
47 #ifndef LOGGERWIDGET_HH
48 #define LOGGERWIDGET_HH
49 
50 #include <QListWidget>
51 
53 
54 #include <QtWidgets>
55 
56 
61 class LoggerWidget : public QWidget
62 {
63 
64  Q_OBJECT
65 
66  public:
67  explicit LoggerWidget( QWidget *parent = 0 );
68 
69  ~LoggerWidget();
70 
75  void append(const QString& _text, Logtype _type);
76 
77  protected:
78 
83  void keyPressEvent (QKeyEvent * _event );
84 
89  void contextMenuEvent ( QContextMenuEvent * event );
90 
95  void showEvent ( QShowEvent * event );
96 
97  private:
98 
99  QListWidget* list_;
100 
101  bool blockNext_;
102 
103  QPushButton* allButton_;
104  QPushButton* infoButton_;
105  QPushButton* warnButton_;
106  QPushButton* errorButton_;
107 
108  QPushButton* filterButton_;
109 
110  QPushButton* clearButton_;
111 
112  QMenu* context_;
113 
114  QMenu* filterMenu_;
115 
116  QTimer loggerUpdateTimer_;
117 
118  // true if new data is available
119  bool newData_;
120 
121  public:
122  // Action for OpenMesh filters
123  QAction* openMeshFilterAction_;
124 
125  private slots:
127  void updateList();
128 
130  void copySelected();
131 
133  void slotScrollUpdate();
134 
136  void slotFilterMenu();
137 };
138 
139 #endif //LOGGERWIDGET_HH
void copySelected()
copy Selected rows to clipboard
Logtype
Log types for Message Window.
void keyPressEvent(QKeyEvent *_event)
Grab key events.
Implementation of the logger Widget.
Definition: loggerWidget.hh:61
void contextMenuEvent(QContextMenuEvent *event)
Show context menu.
void updateList()
update the list if a button was pressed
void append(const QString &_text, Logtype _type)
Append a new logmessage to log viewer.
void slotFilterMenu()
Called when filter button is pressed.
void slotScrollUpdate()
Called when we want to scroll to the bottom.
void showEvent(QShowEvent *event)
Called when the widget is shown.