blob: f5297e87feca4373736c2930fb42bc66b0ba92d5 (
plain)
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
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
|
/*
Rosegarden
A MIDI and audio sequencer and musical notation editor.
This program is Copyright 2000-2008
Guillaume Laurent <glaurent@telegraph-road.org>,
Chris Cannam <cannam@all-day-breakfast.com>,
Richard Bown <richard.bown@ferventsoftware.com>
The moral rights of Guillaume Laurent, Chris Cannam, and Richard
Bown to claim authorship of this work have been asserted.
Other copyrights also apply to some parts of this work. Please
see the AUTHORS file and individual file headers for details.
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 2 of the
License, or (at your option) any later version. See the file
COPYING included with this distribution for more information.
*/
#ifndef _RG_MIDIINSTRUMENTPARAMETERPANEL_H_
#define _RG_MIDIINSTRUMENTPARAMETERPANEL_H_
#include "base/MidiProgram.h"
#include "base/MidiDevice.h"
#include "InstrumentParameterPanel.h"
#include <tqstring.h>
class TQWidget;
class TQSignalMapper;
class TQLabel;
class TQGridLayout;
class TQFrame;
class TQCheckBox;
class KComboBox;
namespace Rosegarden
{
class RosegardenGUIDoc;
class MidiDevice;
class Instrument;
class MIDIInstrumentParameterPanel : public InstrumentParameterPanel
{
Q_OBJECT
public:
MIDIInstrumentParameterPanel(RosegardenGUIDoc *doc, TQWidget* parent);
void setupControllers(MidiDevice *); // setup ControlParameters on box
virtual void setupForInstrument(Instrument*);
void showAdditionalControls(bool showThem);
signals:
void changeInstrumentLabel(InstrumentId id, TQString label);
void instrumentParametersChanged(InstrumentId);
public slots:
void slotSelectProgram(int index);
void slotSelectBank(int index);
void slotSelectVariation(int index);
void slotSelectChannel(int index);
//void slotSelectInputChannel(int index);
void slotControllerChanged(int index);
void slotTogglePercussion(bool value);
void slotToggleProgramChange(bool value);
void slotToggleBank(bool value);
void slotToggleVariation(bool value);
protected:
// fill (or hide) bank combo based on whether the instrument is percussion
void populateBankList();
// fill program combo based on current bank
void populateProgramList();
// fill (or hide) variation combo based on current bank and program
void populateVariationList();
// send the bank and program events relevant to this instrument
void sendBankAndProgram();
// get value of a specific rotary (keyed by controller value)
int getValueFromRotary(int rotary);
// set rotary to value
void setRotaryToValue(int controller, int value);
//--------------- Data members ---------------------------------
TQLabel *m_connectionLabel;
KComboBox *m_bankValue;
KComboBox *m_variationValue;
KComboBox *m_channelValue;
KComboBox *m_programValue;
//KComboBox *m_channelInValue;
TQCheckBox *m_percussionCheckBox;
TQCheckBox *m_bankCheckBox;
TQCheckBox *m_variationCheckBox;
TQCheckBox *m_programCheckBox;
TQLabel *m_bankLabel;
TQLabel *m_variationLabel;
TQLabel *m_programLabel;
TQGridLayout *m_mainGrid;
TQFrame *m_rotaryFrame;
TQGridLayout *m_rotaryGrid;
RotaryMap m_rotaries;
TQSignalMapper *m_rotaryMapper;
BankList m_banks;
ProgramList m_programs;
MidiByteList m_variations;
};
}
#endif
|