forked from neundorf/CuteCom
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathcontrolpanel.h
100 lines (87 loc) · 2.88 KB
/
controlpanel.h
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
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
/*
* Copyright (c) 2015 Meinhard Ritscher <cyc1ingsir@gmail.com>
*
* 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, write to the Free Software
* Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
*
* For more information on the GPL, please go to:
* http://www.gnu.org/copyleft/gpl.html
*/
#ifndef CONTROLPANEL_H
#define CONTROLPANEL_H
#include "ui_controlpanel.h"
#include "settings.h"
#include <QFrame>
#include <QSerialPort>
class ControlPanel : public QFrame, public Ui::ControlPanel
{
Q_OBJECT
signals:
void openDeviceClicked();
void closeDeviceClicked();
void settingChanged(Settings::Options option, QVariant setting);
public:
explicit ControlPanel(QWidget *parent = 0, Settings *settings = 0);
~ControlPanel();
/**
* Returns the space in the y-achsis needed
* when the panel is collapsed
* @brief hiddenHeight
* @return
*/
int hiddenHeight() { return height() + m_y; }
void printPosition();
void collapse();
void slideOut();
/**
* @brief setLeftMargin
* @param x
*/
void setLeftMargin(int x) { m_x = x; }
void fillDeviceCombo(const QString &deviceName);
void applySessionSettings(Settings::Session settings);
void closeDevice()
{
toggleDevice(false);
m_bt_open->setChecked(false);
}
private:
void fillBaudCombo();
void fillFlowCombo();
void fillParityCombo();
void fillDataBitCombo();
void fillStopBitCombo();
void fillOpenModeCombo();
// slots
void toggleMenu();
void toggleDevice(bool open);
void customBaudRate(int index);
void customBaudRateSet();
void chooseLogFile();
/**
* @brief Designed to catch QComboBox::currentIndexChanged(int) signal. Its roles is to set the
* proper visibility of RTS and DTR checkboxes which depends on selected type of flow control.
* If user selects the hardware flow control, then RTS and DTR checkboxes are being invisible.
* If user selects none or software flow control, then RTS and DTR checkboxes are being visible.
* @param index QComboBox item's index.
*/
void changeVisibilityOfRTSandDTRCheckboxes(int index);
private:
int m_x;
int m_y;
bool m_menuVisible;
QIntValidator *m_baudValidator;
QLineEdit *m_baud_edit;
};
#endif // CONTROLPANEL_H