src/MessageLog.h

Wed, 12 Mar 2014 16:21:49 +0200

author
Santeri Piippo <crimsondusk64@gmail.com>
date
Wed, 12 Mar 2014 16:21:49 +0200
changeset 705
09150d027e8c
parent 650
db7146a87ae4
permissions
-rw-r--r--

Merge ../ldforge into gl

629
b75c6cce02e2 - refactored filenames
Santeri Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
1 /*
b75c6cce02e2 - refactored filenames
Santeri Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
2 * LDForge: LDraw parts authoring CAD
b75c6cce02e2 - refactored filenames
Santeri Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
3 * Copyright (C) 2013, 2014 Santeri Piippo
b75c6cce02e2 - refactored filenames
Santeri Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
4 *
b75c6cce02e2 - refactored filenames
Santeri Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
5 * This program is free software: you can redistribute it and/or modify
b75c6cce02e2 - refactored filenames
Santeri Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
6 * it under the terms of the GNU General Public License as published by
b75c6cce02e2 - refactored filenames
Santeri Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
7 * the Free Software Foundation, either version 3 of the License, or
b75c6cce02e2 - refactored filenames
Santeri Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
8 * (at your option) any later version.
b75c6cce02e2 - refactored filenames
Santeri Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
9 *
b75c6cce02e2 - refactored filenames
Santeri Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
10 * This program is distributed in the hope that it will be useful,
b75c6cce02e2 - refactored filenames
Santeri Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
11 * but WITHOUT ANY WARRANTY; without even the implied warranty of
b75c6cce02e2 - refactored filenames
Santeri Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
12 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
b75c6cce02e2 - refactored filenames
Santeri Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
13 * GNU General Public License for more details.
b75c6cce02e2 - refactored filenames
Santeri Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
14 *
b75c6cce02e2 - refactored filenames
Santeri Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
15 * You should have received a copy of the GNU General Public License
b75c6cce02e2 - refactored filenames
Santeri Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
16 * along with this program. If not, see <http://www.gnu.org/licenses/>.
b75c6cce02e2 - refactored filenames
Santeri Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
17 */
b75c6cce02e2 - refactored filenames
Santeri Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
18
641
425b169a82aa - changed header guards into #pragma once
Santeri Piippo <crimsondusk64@gmail.com>
parents: 629
diff changeset
19 #pragma once
629
b75c6cce02e2 - refactored filenames
Santeri Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
20 #include <QObject>
b75c6cce02e2 - refactored filenames
Santeri Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
21 #include <QDate>
b75c6cce02e2 - refactored filenames
Santeri Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
22 #include "Main.h"
b75c6cce02e2 - refactored filenames
Santeri Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
23 #include "Types.h"
b75c6cce02e2 - refactored filenames
Santeri Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
24
b75c6cce02e2 - refactored filenames
Santeri Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
25 class GLRenderer;
b75c6cce02e2 - refactored filenames
Santeri Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
26 class QTimer;
b75c6cce02e2 - refactored filenames
Santeri Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
27
647
b87941923eb4 - made MessageLog.h and RingFinder.h suitable for doxygen
Santeri Piippo <crimsondusk64@gmail.com>
parents: 642
diff changeset
28 //!
650
db7146a87ae4 - changed doxygen entity style from @argh to \argh
Santeri Piippo <crimsondusk64@gmail.com>
parents: 647
diff changeset
29 //! \brief Manages the list of messages at the top-left of the renderer.
647
b87941923eb4 - made MessageLog.h and RingFinder.h suitable for doxygen
Santeri Piippo <crimsondusk64@gmail.com>
parents: 642
diff changeset
30 //!
b87941923eb4 - made MessageLog.h and RingFinder.h suitable for doxygen
Santeri Piippo <crimsondusk64@gmail.com>
parents: 642
diff changeset
31 //! The message manager is an object which keeps track of messages that appear
b87941923eb4 - made MessageLog.h and RingFinder.h suitable for doxygen
Santeri Piippo <crimsondusk64@gmail.com>
parents: 642
diff changeset
32 //! on the renderer's screen. Each line is contained in a separate object which
b87941923eb4 - made MessageLog.h and RingFinder.h suitable for doxygen
Santeri Piippo <crimsondusk64@gmail.com>
parents: 642
diff changeset
33 //! contains the text, expiry time and alpha. The message manager is doubly
b87941923eb4 - made MessageLog.h and RingFinder.h suitable for doxygen
Santeri Piippo <crimsondusk64@gmail.com>
parents: 642
diff changeset
34 //! linked to its corresponding renderer.
b87941923eb4 - made MessageLog.h and RingFinder.h suitable for doxygen
Santeri Piippo <crimsondusk64@gmail.com>
parents: 642
diff changeset
35 //!
650
db7146a87ae4 - changed doxygen entity style from @argh to \argh
Santeri Piippo <crimsondusk64@gmail.com>
parents: 647
diff changeset
36 //! Message manager calls its \c tick() function regularly to update the messages,
647
b87941923eb4 - made MessageLog.h and RingFinder.h suitable for doxygen
Santeri Piippo <crimsondusk64@gmail.com>
parents: 642
diff changeset
37 //! where each line's expiry is checked for. Lines begin to fade out when nearing
b87941923eb4 - made MessageLog.h and RingFinder.h suitable for doxygen
Santeri Piippo <crimsondusk64@gmail.com>
parents: 642
diff changeset
38 //! their expiry. If the message manager's lines change, the renderer undergoes
b87941923eb4 - made MessageLog.h and RingFinder.h suitable for doxygen
Santeri Piippo <crimsondusk64@gmail.com>
parents: 642
diff changeset
39 //! repainting.
b87941923eb4 - made MessageLog.h and RingFinder.h suitable for doxygen
Santeri Piippo <crimsondusk64@gmail.com>
parents: 642
diff changeset
40 //!
629
b75c6cce02e2 - refactored filenames
Santeri Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
41 class MessageManager : public QObject
b75c6cce02e2 - refactored filenames
Santeri Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
42 {
b75c6cce02e2 - refactored filenames
Santeri Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
43 Q_OBJECT
642
751a8df42842 - migrated the codebase to use a simpler PROPERTY macro, arrrrrrrrrrrrrrrrrrrrrgh
Santeri Piippo <crimsondusk64@gmail.com>
parents: 641
diff changeset
44 PROPERTY (public, GLRenderer*, renderer, setRenderer, STOCK_WRITE)
629
b75c6cce02e2 - refactored filenames
Santeri Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
45
b75c6cce02e2 - refactored filenames
Santeri Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
46 public:
650
db7146a87ae4 - changed doxygen entity style from @argh to \argh
Santeri Piippo <crimsondusk64@gmail.com>
parents: 647
diff changeset
47 //! \class MessageManager::Line
647
b87941923eb4 - made MessageLog.h and RingFinder.h suitable for doxygen
Santeri Piippo <crimsondusk64@gmail.com>
parents: 642
diff changeset
48 //! A single line of the message log.
629
b75c6cce02e2 - refactored filenames
Santeri Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
49 class Line
b75c6cce02e2 - refactored filenames
Santeri Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
50 {
b75c6cce02e2 - refactored filenames
Santeri Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
51 public:
650
db7146a87ae4 - changed doxygen entity style from @argh to \argh
Santeri Piippo <crimsondusk64@gmail.com>
parents: 647
diff changeset
52 //! Constructs a line with the given \c text
629
b75c6cce02e2 - refactored filenames
Santeri Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
53 Line (QString text);
647
b87941923eb4 - made MessageLog.h and RingFinder.h suitable for doxygen
Santeri Piippo <crimsondusk64@gmail.com>
parents: 642
diff changeset
54
b87941923eb4 - made MessageLog.h and RingFinder.h suitable for doxygen
Santeri Piippo <crimsondusk64@gmail.com>
parents: 642
diff changeset
55 //! Check this line's expiry and update alpha accordingly.
650
db7146a87ae4 - changed doxygen entity style from @argh to \argh
Santeri Piippo <crimsondusk64@gmail.com>
parents: 647
diff changeset
56 //! \c changed is updated to whether the line has somehow
647
b87941923eb4 - made MessageLog.h and RingFinder.h suitable for doxygen
Santeri Piippo <crimsondusk64@gmail.com>
parents: 642
diff changeset
57 //! changed since the last update.
650
db7146a87ae4 - changed doxygen entity style from @argh to \argh
Santeri Piippo <crimsondusk64@gmail.com>
parents: 647
diff changeset
58 //! \returns true if the line is to still stick around, false
db7146a87ae4 - changed doxygen entity style from @argh to \argh
Santeri Piippo <crimsondusk64@gmail.com>
parents: 647
diff changeset
59 //! \returns if it expired.
629
b75c6cce02e2 - refactored filenames
Santeri Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
60 bool update (bool& changed);
b75c6cce02e2 - refactored filenames
Santeri Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
61
b75c6cce02e2 - refactored filenames
Santeri Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
62 QString text;
b75c6cce02e2 - refactored filenames
Santeri Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
63 float alpha;
b75c6cce02e2 - refactored filenames
Santeri Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
64 QDateTime expiry;
b75c6cce02e2 - refactored filenames
Santeri Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
65 };
b75c6cce02e2 - refactored filenames
Santeri Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
66
647
b87941923eb4 - made MessageLog.h and RingFinder.h suitable for doxygen
Santeri Piippo <crimsondusk64@gmail.com>
parents: 642
diff changeset
67 //! Constructs the message manager.
b87941923eb4 - made MessageLog.h and RingFinder.h suitable for doxygen
Santeri Piippo <crimsondusk64@gmail.com>
parents: 642
diff changeset
68 explicit MessageManager (QObject* parent = null);
b87941923eb4 - made MessageLog.h and RingFinder.h suitable for doxygen
Santeri Piippo <crimsondusk64@gmail.com>
parents: 642
diff changeset
69
650
db7146a87ae4 - changed doxygen entity style from @argh to \argh
Santeri Piippo <crimsondusk64@gmail.com>
parents: 647
diff changeset
70 //! Adds a line with the given \c text to the message manager.
629
b75c6cce02e2 - refactored filenames
Santeri Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
71 void addLine (QString line);
647
b87941923eb4 - made MessageLog.h and RingFinder.h suitable for doxygen
Santeri Piippo <crimsondusk64@gmail.com>
parents: 642
diff changeset
72
650
db7146a87ae4 - changed doxygen entity style from @argh to \argh
Santeri Piippo <crimsondusk64@gmail.com>
parents: 647
diff changeset
73 //! \returns all active lines in the message manager.
629
b75c6cce02e2 - refactored filenames
Santeri Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
74 const QList<Line>& getLines() const;
b75c6cce02e2 - refactored filenames
Santeri Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
75
b75c6cce02e2 - refactored filenames
Santeri Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
76 private:
647
b87941923eb4 - made MessageLog.h and RingFinder.h suitable for doxygen
Santeri Piippo <crimsondusk64@gmail.com>
parents: 642
diff changeset
77 QList<Line> m_lines;
b87941923eb4 - made MessageLog.h and RingFinder.h suitable for doxygen
Santeri Piippo <crimsondusk64@gmail.com>
parents: 642
diff changeset
78 QTimer* m_ticker;
629
b75c6cce02e2 - refactored filenames
Santeri Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
79
b75c6cce02e2 - refactored filenames
Santeri Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
80 private slots:
647
b87941923eb4 - made MessageLog.h and RingFinder.h suitable for doxygen
Santeri Piippo <crimsondusk64@gmail.com>
parents: 642
diff changeset
81 //! Ticks the manager. This is called by the timer to update
b87941923eb4 - made MessageLog.h and RingFinder.h suitable for doxygen
Santeri Piippo <crimsondusk64@gmail.com>
parents: 642
diff changeset
82 //! the messages.
629
b75c6cce02e2 - refactored filenames
Santeri Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
83 void tick();
b75c6cce02e2 - refactored filenames
Santeri Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
84 };

mercurial