-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathTimerItem.hpp
57 lines (45 loc) · 2.03 KB
/
TimerItem.hpp
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
// SC2 Metronome, a tool for improving mechanics in StarCraft(R) II
// Copyright (C) 2016 Martial Demolins AKA Folco
// This program is free software: you can redistribute it and/or modify it under the terms of the GNU General Public License
// as published by the Free Software foundation, either version 3 of the License, or (at your option) any later version.
// This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty
// of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details.
// You should have received a copy of the GNU General Public License along with this program.
// If not, see <http://www.gnu.org/licenses/>.
#ifndef TIMERITEM_HPP
#define TIMERITEM_HPP
#include <QString>
#include <QMetaType>
#include <windows.h>
#include <QKeySequence>
#define CUSTOM_TIMER_PERIOD 30
// This class contains a predefined timer used to be proposed in the list when the user creates a new timer
// The data of the objects are used only to initialize the interface when their are displayed
class TimerItem
{
Q_DISABLE_COPY(TimerItem)
public:
TimerItem();
explicit TimerItem(QString filename);
TimerItem(QString filename, int period, QKeySequence keySequence, UINT nativeModifiers, UINT nativeVirtualKey);
// Getters
QString getFilename() const { return filename; }
int getPeriod() const { return period; }
QKeySequence getKeySequence() const { return keySequence; }
UINT getNativeModifiers() const { return nativeModifiers; }
UINT getNativeVirtualKey() const { return nativeVirtualKey; }
bool mustPromptForFile() const { return promptForFile; }
QString getDisplayedName() const { return displayedName; }
//
private:
QString filename;
int period;
QKeySequence keySequence;
UINT nativeModifiers;
UINT nativeVirtualKey;
bool promptForFile;
QString displayedName;
};
// TimerItem* may be stored as a QVariant
Q_DECLARE_METATYPE(TimerItem*)
#endif // TIMERITEM_HPP