/[svn]/qsampler/trunk/src/qsamplerChannelForm.cpp
ViewVC logotype

Contents of /qsampler/trunk/src/qsamplerChannelForm.cpp

Parent Directory Parent Directory | Revision Log Revision Log


Revision 1840 - (show annotations) (download)
Thu Feb 19 11:44:57 2009 UTC (15 years, 1 month ago) by capela
File size: 24213 byte(s)
* Converted obsolete QMessageBox forms to standard buttons.

1 // qsamplerChannelForm.cpp
2 //
3 /****************************************************************************
4 Copyright (C) 2004-2009, rncbc aka Rui Nuno Capela. All rights reserved.
5 Copyright (C) 2007, 2008 Christian Schoenebeck
6
7 This program is free software; you can redistribute it and/or
8 modify it under the terms of the GNU General Public License
9 as published by the Free Software Foundation; either version 2
10 of the License, or (at your option) any later version.
11
12 This program is distributed in the hope that it will be useful,
13 but WITHOUT ANY WARRANTY; without even the implied warranty of
14 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
15 GNU General Public License for more details.
16
17 You should have received a copy of the GNU General Public License along
18 with this program; if not, write to the Free Software Foundation, Inc.,
19 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
20
21 *****************************************************************************/
22
23 #include "qsamplerChannelForm.h"
24
25 #include "qsamplerAbout.h"
26 #include "qsamplerDeviceForm.h"
27
28 #include "qsamplerMainForm.h"
29 #include "qsamplerInstrument.h"
30
31 #include <QValidator>
32 #include <QMessageBox>
33 #include <QFileDialog>
34 #include <QFileInfo>
35
36 #include <QHeaderView>
37
38
39 namespace QSampler {
40
41 //-------------------------------------------------------------------------
42 // QSampler::Channelform -- Channel form implementation.
43 //
44
45 ChannelForm::ChannelForm ( QWidget* pParent )
46 : QDialog(pParent)
47 {
48 m_ui.setupUi(this);
49
50 // Initialize locals.
51 m_pChannel = NULL;
52
53 m_iDirtySetup = 0;
54 m_iDirtyCount = 0;
55
56 // m_midiDevices.setAutoDelete(true);
57 // m_audioDevices.setAutoDelete(true);
58
59 m_pDeviceForm = NULL;
60
61 int iRowHeight = m_ui.AudioRoutingTable->fontMetrics().height() + 4;
62 m_ui.AudioRoutingTable->verticalHeader()->setDefaultSectionSize(iRowHeight);
63 m_ui.AudioRoutingTable->horizontalHeader()->setDefaultAlignment(Qt::AlignLeft);
64
65 m_ui.AudioRoutingTable->setModel(&m_routingModel);
66 m_ui.AudioRoutingTable->setItemDelegate(&m_routingDelegate);
67 m_ui.AudioRoutingTable->horizontalHeader()->setResizeMode(0, QHeaderView::Stretch);
68 // m_ui.AudioRoutingTable->verticalHeader()->hide();
69
70 // This goes initially hidden, and will be shown
71 // on setup() for currently existing channels...
72 m_ui.AudioRoutingTable->hide();
73
74 // Try to restore normal window positioning.
75 adjustSize();
76
77 QObject::connect(m_ui.EngineNameComboBox,
78 SIGNAL(activated(int)),
79 SLOT(optionsChanged()));
80 QObject::connect(m_ui.InstrumentFileComboBox,
81 SIGNAL(activated(const QString&)),
82 SLOT(updateInstrumentName()));
83 QObject::connect(m_ui.InstrumentFileToolButton,
84 SIGNAL(clicked()),
85 SLOT(openInstrumentFile()));
86 QObject::connect(m_ui.InstrumentNrComboBox,
87 SIGNAL(activated(int)),
88 SLOT(optionsChanged()));
89 QObject::connect(m_ui.MidiDriverComboBox,
90 SIGNAL(activated(const QString&)),
91 SLOT(selectMidiDriver(const QString&)));
92 QObject::connect(m_ui.MidiDeviceComboBox,
93 SIGNAL(activated(int)),
94 SLOT(selectMidiDevice(int)));
95 QObject::connect(m_ui.MidiPortSpinBox,
96 SIGNAL(valueChanged(int)),
97 SLOT(optionsChanged()));
98 QObject::connect(m_ui.MidiChannelComboBox,
99 SIGNAL(activated(int)),
100 SLOT(optionsChanged()));
101 QObject::connect(m_ui.MidiMapComboBox,
102 SIGNAL(activated(int)),
103 SLOT(optionsChanged()));
104 QObject::connect(m_ui.AudioDriverComboBox,
105 SIGNAL(activated(const QString&)),
106 SLOT(selectAudioDriver(const QString&)));
107 QObject::connect(m_ui.AudioDeviceComboBox,
108 SIGNAL(activated(int)),
109 SLOT(selectAudioDevice(int)));
110 QObject::connect(m_ui.OkPushButton,
111 SIGNAL(clicked()),
112 SLOT(accept()));
113 QObject::connect(m_ui.CancelPushButton,
114 SIGNAL(clicked()),
115 SLOT(reject()));
116 QObject::connect(m_ui.MidiDeviceToolButton,
117 SIGNAL(clicked()),
118 SLOT(setupMidiDevice()));
119 QObject::connect(m_ui.AudioDeviceToolButton,
120 SIGNAL(clicked()),
121 SLOT(setupAudioDevice()));
122 QObject::connect(&m_routingModel,
123 SIGNAL(dataChanged(const QModelIndex&, const QModelIndex&)),
124 SLOT(optionsChanged()));
125 QObject::connect(&m_routingModel,
126 SIGNAL(dataChanged(const QModelIndex&, const QModelIndex&)),
127 SLOT(updateTableCellRenderers(const QModelIndex&, const QModelIndex&)));
128 QObject::connect(&m_routingModel,
129 SIGNAL(modelReset()),
130 SLOT(updateTableCellRenderers()));
131 }
132
133 ChannelForm::~ChannelForm()
134 {
135 if (m_pDeviceForm)
136 delete m_pDeviceForm;
137 m_pDeviceForm = NULL;
138
139 qDeleteAll(m_midiDevices);
140 m_midiDevices.clear();
141
142 qDeleteAll(m_audioDevices);
143 m_audioDevices.clear();
144 }
145
146
147 // Channel dialog setup formal initializer.
148 void ChannelForm::setup ( Channel *pChannel )
149 {
150 m_pChannel = pChannel;
151
152 m_iDirtySetup = 0;
153 m_iDirtyCount = 0;
154
155 if (m_pChannel == NULL)
156 return;
157
158 // It can be a brand new channel, remember?
159 const bool bNew = (m_pChannel->channelID() < 0);
160 setWindowTitle(QSAMPLER_TITLE ": " + m_pChannel->channelName());
161
162 // Check if we're up and connected.
163 MainForm *pMainForm = MainForm::getInstance();
164 if (pMainForm == NULL)
165 return;
166 if (pMainForm->client() == NULL)
167 return;
168
169 Options *pOptions = pMainForm->options();
170 if (pOptions == NULL)
171 return;
172
173 // Avoid nested changes.
174 m_iDirtySetup++;
175
176 // Load combo box history...
177 pOptions->loadComboBoxHistory(m_ui.InstrumentFileComboBox);
178
179 // Populate Engines list.
180 const char **ppszEngines = ::lscp_list_available_engines(pMainForm->client());
181 if (ppszEngines) {
182 m_ui.EngineNameComboBox->clear();
183 for (int iEngine = 0; ppszEngines[iEngine]; iEngine++)
184 m_ui.EngineNameComboBox->addItem(QString(ppszEngines[iEngine]));
185 }
186 else m_pChannel->appendMessagesClient("lscp_list_available_engines");
187
188 // Populate Audio output type list.
189 m_ui.AudioDriverComboBox->clear();
190 m_ui.AudioDriverComboBox->insertItems(0,
191 Device::getDrivers(pMainForm->client(), Device::Audio));
192
193 // Populate MIDI input type list.
194 m_ui.MidiDriverComboBox->clear();
195 m_ui.MidiDriverComboBox->insertItems(0,
196 Device::getDrivers(pMainForm->client(), Device::Midi));
197
198 // Populate Maps list.
199 m_ui.MidiMapComboBox->clear();
200 m_ui.MidiMapComboBox->insertItems(0,
201 Instrument::getMapNames());
202
203 // Read proper channel information,
204 // and populate the channel form fields.
205
206 // Engine name...
207 QString sEngineName = pChannel->engineName();
208 if (sEngineName.isEmpty() || bNew)
209 sEngineName = pOptions->sEngineName;
210 if (sEngineName.isEmpty())
211 sEngineName = Channel::noEngineName();
212 if (m_ui.EngineNameComboBox->findText(sEngineName,
213 Qt::MatchExactly | Qt::MatchCaseSensitive) < 0) {
214 m_ui.EngineNameComboBox->addItem(sEngineName);
215 }
216 m_ui.EngineNameComboBox->setCurrentIndex(
217 m_ui.EngineNameComboBox->findText(sEngineName,
218 Qt::MatchExactly | Qt::MatchCaseSensitive));
219
220 // Instrument filename and index...
221 QString sInstrumentFile = pChannel->instrumentFile();
222 if (sInstrumentFile.isEmpty())
223 sInstrumentFile = Channel::noInstrumentName();
224 m_ui.InstrumentFileComboBox->setEditText(sInstrumentFile);
225 m_ui.InstrumentNrComboBox->clear();
226 m_ui.InstrumentNrComboBox->insertItems(0,
227 Channel::getInstrumentList(sInstrumentFile,
228 pOptions->bInstrumentNames));
229 int iInstrumentNr = pChannel->instrumentNr();
230 if (iInstrumentNr < 0)
231 iInstrumentNr = 0;
232 m_ui.InstrumentNrComboBox->setCurrentIndex(iInstrumentNr);
233
234 // MIDI input device...
235 Device midiDevice(Device::Midi, m_pChannel->midiDevice());
236 // MIDI input driver...
237 QString sMidiDriver = midiDevice.driverName();
238 if (sMidiDriver.isEmpty() || bNew)
239 sMidiDriver = pOptions->sMidiDriver.toUpper();
240 if (!sMidiDriver.isEmpty()) {
241 if (m_ui.MidiDriverComboBox->findText(sMidiDriver,
242 Qt::MatchExactly | Qt::MatchCaseSensitive) < 0) {
243 m_ui.MidiDriverComboBox->insertItem(0, sMidiDriver);
244 }
245 m_ui.MidiDriverComboBox->setCurrentIndex(
246 m_ui.MidiDriverComboBox->findText(sMidiDriver,
247 Qt::MatchExactly | Qt::MatchCaseSensitive)
248 );
249 }
250 selectMidiDriverItem(sMidiDriver);
251 if (!bNew) {
252 m_ui.MidiDeviceComboBox->setItemText(
253 m_ui.MidiDeviceComboBox->currentIndex(),
254 midiDevice.deviceName());
255 }
256 selectMidiDeviceItem(m_ui.MidiDeviceComboBox->currentIndex());
257 // MIDI input port...
258 m_ui.MidiPortSpinBox->setValue(pChannel->midiPort());
259 // MIDI input channel...
260 int iMidiChannel = pChannel->midiChannel();
261 // When new, try to suggest a sensible MIDI channel...
262 if (iMidiChannel < 0)
263 iMidiChannel = (::lscp_get_channels(pMainForm->client()) % 16);
264 m_ui.MidiChannelComboBox->setCurrentIndex(iMidiChannel);
265 // MIDI instrument map...
266 int iMidiMap = (bNew ? pOptions->iMidiMap : pChannel->midiMap());
267 // When new, try to suggest a sensible MIDI map...
268 if (iMidiMap < 0)
269 iMidiMap = 0;
270 const QString& sMapName = Instrument::getMapName(iMidiMap);
271 if (!sMapName.isEmpty()) {
272 m_ui.MidiMapComboBox->setItemText(
273 m_ui.MidiMapComboBox->currentIndex(),
274 sMapName);
275 }
276 // It might be no maps around...
277 bool bMidiMapEnabled = (m_ui.MidiMapComboBox->count() > 0);
278 m_ui.MidiMapTextLabel->setEnabled(bMidiMapEnabled);
279 m_ui.MidiMapComboBox->setEnabled(bMidiMapEnabled);
280
281 // Audio output device...
282 Device audioDevice(Device::Audio, m_pChannel->audioDevice());
283 // Audio output driver...
284 QString sAudioDriver = audioDevice.driverName();
285 if (sAudioDriver.isEmpty() || bNew)
286 sAudioDriver = pOptions->sAudioDriver.toUpper();
287 if (!sAudioDriver.isEmpty()) {
288 if (m_ui.AudioDriverComboBox->findText(sAudioDriver,
289 Qt::MatchExactly | Qt::MatchCaseSensitive) < 0) {
290 m_ui.AudioDriverComboBox->insertItem(0, sAudioDriver);
291 }
292 m_ui.AudioDriverComboBox->setCurrentIndex(
293 m_ui.AudioDriverComboBox->findText(sAudioDriver,
294 Qt::MatchExactly | Qt::MatchCaseSensitive)
295 );
296 }
297 selectAudioDriverItem(sAudioDriver);
298 if (!bNew) {
299 m_ui.AudioDeviceComboBox->setItemText(
300 m_ui.AudioDeviceComboBox->currentIndex(),
301 audioDevice.deviceName());
302 }
303 selectAudioDeviceItem(m_ui.AudioDeviceComboBox->currentIndex());
304
305 // Let the audio routing table see the light,
306 // if we're editing an existing sampler channel...
307 m_ui.AudioRoutingTable->setVisible(!bNew);
308
309 const QString sInstrumentNrToolTip =
310 (pOptions->bInstrumentNames) ?
311 "Select an instrument of the file" :
312 "You might want to enable instrument name retrieval in the "
313 "settings dialog";
314 m_ui.InstrumentNrComboBox->setToolTip(
315 QObject::tr(sInstrumentNrToolTip.toUtf8().data())
316 );
317
318 // As convenient, make it ready on stabilizeForm() for
319 // prompt acceptance, if we got the minimum required...
320 /* if (sEngineName != Channel::noEngineName() &&
321 sInstrumentFile != Channel::noInstrumentName())
322 m_iDirtyCount++; */
323 // Done.
324 m_iDirtySetup--;
325 stabilizeForm();
326 }
327
328
329 // Accept settings (OK button slot).
330 void ChannelForm::accept (void)
331 {
332 if (m_pChannel == NULL)
333 return;
334
335 MainForm *pMainForm = MainForm::getInstance();
336 if (pMainForm == NULL)
337 return;
338 if (pMainForm->client() == NULL)
339 return;
340
341 Options *pOptions = pMainForm->options();
342 if (pOptions == NULL)
343 return;
344
345 // Flush any pending editing...
346 //m_ui.AudioRoutingTable->flush();
347
348 // We'll go for it!
349 if (m_iDirtyCount > 0) {
350 int iErrors = 0;
351 // Are we a new channel?
352 if (!m_pChannel->addChannel())
353 iErrors++;
354 // Accept Audio driver or device selection...
355 if (m_audioDevices.isEmpty()) {
356 if (!m_pChannel->setAudioDriver(m_ui.AudioDriverComboBox->currentText()))
357 iErrors++;
358 } else {
359 Device *pDevice = NULL;
360 int iAudioItem = m_ui.AudioDeviceComboBox->currentIndex();
361 if (iAudioItem >= 0 && iAudioItem < m_audioDevices.count())
362 pDevice = m_audioDevices.at(iAudioItem);
363 ChannelRoutingMap routingMap = m_routingModel.routingMap();
364 if (pDevice == NULL)
365 iErrors++;
366 else if (!m_pChannel->setAudioDevice(pDevice->deviceID()))
367 iErrors++;
368 else if (!routingMap.isEmpty()) {
369 // Set the audio route changes...
370 ChannelRoutingMap::ConstIterator iter;
371 for (iter = routingMap.begin();
372 iter != routingMap.end(); ++iter) {
373 if (!m_pChannel->setAudioChannel(iter.key(), iter.value()))
374 iErrors++;
375 }
376 }
377 }
378 // Accept MIDI driver or device selection...
379 if (m_midiDevices.isEmpty()) {
380 if (!m_pChannel->setMidiDriver(m_ui.MidiDriverComboBox->currentText()))
381 iErrors++;
382 } else {
383 Device *pDevice = NULL;
384 int iMidiItem = m_ui.MidiDeviceComboBox->currentIndex();
385 if (iMidiItem >= 0 && iMidiItem < m_midiDevices.count())
386 pDevice = m_midiDevices.at(iMidiItem);
387 if (pDevice == NULL)
388 iErrors++;
389 else if (!m_pChannel->setMidiDevice(pDevice->deviceID()))
390 iErrors++;
391 }
392 // MIDI input port number...
393 if (!m_pChannel->setMidiPort(m_ui.MidiPortSpinBox->value()))
394 iErrors++;
395 // MIDI input channel...
396 if (!m_pChannel->setMidiChannel(m_ui.MidiChannelComboBox->currentIndex()))
397 iErrors++;
398 // Engine name...
399 if (!m_pChannel->loadEngine(m_ui.EngineNameComboBox->currentText()))
400 iErrors++;
401 // Instrument file and index...
402 const QString& sPath = m_ui.InstrumentFileComboBox->currentText();
403 if (!sPath.isEmpty() && QFileInfo(sPath).exists()) {
404 if (!m_pChannel->loadInstrument(sPath, m_ui.InstrumentNrComboBox->currentIndex()))
405 iErrors++;
406 }
407 // MIDI intrument map...
408 if (!m_pChannel->setMidiMap(m_ui.MidiMapComboBox->currentIndex()))
409 iErrors++;
410 // Show error messages?
411 if (iErrors > 0) {
412 m_pChannel->appendMessagesError(
413 tr("Some channel settings could not be set.\n\nSorry."));
414 }
415 }
416
417 // Save default engine name, instrument directory and history...
418 pOptions->sInstrumentDir = QFileInfo(
419 m_ui.InstrumentFileComboBox->currentText()).dir().absolutePath();
420 pOptions->sEngineName = m_ui.EngineNameComboBox->currentText();
421 pOptions->sAudioDriver = m_ui.AudioDriverComboBox->currentText();
422 pOptions->sMidiDriver = m_ui.MidiDriverComboBox->currentText();
423 pOptions->iMidiMap = m_ui.MidiMapComboBox->currentIndex();
424 pOptions->saveComboBoxHistory(m_ui.InstrumentFileComboBox);
425
426 // Just go with dialog acceptance.
427 QDialog::accept();
428 }
429
430
431 // Reject settings (Cancel button slot).
432 void ChannelForm::reject (void)
433 {
434 bool bReject = true;
435
436 // Check if there's any pending changes...
437 if (m_iDirtyCount > 0 && m_ui.OkPushButton->isEnabled()) {
438 switch (QMessageBox::warning(this,
439 QSAMPLER_TITLE ": " + tr("Warning"),
440 tr("Some channel settings have been changed.\n\n"
441 "Do you want to apply the changes?"),
442 QMessageBox::Apply |
443 QMessageBox::Discard |
444 QMessageBox::Cancel)) {
445 case QMessageBox::Apply:
446 accept();
447 return;
448 case QMessageBox::Discard:
449 break;
450 default: // Cancel.
451 bReject = false;
452 break;
453 }
454 }
455
456 if (bReject)
457 QDialog::reject();
458 }
459
460
461 // Browse and open an instrument file.
462 void ChannelForm::openInstrumentFile (void)
463 {
464 MainForm *pMainForm = MainForm::getInstance();
465 if (pMainForm == NULL)
466 return;
467 if (pMainForm->client() == NULL)
468 return;
469
470 Options *pOptions = pMainForm->options();
471 if (pOptions == NULL)
472 return;
473
474 // FIXME: the instrument file filters should be restricted,
475 // depending on the current engine.
476 QString sInstrumentFile = QFileDialog::getOpenFileName(this,
477 QSAMPLER_TITLE ": " + tr("Instrument files"), // Caption.
478 pOptions->sInstrumentDir, // Start here.
479 tr("Instrument files") + " (*.gig *.dls)" // Filter (GIG and DLS files)
480 );
481
482 if (sInstrumentFile.isEmpty())
483 return;
484
485 m_ui.InstrumentFileComboBox->setEditText(sInstrumentFile);
486 updateInstrumentName();
487 }
488
489
490 // Refresh the actual instrument name.
491 void ChannelForm::updateInstrumentName (void)
492 {
493 MainForm *pMainForm = MainForm::getInstance();
494 if (pMainForm == NULL)
495 return;
496 if (pMainForm->client() == NULL)
497 return;
498
499 Options *pOptions = pMainForm->options();
500 if (pOptions == NULL)
501 return;
502
503 // Finally this better idea would be to use libgig
504 // to retrieve the REAL instrument names.
505 m_ui.InstrumentNrComboBox->clear();
506 m_ui.InstrumentNrComboBox->insertItems(0,
507 Channel::getInstrumentList(
508 m_ui.InstrumentFileComboBox->currentText(),
509 pOptions->bInstrumentNames)
510 );
511
512 optionsChanged();
513 }
514
515
516 // Show device options dialog.
517 void ChannelForm::setupDevice ( Device *pDevice,
518 Device::DeviceType deviceTypeMode,
519 const QString& sDriverName )
520 {
521 MainForm *pMainForm = MainForm::getInstance();
522 if (pMainForm == NULL)
523 return;
524 if (pMainForm->client() == NULL)
525 return;
526
527 // Create the device form if not already...
528 if (m_pDeviceForm == NULL) {
529 m_pDeviceForm = new DeviceForm(this, Qt::Dialog);
530 m_pDeviceForm->setAttribute(Qt::WA_ShowModal);
531 QObject::connect(m_pDeviceForm, SIGNAL(devicesChanged()),
532 this, SLOT(updateDevices()));
533 }
534
535 // Refresh the device form with selected data.
536 if (m_pDeviceForm) {
537 m_pDeviceForm->setDeviceTypeMode(deviceTypeMode);
538 m_pDeviceForm->refreshDevices();
539 m_pDeviceForm->setDevice(pDevice);
540 m_pDeviceForm->setDriverName(sDriverName);
541 m_pDeviceForm->show();
542 }
543 }
544
545
546 // Refresh MIDI driver item devices.
547 void ChannelForm::selectMidiDriverItem ( const QString& sMidiDriver )
548 {
549 MainForm *pMainForm = MainForm::getInstance();
550 if (pMainForm == NULL)
551 return;
552 if (pMainForm->client() == NULL)
553 return;
554
555 const QString sDriverName = sMidiDriver.toUpper();
556
557 // Save current device id.
558 // Save current device id.
559 int iDeviceID = 0;
560 Device *pDevice = NULL;
561 int iMidiItem = m_ui.MidiDeviceComboBox->currentIndex();
562 if (iMidiItem >= 0 && iMidiItem < m_midiDevices.count())
563 pDevice = m_midiDevices.at(iMidiItem);
564 if (pDevice)
565 iDeviceID = pDevice->deviceID();
566
567 // Clean maplist.
568 m_ui.MidiDeviceComboBox->clear();
569 qDeleteAll(m_midiDevices);
570 m_midiDevices.clear();
571
572 // Populate with the current ones...
573 const QPixmap midiPixmap(":/icons/midi2.png");
574 int *piDeviceIDs = Device::getDevices(pMainForm->client(),
575 Device::Midi);
576 for (int i = 0; piDeviceIDs && piDeviceIDs[i] >= 0; i++) {
577 pDevice = new Device(Device::Midi, piDeviceIDs[i]);
578 if (pDevice->driverName().toUpper() == sDriverName) {
579 m_ui.MidiDeviceComboBox->insertItem(0,
580 midiPixmap, pDevice->deviceName());
581 m_midiDevices.append(pDevice);
582 } else {
583 delete pDevice;
584 }
585 }
586
587 // Do proper enabling...
588 bool bEnabled = !m_midiDevices.isEmpty();
589 if (bEnabled) {
590 // Select the previous current device...
591 iMidiItem = 0;
592 QListIterator<Device *> iter(m_midiDevices);
593 while (iter.hasNext()) {
594 pDevice = iter.next();
595 if (pDevice->deviceID() == iDeviceID) {
596 m_ui.MidiDeviceComboBox->setCurrentIndex(iMidiItem);
597 selectMidiDeviceItem(iMidiItem);
598 break;
599 }
600 iMidiItem++;
601 }
602 } else {
603 m_ui.MidiDeviceComboBox->insertItem(0,
604 tr("(New MIDI %1 device)").arg(sMidiDriver));
605 }
606 m_ui.MidiDeviceTextLabel->setEnabled(bEnabled);
607 m_ui.MidiDeviceComboBox->setEnabled(bEnabled);
608 }
609
610
611 // Refresh MIDI device options slot.
612 void ChannelForm::selectMidiDriver ( const QString& sMidiDriver )
613 {
614 if (m_iDirtySetup > 0)
615 return;
616
617 selectMidiDriverItem(sMidiDriver);
618 optionsChanged();
619 }
620
621
622 // Select MIDI device item.
623 void ChannelForm::selectMidiDeviceItem ( int iMidiItem )
624 {
625 Device *pDevice = NULL;
626 if (iMidiItem >= 0 && iMidiItem < m_midiDevices.count())
627 pDevice = m_midiDevices.at(iMidiItem);
628 if (pDevice) {
629 const DeviceParamMap& params = pDevice->params();
630 int iPorts = params["PORTS"].value.toInt();
631 m_ui.MidiPortTextLabel->setEnabled(iPorts > 0);
632 m_ui.MidiPortSpinBox->setEnabled(iPorts > 0);
633 if (iPorts > 0)
634 m_ui.MidiPortSpinBox->setMaximum(iPorts - 1);
635 }
636 }
637
638
639 // Select MIDI device options slot.
640 void ChannelForm::selectMidiDevice ( int iMidiItem )
641 {
642 if (m_iDirtySetup > 0)
643 return;
644
645 selectMidiDeviceItem(iMidiItem);
646 optionsChanged();
647 }
648
649
650 // MIDI device options.
651 void ChannelForm::setupMidiDevice (void)
652 {
653 Device *pDevice = NULL;
654 int iMidiItem = m_ui.MidiDeviceComboBox->currentIndex();
655 if (iMidiItem >= 0 && iMidiItem < m_midiDevices.count())
656 pDevice = m_midiDevices.at(iMidiItem);
657 setupDevice(pDevice,
658 Device::Midi, m_ui.MidiDriverComboBox->currentText());
659 }
660
661
662 // Refresh Audio driver item devices.
663 void ChannelForm::selectAudioDriverItem ( const QString& sAudioDriver )
664 {
665 MainForm *pMainForm = MainForm::getInstance();
666 if (pMainForm == NULL)
667 return;
668 if (pMainForm->client() == NULL)
669 return;
670
671 const QString sDriverName = sAudioDriver.toUpper();
672
673 // Save current device id.
674 int iDeviceID = 0;
675 Device *pDevice = NULL;
676 int iAudioItem = m_ui.AudioDeviceComboBox->currentIndex();
677 if (iAudioItem >= 0 && iAudioItem < m_audioDevices.count())
678 pDevice = m_audioDevices.at(iAudioItem);
679 if (pDevice)
680 iDeviceID = pDevice->deviceID();
681
682 // Clean maplist.
683 m_ui.AudioDeviceComboBox->clear();
684 qDeleteAll(m_audioDevices);
685 m_audioDevices.clear();
686
687 // Populate with the current ones...
688 const QPixmap audioPixmap(":/icons/audio2.png");
689 int *piDeviceIDs = Device::getDevices(pMainForm->client(),
690 Device::Audio);
691 for (int i = 0; piDeviceIDs && piDeviceIDs[i] >= 0; i++) {
692 pDevice = new Device(Device::Audio, piDeviceIDs[i]);
693 if (pDevice->driverName().toUpper() == sDriverName) {
694 m_ui.AudioDeviceComboBox->insertItem(0,
695 audioPixmap, pDevice->deviceName());
696 m_audioDevices.append(pDevice);
697 } else {
698 delete pDevice;
699 }
700 }
701
702 // Do proper enabling...
703 bool bEnabled = !m_audioDevices.isEmpty();
704 if (bEnabled) {
705 // Select the previous current device...
706 iAudioItem = 0;
707 QListIterator<Device *> iter(m_audioDevices);
708 while (iter.hasNext()) {
709 pDevice = iter.next();
710 if (pDevice->deviceID() == iDeviceID) {
711 m_ui.AudioDeviceComboBox->setCurrentIndex(iAudioItem);
712 selectAudioDeviceItem(iAudioItem);
713 break;
714 }
715 iAudioItem++;
716 }
717 } else {
718 m_ui.AudioDeviceComboBox->insertItem(0,
719 tr("(New Audio %1 device)").arg(sAudioDriver));
720 //m_ui.AudioRoutingTable->setNumRows(0);
721 }
722 m_ui.AudioDeviceTextLabel->setEnabled(bEnabled);
723 m_ui.AudioDeviceComboBox->setEnabled(bEnabled);
724 m_ui.AudioRoutingTable->setEnabled(bEnabled);
725 }
726
727
728 // Refresh Audio device options slot.
729 void ChannelForm::selectAudioDriver ( const QString& sAudioDriver )
730 {
731 if (m_iDirtySetup > 0)
732 return;
733
734 selectAudioDriverItem(sAudioDriver);
735 optionsChanged();
736 }
737
738
739 // Select Audio device item.
740 void ChannelForm::selectAudioDeviceItem ( int iAudioItem )
741 {
742 Device *pDevice = NULL;
743 if (iAudioItem >= 0 && iAudioItem < m_audioDevices.count())
744 pDevice = m_audioDevices.at(iAudioItem);
745 if (pDevice) {
746 // Refresh the audio routing table.
747 m_routingModel.refresh(pDevice, m_pChannel->audioRouting());
748 // Reset routing change map.
749 m_routingModel.clear();
750 }
751 }
752
753
754 // Select Audio device options slot.
755 void ChannelForm::selectAudioDevice ( int iAudioItem )
756 {
757 if (m_iDirtySetup > 0)
758 return;
759
760 selectAudioDeviceItem(iAudioItem);
761 optionsChanged();
762 }
763
764
765 // Audio device options.
766 void ChannelForm::setupAudioDevice (void)
767 {
768 Device *pDevice = NULL;
769 int iAudioItem = m_ui.AudioDeviceComboBox->currentIndex();
770 if (iAudioItem >= 0 && iAudioItem < m_audioDevices.count())
771 pDevice = m_audioDevices.at(iAudioItem);
772 setupDevice(pDevice,
773 Device::Audio, m_ui.AudioDriverComboBox->currentText());
774 }
775
776 // UPdate all device lists slot.
777 void ChannelForm::updateDevices (void)
778 {
779 if (m_iDirtySetup > 0)
780 return;
781
782 selectMidiDriverItem(m_ui.MidiDriverComboBox->currentText());
783 selectAudioDriverItem(m_ui.AudioDriverComboBox->currentText());
784 optionsChanged();
785 }
786
787
788 // Dirty up settings.
789 void ChannelForm::optionsChanged (void)
790 {
791 if (m_iDirtySetup > 0)
792 return;
793
794 m_iDirtyCount++;
795 stabilizeForm();
796 }
797
798
799 // Stabilize current form state.
800 void ChannelForm::stabilizeForm (void)
801 {
802 const bool bValid =
803 m_ui.EngineNameComboBox->currentIndex() >= 0 &&
804 m_ui.EngineNameComboBox->currentText()
805 != Channel::noEngineName();
806 #if 0
807 const QString& sPath = InstrumentFileComboBox->currentText();
808 bValid = bValid && !sPath.isEmpty() && QFileInfo(sPath).exists();
809 #endif
810 m_ui.OkPushButton->setEnabled(m_iDirtyCount > 0 && bValid);
811 }
812
813
814 void ChannelForm::updateTableCellRenderers (void)
815 {
816 const int rows = m_routingModel.rowCount();
817 const int cols = m_routingModel.columnCount();
818 updateTableCellRenderers(
819 m_routingModel.index(0, 0),
820 m_routingModel.index(rows - 1, cols - 1));
821 }
822
823
824 void ChannelForm::updateTableCellRenderers (
825 const QModelIndex& topLeft, const QModelIndex& bottomRight )
826 {
827 for (int r = topLeft.row(); r <= bottomRight.row(); r++) {
828 for (int c = topLeft.column(); c <= bottomRight.column(); c++) {
829 const QModelIndex index = m_routingModel.index(r, c);
830 m_ui.AudioRoutingTable->openPersistentEditor(index);
831 }
832 }
833 }
834
835 } // namespace QSampler
836
837
838 // end of qsamplerChannelForm.cpp

  ViewVC Help
Powered by ViewVC