#include "mainwindow.h"
#include "ui_mainwindow.h"
-#include "pirkeysetwidgetitem.h"
-
-//#include "pirexception.h"
#include <QtCore/QCoreApplication>
#include <QMutex>
#include <QtGui/QMessageBox>
+//#include <QtGui>
#include <QSettings>
-//#include <QDesktopServices>
-//#include <QUrl>
-//#include <iostream>
+#include "pirkeysetwidgetitem.h"
+#include "pirselectkeysetform.h"
+#include "pirselectdeviceform.h"
+#include "pirpanelselectionform.h"
+#include "pirdocumentationform.h"
+#include "piraboutform.h"
+#include "pirkeysetmanager.h"
+#include "pirpanelmanager.h"
//#define DEBUGGING
+// Some ugly globals used for thread communications:
+
+// A global to show that a command is being processed:
+bool commandInFlight = false;
+QMutex commandIFMutex;
+
+// The stopRepeatingFlag boolean is the method used to tell running commands
+// in the worker thread to stop:
+bool stopRepeatingFlag = false;
+QMutex stopRepeatingMutex;
+
+
extern PIRMakeMgr makeManager;
: QMainWindow(parent),
ui(new Ui::MainWindow),
selectKeysetForm(0),
+ selectDeviceForm(0),
+ panelSelectionForm(0),
documentationForm(0),
aboutForm(0),
currentKeyset(0)
// Make this a Maemo 5 stacked widget:
setAttribute(Qt::WA_Maemo5StackedWindow);
- // Collect the keysets:
- myKeysets = new PIRKeysetManager(this);
+ // Create the managers:
+ myKeysets = new PIRKeysetManager();
+ myPanels = new PIRPanelManager(this);
// Set up the keyset selection window:
selectKeysetForm = new PIRSelectKeysetForm(this);
- myKeysets->populateGuiWidget(selectKeysetForm);
+ // Set up the device selection window:
+ selectDeviceForm = new PIRSelectDeviceForm(this);
+
+ // Set up the panel selection window:
+ panelSelectionForm = new PIRPanelSelectionForm(this);
+
+ myKeysets->populateSelectionWidgets(selectKeysetForm, selectDeviceForm);
+// myPanels->setupPanels(panelSelectionForm);
// Remember any favorites the user has already set:
populateFavorites();
+ // Retrieve the user's most recent keyset (if any):
QSettings settings("pietrzak.org", "Pierogi");
- if (settings.contains("currentKeyset"))
+ if (settings.contains("currentKeysetName"))
{
- currentKeyset = settings.value("currentKeyset").toInt();
+ myKeysets->findKeysetID(
+ settings.value("currentKeysetMake").toString(),
+ settings.value("currentKeysetName").toString(),
+ currentKeyset);
+// currentKeyset = settings.value("currentKeyset").toInt();
}
enableButtons();
+ QListWidget *fkw = myPanels->getFavoritesListWidget();
+
connect(
- ui->favoriteKeysetsWidget,
+ fkw,
SIGNAL(itemActivated(QListWidgetItem *)),
this,
SLOT(keysetSelectionChanged(QListWidgetItem *)),
Qt::QueuedConnection);
- // Make sure the two selection lists don't show different selections:
+ // Make sure the three selection lists don't show different selections:
QListWidget *klw = selectKeysetForm->getKeysetListWidget();
+ QListWidget *dlw = selectDeviceForm->getDeviceListWidget();
+
+ // favorites -> keyset name
+ connect(
+ fkw,
+ SIGNAL(itemActivated(QListWidgetItem *)),
+ klw,
+ SLOT(clearSelection()),
+ Qt::QueuedConnection);
+
+ // favorites -> device name
connect(
- ui->favoriteKeysetsWidget,
+ fkw,
SIGNAL(itemActivated(QListWidgetItem *)),
+ dlw,
+ SLOT(clearSelection()),
+ Qt::QueuedConnection);
+
+ // keyset name -> favorites
+ connect(
klw,
+ SIGNAL(itemActivated(QListWidgetItem *)),
+ fkw,
+ SLOT(clearSelection()),
+ Qt::QueuedConnection);
+
+ // device name -> favorites
+ connect(
+ dlw,
+ SIGNAL(itemActivated(QListWidgetItem *)),
+ fkw,
SLOT(clearSelection()),
Qt::QueuedConnection);
+ // keyset name -> device name
connect(
klw,
SIGNAL(itemActivated(QListWidgetItem *)),
- ui->favoriteKeysetsWidget,
+ dlw,
+ SLOT(clearSelection()),
+ Qt::QueuedConnection);
+
+ // device name -> keyset name
+ connect(
+ dlw,
+ SIGNAL(itemActivated(QListWidgetItem *)),
+ klw,
SLOT(clearSelection()),
Qt::QueuedConnection);
{
delete myKeysets;
if (selectKeysetForm) delete selectKeysetForm;
+ if (selectDeviceForm) delete selectDeviceForm;
+ if (panelSelectionForm) delete panelSelectionForm;
if (documentationForm) delete documentationForm;
if (aboutForm) delete aboutForm;
delete ui;
void MainWindow::enableButtons()
{
- // This is going to be a little painful...
- // Main keys
- emit powerEnabled(myKeysets->hasKey(currentKeyset, Power_Key));
- emit volumeUpEnabled(myKeysets->hasKey(currentKeyset, VolumeUp_Key));
- emit volumeDownEnabled(myKeysets->hasKey(currentKeyset, VolumeDown_Key));
- emit channelUpEnabled(myKeysets->hasKey(currentKeyset, ChannelUp_Key));
- emit channelDownEnabled(myKeysets->hasKey(currentKeyset, ChannelDown_Key));
-
- // Utility keys:
- emit redEnabled(myKeysets->hasKey(currentKeyset, Red_Key));
- emit greenEnabled(myKeysets->hasKey(currentKeyset, Green_Key));
- emit yellowEnabled(myKeysets->hasKey(currentKeyset, Yellow_Key));
- emit blueEnabled(myKeysets->hasKey(currentKeyset, Blue_Key));
- emit aspectRatioEnabled(myKeysets->hasKey(currentKeyset, AspectRatio_Key));
- emit surroundEnabled(myKeysets->hasKey(currentKeyset, Surround_Key));
- emit languageEnabled(myKeysets->hasKey(currentKeyset, Language_Key));
- emit favoritesEnabled(myKeysets->hasKey(currentKeyset, Favorites_Key));
- emit captionsEnabled(myKeysets->hasKey(currentKeyset, Captions_Key));
- emit sleepEnabled(myKeysets->hasKey(currentKeyset, Sleep_Key));
- emit inputEnabled(myKeysets->hasKey(currentKeyset, Input_Key));
- emit muteEnabled(myKeysets->hasKey(currentKeyset, Mute_Key));
-
- // Keypad keys
- emit zeroEnabled(myKeysets->hasKey(currentKeyset, Zero_Key));
- emit oneEnabled(myKeysets->hasKey(currentKeyset, One_Key));
- emit twoEnabled(myKeysets->hasKey(currentKeyset, Two_Key));
- emit threeEnabled(myKeysets->hasKey(currentKeyset, Three_Key));
- emit fourEnabled(myKeysets->hasKey(currentKeyset, Four_Key));
- emit fiveEnabled(myKeysets->hasKey(currentKeyset, Five_Key));
- emit sixEnabled(myKeysets->hasKey(currentKeyset, Six_Key));
- emit sevenEnabled(myKeysets->hasKey(currentKeyset, Seven_Key));
- emit eightEnabled(myKeysets->hasKey(currentKeyset, Eight_Key));
- emit nineEnabled(myKeysets->hasKey(currentKeyset, Nine_Key));
- emit enterEnabled(myKeysets->hasKey(currentKeyset, Enter_Key));
- emit clearEnabled(myKeysets->hasKey(currentKeyset, Clear_Key));
- emit dashEnabled(myKeysets->hasKey(currentKeyset, Dash_Key));
- emit plusOneHundredEnabled(myKeysets->hasKey(currentKeyset, PlusOneHundred_Key));
- emit doubleDigitEnabled(myKeysets->hasKey(currentKeyset, DoubleDigit_Key));
- emit prevChannelEnabled(myKeysets->hasKey(currentKeyset, PrevChannel_Key));
-
- // Menu keys:
- emit menuEnabled(myKeysets->hasKey(currentKeyset, Menu_Key));
- emit upEnabled(myKeysets->hasKey(currentKeyset, Up_Key));
- emit downEnabled(myKeysets->hasKey(currentKeyset, Down_Key));
- emit leftEnabled(myKeysets->hasKey(currentKeyset, Left_Key));
- emit rightEnabled(myKeysets->hasKey(currentKeyset, Right_Key));
- emit selectEnabled(myKeysets->hasKey(currentKeyset, Select_Key));
- emit exitEnabled(myKeysets->hasKey(currentKeyset, Exit_Key));
- emit infoEnabled(myKeysets->hasKey(currentKeyset, Info_Key));
- emit guideEnabled(myKeysets->hasKey(currentKeyset, Guide_Key));
-
- // Media keys:
- emit playEnabled(myKeysets->hasKey(currentKeyset, Play_Key));
- emit pauseEnabled(myKeysets->hasKey(currentKeyset, Pause_Key));
- emit stopEnabled(myKeysets->hasKey(currentKeyset, Stop_Key));
- emit fastForwardEnabled(myKeysets->hasKey(currentKeyset, FastForward_Key));
- emit reverseEnabled(myKeysets->hasKey(currentKeyset, Rewind_Key));
- emit nextEnabled(myKeysets->hasKey(currentKeyset, Next_Key));
- emit previousEnabled(myKeysets->hasKey(currentKeyset, Previous_Key));
- emit stepForwardEnabled(myKeysets->hasKey(currentKeyset, StepForward_Key));
- emit stepBackEnabled(myKeysets->hasKey(currentKeyset, StepBack_Key));
- emit advanceEnabled(myKeysets->hasKey(currentKeyset, Advance_Key));
- emit replayEnabled(myKeysets->hasKey(currentKeyset, Replay_Key));
- emit ejectEnabled(myKeysets->hasKey(currentKeyset, Eject_Key));
-
- // Other keys:
- emit pipEnabled(myKeysets->hasKey(currentKeyset, PIP_Key));
- emit pipSwapEnabled(myKeysets->hasKey(currentKeyset, PIPSwap_Key));
- emit pipMoveEnabled(myKeysets->hasKey(currentKeyset, PIPMove_Key));
- emit pipSourceEnabled(myKeysets->hasKey(currentKeyset, PIPSource_Key));
- emit scanEnabled(myKeysets->hasKey(currentKeyset, Scan_Key));
- emit programEnabled(myKeysets->hasKey(currentKeyset, Program_Key));
- emit pictureModeEnabled(myKeysets->hasKey(currentKeyset, PictureMode_Key));
- emit soundModeEnabled(myKeysets->hasKey(currentKeyset, SoundMode_Key));
- emit discTitleEnabled(myKeysets->hasKey(currentKeyset, DiscTitle_Key));
- emit discMenuEnabled(myKeysets->hasKey(currentKeyset, DiscMenu_Key));
- emit discSelectEnabled(myKeysets->hasKey(currentKeyset, DiscSelect_Key));
- emit recordEnabled(myKeysets->hasKey(currentKeyset, Record_Key));
- emit trackingMinusEnabled(myKeysets->hasKey(currentKeyset, TrackingMinus_Key));
- emit trackingPlusEnabled(myKeysets->hasKey(currentKeyset, TrackingPlus_Key));
- emit autoTrackingEnabled(myKeysets->hasKey(currentKeyset, AutoTracking_Key));
- emit vhsSpeedEnabled(myKeysets->hasKey(currentKeyset, VHSSpeed_Key));
-
- emit keysetMakeChanged(
- makeManager.getMakeString(myKeysets->getMake(currentKeyset)));
+ // Just to be sure, check to see if the keyset has been populated:
+ myKeysets->populateKeyset(this, currentKeyset);
- emit keysetNameChanged(myKeysets->getDisplayName(currentKeyset));
+ myPanels->enableButtons(myKeysets, currentKeyset);
}
}
-// Main tab buttons:
+// Menu actions:
-void MainWindow::on_powerButton_pressed()
+void MainWindow::on_actionSelectKeyset_triggered()
{
- emit buttonPressed(currentKeyset, Power_Key);
+ selectKeysetForm->show();
}
-void MainWindow::on_powerButton_released()
+void MainWindow::on_actionSelect_Device_By_Name_triggered()
{
- stopRepeating();
+ selectDeviceForm->show();
}
-void MainWindow::on_mainChannelUpButton_pressed()
+void MainWindow::on_actionArrange_Button_Panels_triggered()
{
- emit buttonPressed(currentKeyset, ChannelUp_Key);
+ panelSelectionForm->show();
}
-void MainWindow::on_mainChannelUpButton_released()
+void MainWindow::on_actionAbout_triggered()
{
- stopRepeating();
-}
+ if (!aboutForm)
+ {
+ aboutForm = new PIRAboutForm(this);
+ }
-void MainWindow::on_mainChannelDownButton_pressed()
-{
- emit buttonPressed(currentKeyset, ChannelDown_Key);
+ aboutForm->show();
}
-void MainWindow::on_mainChannelDownButton_released()
+void MainWindow::on_actionDocumentation_triggered()
{
- stopRepeating();
-}
+ if (!documentationForm)
+ {
+ documentationForm = new PIRDocumentationForm(this);
+ }
-void MainWindow::on_mainVolumeUp_pressed()
-{
- emit buttonPressed(currentKeyset, VolumeUp_Key);
+ documentationForm->show();
}
-void MainWindow::on_mainVolumeUp_released()
-{
- stopRepeating();
-}
-void MainWindow::on_mainVolumeDownButton_pressed()
-{
- emit buttonPressed(currentKeyset, VolumeDown_Key);
-}
+// Other actions:
-void MainWindow::on_mainVolumeDownButton_released()
+void MainWindow::keysetSelectionChanged(
+ QListWidgetItem *item)
{
- stopRepeating();
-}
+ if (!item) return; // Should probably display error message here!
+ PIRKeysetWidgetItem *kwi = dynamic_cast<PIRKeysetWidgetItem *>(item);
-// Utility tab buttons:
+ if (!kwi) return; // Also need to say something here
-void MainWindow::on_redButton_pressed()
-{
- emit buttonPressed(currentKeyset, Red_Key);
-}
+ if (currentKeyset == kwi->getID())
+ {
+ // We're already on that keyset, so nothing to do:
+ return;
+ }
+
+ currentKeyset = kwi->getID();
-void MainWindow::on_redButton_released()
-{
- stopRepeating();
-}
+ QSettings settings("pietrzak.org", "Pierogi");
+// settings.setValue("currentKeyset", currentKeyset);
-void MainWindow::on_greenButton_pressed()
-{
- emit buttonPressed(currentKeyset, Green_Key);
-}
+ settings.setValue(
+ "currentKeysetMake",
+ makeManager.getMakeString(kwi->getMake()));
-void MainWindow::on_greenButton_released()
-{
- stopRepeating();
-}
+ settings.setValue(
+ "currentKeysetName",
+ myKeysets->getDisplayName(currentKeyset));
-void MainWindow::on_yellowButton_pressed()
-{
- emit buttonPressed(currentKeyset, Yellow_Key);
+ enableButtons();
}
-void MainWindow::on_yellowButton_released()
-{
- stopRepeating();
-}
-void MainWindow::on_blueButton_pressed()
+void MainWindow::finalCleanup()
{
- emit buttonPressed(currentKeyset, Blue_Key);
-}
+ // Perform any necessary cleanup work here.
-void MainWindow::on_blueButton_released()
-{
+ // Make certain that the thread stops repeating:
stopRepeating();
}
-void MainWindow::on_aspectRatioButton_pressed()
-{
- emit buttonPressed(currentKeyset, AspectRatio_Key);
-}
-void MainWindow::on_aspectRatioButton_released()
+void MainWindow::addCurrentKeyset(
+ QListWidget *qlw)
{
- stopRepeating();
-}
+ // Is the current keyset already a favorite?
+ int count = qlw->count();
+ int index = 0;
+ PIRKeysetWidgetItem *kwi = NULL;
+ while (index < count)
+ {
+ kwi = dynamic_cast<PIRKeysetWidgetItem *>(
+ qlw->item(index));
-void MainWindow::on_surroundButton_pressed()
-{
- emit buttonPressed(currentKeyset, Surround_Key);
-}
+ if (kwi && (kwi->getID() == currentKeyset))
+ {
+ // Current keyset already in list! No need to continue.
+ return;
+ }
+ ++index;
+ }
-void MainWindow::on_surroundButton_released()
-{
- stopRepeating();
-}
+ // Ok, add the current keyset to the favorites:
+ PIRMakeName make = myKeysets->getMake(currentKeyset);
-void MainWindow::on_languageButton_pressed()
-{
- emit buttonPressed(currentKeyset, Language_Key);
-}
+ QString name = makeManager.getMakeString(make);
+ name.append(" ");
+ name.append(myKeysets->getDisplayName(currentKeyset));
-void MainWindow::on_languageButton_released()
-{
- stopRepeating();
-}
+ qlw->addItem(new PIRKeysetWidgetItem(name, currentKeyset, make));
-void MainWindow::on_favoritesButton_pressed()
-{
- emit buttonPressed(currentKeyset, Favorites_Key);
-}
+ // And, add the keyset id to the persistent list:
+ QSettings settings("pietrzak.org", "Pierogi");
-void MainWindow::on_favoritesButton_released()
-{
- stopRepeating();
-}
+ int favSettingsSize = settings.beginReadArray("favorites");
+ settings.endArray();
-void MainWindow::on_captionButton_pressed()
-{
- emit buttonPressed(currentKeyset, Captions_Key);
-}
+ settings.beginWriteArray("favorites");
+ settings.setArrayIndex(favSettingsSize);
+// settings.setValue("keysetID", currentKeyset);
-void MainWindow::on_captionButton_released()
-{
- stopRepeating();
-}
+ settings.setValue(
+ "keysetMake",
+ makeManager.getMakeString(myKeysets->getMake(currentKeyset)));
-void MainWindow::on_inputButton_pressed()
-{
- emit buttonPressed(currentKeyset, Input_Key);
-}
+ settings.setValue("keysetName", myKeysets->getDisplayName(currentKeyset));
-void MainWindow::on_inputButton_released()
-{
- stopRepeating();
+ settings.endArray();
}
-void MainWindow::on_sleepButton_pressed()
-{
- emit buttonPressed(currentKeyset, Sleep_Key);
-}
-void MainWindow::on_sleepButton_released()
+void MainWindow::removeFavoriteKeyset(
+ QListWidget *qlw)
{
- stopRepeating();
-}
+ // Deleting an item removes it from the list, so just grab the currently
+ // selected item and delete it:
+ QListWidgetItem *item = qlw->currentItem();
-void MainWindow::on_muteButton_pressed()
-{
- emit buttonPressed(currentKeyset, Mute_Key);
-}
+ if (item) delete item;
-void MainWindow::on_muteButton_released()
-{
- stopRepeating();
-}
+ // Remove this item from the persistent list. Well, actually, it seems a
+ // little more convenient to just blow away the existing list of favorites
+ // and rewrite it, as modifying an existing QSettings array in the middle
+ // seems a bit hard...
+ QSettings settings("pietrzak.org", "Pierogi");
+ settings.remove("favorites");
-// Keypad tab buttons:
+ int count = qlw->count();
-void MainWindow::on_oneButton_pressed()
-{
- emit buttonPressed(currentKeyset, One_Key);
-}
+ // If the count is empty, we can stop right here:
+ if (count == 0) return;
-void MainWindow::on_oneButton_released()
-{
- stopRepeating();
-}
+ int index = 0;
+ unsigned int id;
+ PIRKeysetWidgetItem *kwi = NULL;
+ settings.beginWriteArray("favorites");
+ while (index < count)
+ {
+ kwi = dynamic_cast<PIRKeysetWidgetItem *>(qlw->item(index));
-void MainWindow::on_twoButton_pressed()
-{
- emit buttonPressed(currentKeyset, Two_Key);
-}
+ settings.setArrayIndex(index);
+// settings.setValue("keysetID", kwi->getID());
+ id = kwi->getID();
-void MainWindow::on_twoButton_released()
-{
- stopRepeating();
-}
+ settings.setValue(
+ "keysetMake",
+ makeManager.getMakeString(myKeysets->getMake(id)));
-void MainWindow::on_threeButton_pressed()
-{
- emit buttonPressed(currentKeyset, Three_Key);
-}
+ settings.setValue("keysetName", myKeysets->getDisplayName(id));
-void MainWindow::on_threeButton_released()
-{
- stopRepeating();
+ ++index;
+ }
+ settings.endArray();
}
-void MainWindow::on_fourButton_pressed()
-{
- emit buttonPressed(currentKeyset, Four_Key);
-}
-void MainWindow::on_fourButton_released()
+void MainWindow::populateFavorites()
{
- stopRepeating();
-}
+ QSettings settings("pietrzak.org", "Pierogi");
-void MainWindow::on_fiveButton_pressed()
-{
- emit buttonPressed(currentKeyset, Five_Key);
-}
+ int size = settings.beginReadArray("favorites");
+ int index = 0;
+ QString make;
+ QString name;
+ PIRKeysetWidgetItem *kwi;
-void MainWindow::on_fiveButton_released()
-{
- stopRepeating();
-}
+ while (index < size)
+ {
+ settings.setArrayIndex(index);
+ make = settings.value("keysetMake").toString();
+ name = settings.value("keysetName").toString();
-void MainWindow::on_sixButton_pressed()
-{
- emit buttonPressed(currentKeyset, Six_Key);
-}
+ kwi = myKeysets->makeKeysetItem(make, name);
-void MainWindow::on_sixButton_released()
-{
- stopRepeating();
-}
+ // Did the item creation work?
+ if (kwi)
+ {
+ // Keyset does exist, so continue:
+ myPanels->addFavoritesItem(kwi);
+ }
-void MainWindow::on_sevenButton_pressed()
-{
- emit buttonPressed(currentKeyset, Seven_Key);
-}
+ ++index;
+ }
-void MainWindow::on_sevenButton_released()
-{
- stopRepeating();
+ settings.endArray();
}
-void MainWindow::on_eightButton_pressed()
-{
- emit buttonPressed(currentKeyset, Eight_Key);
-}
-void MainWindow::on_eightButton_released()
+void MainWindow::startRepeating(
+ PIRKeyName name)
{
- stopRepeating();
+ QMutexLocker locker(&commandIFMutex);
+ if (!commandInFlight)
+ {
+ commandInFlight = true;
+ emit buttonPressed(currentKeyset, name);
+ }
}
-void MainWindow::on_nineButton_pressed()
-{
- emit buttonPressed(currentKeyset, Nine_Key);
-}
-void MainWindow::on_nineButton_released()
+void MainWindow::stopRepeating()
{
- stopRepeating();
+ QMutexLocker locker(&stopRepeatingMutex);
+ stopRepeatingFlag = true;
}
-void MainWindow::on_zeroButton_pressed()
-{
- emit buttonPressed(currentKeyset, Zero_Key);
-}
-void MainWindow::on_zeroButton_released()
+void MainWindow::selectPrevFavKeyset()
{
- stopRepeating();
+ myPanels->selectPrevFavKeyset();
}
-void MainWindow::on_enterButton_pressed()
-{
- emit buttonPressed(currentKeyset, Enter_Key);
-}
-void MainWindow::on_enterButton_released()
+void MainWindow::selectNextFavKeyset()
{
- stopRepeating();
+ myPanels->selectNextFavKeyset();
}
-void MainWindow::on_clearButton_pressed()
-{
- emit buttonPressed(currentKeyset, Clear_Key);
-}
-void MainWindow::on_clearButton_released()
+void MainWindow::managePanel(
+ PIRPanelName name,
+ int state)
{
- stopRepeating();
+ myPanels->managePanel(name, state);
}
-void MainWindow::on_prevChannelButton_pressed()
-{
- emit buttonPressed(currentKeyset, PrevChannel_Key);
-}
-void MainWindow::on_prevChannelButton_released()
+void MainWindow::insertPanel(
+ int index,
+ QWidget *panel,
+ const QString &displayName)
{
- stopRepeating();
+ ui->stackedButtonsWidget->insertWidget(index, panel);
+ ui->selectPanelComboBox->insertItem(index, displayName);
}
-void MainWindow::on_plusOneHundredButton_pressed()
-{
- emit buttonPressed(currentKeyset, PlusOneHundred_Key);
-}
-void MainWindow::on_plusOneHundredButton_released()
+void MainWindow::removePanel(
+ int index,
+ QWidget *panel)
{
- stopRepeating();
+ ui->stackedButtonsWidget->removeWidget(panel);
+ ui->selectPanelComboBox->removeItem(index);
}
-void MainWindow::on_dashButton_pressed()
-{
- emit buttonPressed(currentKeyset, Dash_Key);
-}
-void MainWindow::on_dashButton_released()
+void MainWindow::on_prevPanelButton_clicked()
{
- stopRepeating();
-}
+ int count = ui->selectPanelComboBox->count();
-void MainWindow::on_doubleDigitButton_pressed()
-{
- emit buttonPressed(currentKeyset, DoubleDigit_Key);
-}
+ // No need to do anything if there are less than two panels available:
+ if (count < 2) return;
-void MainWindow::on_doubleDigitButton_released()
-{
- stopRepeating();
-}
+ int index = ui->selectPanelComboBox->currentIndex();
+ if (index == 0)
+ {
+ index = count - 1;
+ }
+ else
+ {
+ --index;
+ }
+ ui->selectPanelComboBox->setCurrentIndex(index);
+}
-// Menu tab buttons:
-void MainWindow::on_upButton_pressed()
+void MainWindow::on_nextPanelButton_clicked()
{
- emit buttonPressed(currentKeyset, Up_Key);
-}
+ int count = ui->selectPanelComboBox->count();
-void MainWindow::on_upButton_released()
-{
- stopRepeating();
-}
-
-void MainWindow::on_leftButton_pressed()
-{
- emit buttonPressed(currentKeyset, Left_Key);
-}
-
-void MainWindow::on_leftButton_released()
-{
- stopRepeating();
-}
-
-void MainWindow::on_rightButton_pressed()
-{
- emit buttonPressed(currentKeyset, Right_Key);
-}
-
-void MainWindow::on_rightButton_released()
-{
- stopRepeating();
-}
-
-void MainWindow::on_downButton_pressed()
-{
- emit buttonPressed(currentKeyset, Down_Key);
-}
-
-void MainWindow::on_downButton_released()
-{
- stopRepeating();
-}
-
-void MainWindow::on_selectButton_pressed()
-{
- emit buttonPressed(currentKeyset, Select_Key);
-}
-
-void MainWindow::on_selectButton_released()
-{
- stopRepeating();
-}
-
-void MainWindow::on_menuButton_pressed()
-{
- emit buttonPressed(currentKeyset, Menu_Key);
-}
-
-void MainWindow::on_menuButton_released()
-{
- stopRepeating();
-}
-
-void MainWindow::on_exitButton_pressed()
-{
- emit buttonPressed(currentKeyset, Exit_Key);
-}
-
-void MainWindow::on_exitButton_released()
-{
- stopRepeating();
-}
-
-
-
-// Media tab buttons:
-
-void MainWindow::on_mediaPreviousButton_pressed()
-{
- emit buttonPressed(currentKeyset, Previous_Key);
-}
-
-void MainWindow::on_mediaPreviousButton_released()
-{
- stopRepeating();
-}
-
-void MainWindow::on_mediaNextButton_pressed()
-{
- emit buttonPressed(currentKeyset, Next_Key);
-}
-
-void MainWindow::on_mediaNextButton_released()
-{
- stopRepeating();
-}
-
-void MainWindow::on_replayButton_pressed()
-{
- emit buttonPressed(currentKeyset, Replay_Key);
-}
-
-void MainWindow::on_replayButton_released()
-{
- stopRepeating();
-}
-
-void MainWindow::on_advanceButton_pressed()
-{
- emit buttonPressed(currentKeyset, Advance_Key);
-}
-
-void MainWindow::on_advanceButton_released()
-{
- stopRepeating();
-}
-
-void MainWindow::on_stepBackButton_pressed()
-{
- emit buttonPressed(currentKeyset, StepBack_Key);
-}
-
-void MainWindow::on_stepBackButton_released()
-{
- stopRepeating();
-}
-
-void MainWindow::on_stepForwardButton_pressed()
-{
- emit buttonPressed(currentKeyset, StepForward_Key);
-}
-
-void MainWindow::on_stepForwardButton_released()
-{
- stopRepeating();
-}
-
-void MainWindow::on_reverseButton_pressed()
-{
- emit buttonPressed(currentKeyset, Rewind_Key);
-}
-
-void MainWindow::on_reverseButton_released()
-{
- stopRepeating();
-}
-
-void MainWindow::on_fastForwardButton_pressed()
-{
- emit buttonPressed(currentKeyset, FastForward_Key);
-}
-
-void MainWindow::on_fastForwardButton_released()
-{
- stopRepeating();
-}
-
-void MainWindow::on_playButton_pressed()
-{
- emit buttonPressed(currentKeyset, Play_Key);
-}
-
-void MainWindow::on_playButton_released()
-{
- stopRepeating();
-}
-
-void MainWindow::on_pauseButton_pressed()
-{
- emit buttonPressed(currentKeyset, Pause_Key);
-}
-
-void MainWindow::on_pauseButton_released()
-{
- stopRepeating();
-}
-
-void MainWindow::on_stopButton_pressed()
-{
- emit buttonPressed(currentKeyset, Stop_Key);
-}
-
-void MainWindow::on_stopButton_released()
-{
- stopRepeating();
-}
-
-void MainWindow::on_ejectButton_pressed()
-{
- emit buttonPressed(currentKeyset, Eject_Key);
-}
-
-void MainWindow::on_ejectButton_released()
-{
- stopRepeating();
-}
-
-
-// Misc tab slots:
-
-void MainWindow::on_pipOnOffButton_pressed()
-{
- emit buttonPressed(currentKeyset, PIP_Key);
-}
-
-void MainWindow::on_pipOnOffButton_released()
-{
- stopRepeating();
-}
-
-void MainWindow::on_pipSwapButton_pressed()
-{
- emit buttonPressed(currentKeyset, PIPSwap_Key);
-}
-
-void MainWindow::on_pipSwapButton_released()
-{
- stopRepeating();
-}
-
-void MainWindow::on_pipPositionButton_pressed()
-{
- emit buttonPressed(currentKeyset, PIPMove_Key);
-}
-
-void MainWindow::on_pipPositionButton_released()
-{
- stopRepeating();
-}
-
-void MainWindow::on_pipSourceButton_pressed()
-{
- emit buttonPressed(currentKeyset, PIPSource_Key);
-}
-
-void MainWindow::on_pipSourceButton_released()
-{
- stopRepeating();
-}
-
-void MainWindow::on_scanButton_pressed()
-{
- emit buttonPressed(currentKeyset, Scan_Key);
-}
-
-void MainWindow::on_scanButton_released()
-{
- stopRepeating();
-}
-
-void MainWindow::on_programButton_pressed()
-{
- emit buttonPressed(currentKeyset, Program_Key);
-}
-
-void MainWindow::on_programButton_released()
-{
- stopRepeating();
-}
-
-void MainWindow::on_pictureModeButton_pressed()
-{
- emit buttonPressed(currentKeyset, PictureMode_Key);
-}
-
-void MainWindow::on_pictureModeButton_released()
-{
- stopRepeating();
-}
+ // No need to do anything if there are less than two panels available:
+ if (count < 2) return;
-void MainWindow::on_soundModeButton_pressed()
-{
- emit buttonPressed(currentKeyset, SoundMode_Key);
-}
-
-void MainWindow::on_soundModeButton_released()
-{
- stopRepeating();
-}
-
-void MainWindow::on_discTitleButton_pressed()
-{
- emit buttonPressed(currentKeyset, DiscTitle_Key);
-}
-
-void MainWindow::on_discTitleButton_released()
-{
- stopRepeating();
-}
-
-void MainWindow::on_discMenuButton_pressed()
-{
- emit buttonPressed(currentKeyset, DiscMenu_Key);
-}
-
-void MainWindow::on_discMenuButton_released()
-{
- stopRepeating();
-}
-
-void MainWindow::on_discSelectButton_pressed()
-{
- emit buttonPressed(currentKeyset, DiscSelect_Key);
-}
-
-void MainWindow::on_discSelectButton_released()
-{
- stopRepeating();
-}
-
-void MainWindow::on_trackingPlusButton_pressed()
-{
- emit buttonPressed(currentKeyset, TrackingPlus_Key);
-}
-
-void MainWindow::on_trackingPlusButton_released()
-{
- stopRepeating();
-}
-
-void MainWindow::on_trackingMinusButton_pressed()
-{
- emit buttonPressed(currentKeyset, TrackingMinus_Key);
-}
-
-void MainWindow::on_trackingMinusButton_released()
-{
- stopRepeating();
-}
-
-void MainWindow::on_autoTrackingButton_pressed()
-{
- emit buttonPressed(currentKeyset, AutoTracking_Key);
-}
-
-void MainWindow::on_autoTrackingButton_released()
-{
- stopRepeating();
-}
-
-void MainWindow::on_vhsSpeedButton_pressed()
-{
- emit buttonPressed(currentKeyset, VHSSpeed_Key);
-}
-
-void MainWindow::on_vhsSpeedButton_released()
-{
- stopRepeating();
-}
-
-void MainWindow::on_recordButton_pressed()
-{
- emit buttonPressed(currentKeyset, Record_Key);
-}
-
-void MainWindow::on_recordButton_released()
-{
- stopRepeating();
-}
-
-
-// Menu actions:
-
-void MainWindow::on_actionSelectKeyset_triggered()
-{
- selectKeysetForm->show();
-}
-
-void MainWindow::on_actionAbout_triggered()
-{
- if (!aboutForm)
- {
- aboutForm = new PIRAboutForm(this);
- }
-
- aboutForm->show();
-}
-
-void MainWindow::on_actionDocumentation_triggered()
-{
- if (!documentationForm)
+ int index = ui->selectPanelComboBox->currentIndex();
+ if (index == count - 1)
{
- documentationForm = new PIRDocumentationForm(this);
+ index = 0;
}
-
- documentationForm->show();
-}
-
-
-// Other actions:
-
-void MainWindow::keysetSelectionChanged(
- QListWidgetItem *item)
-{
- if (!item) return; // Should probably say something here!
-
- PIRKeysetWidgetItem *kwi = dynamic_cast<PIRKeysetWidgetItem *>(item);
-
- if (!kwi) return; // Also need to say something here
-
- currentKeyset = kwi->getID();
-
- QSettings settings("pietrzak.org", "Pierogi");
- settings.setValue("currentKeyset", currentKeyset);
-
- enableButtons();
-}
-
-
-void MainWindow::on_addKeysetButton_clicked()
-{
- // Is the current keylist already a favorite?
- int count = ui->favoriteKeysetsWidget->count();
- int index = 0;
- PIRKeysetWidgetItem *kwi = NULL;
- while (index < count)
+ else
{
- kwi = dynamic_cast<PIRKeysetWidgetItem *>(
- ui->favoriteKeysetsWidget->item(index));
-
- if (kwi && (kwi->getID() == currentKeyset))
- {
- // Current keyset already in list! No need to continue.
- return;
- }
++index;
}
- // Ok, add the current keylist to the favorites:
- PIRMakeName make = myKeysets->getMake(currentKeyset);
-
- QString name = makeManager.getMakeString(make);
- name.append(" ");
- name.append(myKeysets->getDisplayName(currentKeyset));
-
- ui->favoriteKeysetsWidget->addItem(
- new PIRKeysetWidgetItem(name, currentKeyset, make));
-
- // And, add the keylist id to the persistent list:
- QSettings settings("pietrzak.org", "Pierogi");
-
- int favSettingsSize = settings.beginReadArray("favorites");
- settings.endArray();
-
- settings.beginWriteArray("favorites");
- settings.setArrayIndex(favSettingsSize);
- settings.setValue("keylistID", currentKeyset);
- settings.endArray();
+ ui->selectPanelComboBox->setCurrentIndex(index);
}
-void MainWindow::on_removeKeysetButton_clicked()
-{
- // Deleting an item removes it from the list, so just grab the currently
- // selected item and delete it:
- QListWidgetItem *item = ui->favoriteKeysetsWidget->currentItem();
-
- if (item) delete item;
-
- // Remove this item from the persistent list. Well, actually, it seems a
- // little more convenient to just blow away the existing list of favorites
- // and rewrite it, as modifying an existing QSettings array in the middle
- // seems a bit hard...
- QSettings settings("pietrzak.org", "Pierogi");
-
- settings.remove("favorites");
-
- int count = ui->favoriteKeysetsWidget->count();
-
- // If the count is empty, we can stop right here:
- if (count == 0) return;
-
- int index = 0;
- PIRKeysetWidgetItem *kwi = NULL;
- settings.beginWriteArray("favorites");
- while (index < count)
- {
- kwi = dynamic_cast<PIRKeysetWidgetItem *>(
- ui->favoriteKeysetsWidget->item(index));
-
- settings.setArrayIndex(index);
- settings.setValue("keylistID", kwi->getID());
- ++index;
- }
- settings.endArray();
-}
-
-void MainWindow::populateFavorites()
+void MainWindow::on_selectPanelComboBox_currentIndexChanged(int index)
{
- QSettings settings("pietrzak.org", "Pierogi");
-
- int size = settings.beginReadArray("favorites");
- int index = 0;
- PIRMakeName make;
- QString name;
- unsigned int id;
-// PIRKeysetWidgetItem *kwi;
-
- while (index < size)
- {
- settings.setArrayIndex(index);
- id = settings.value("keylistID").toInt();
- make = myKeysets->getMake(id);
- name = makeManager.getMakeString(make);
- name.append(" ");
- name.append(myKeysets->getDisplayName(id));
-// kwi = new PIRKeysetWidgetItem(name, id, make);
-// myKeysets->populateDeviceTypes(kwi, id);
- ui->favoriteKeysetsWidget->addItem(new PIRKeysetWidgetItem(name, id, make));
- ++index;
- }
-
- settings.endArray();
+ ui->stackedButtonsWidget->setCurrentIndex(index);
}