--- qsampler/trunk/src/qsamplerMainForm.ui.h 2004/06/24 18:26:57 145
+++ qsampler/trunk/src/qsamplerMainForm.ui.h 2004/10/06 15:42:59 267
@@ -36,6 +36,7 @@
#include "qsamplerAbout.h"
#include "qsamplerOptions.h"
+#include "qsamplerChannel.h"
#include "qsamplerMessages.h"
#include "qsamplerChannelStrip.h"
@@ -54,10 +55,42 @@
#define QSAMPLER_STATUS_SESSION 3 // Current session modification state.
+// All winsock apps needs this.
#if defined(WIN32)
static WSADATA _wsaData;
#endif
+
+//-------------------------------------------------------------------------
+// qsamplerCustomEvent -- specialty for callback comunication.
+
+#define QSAMPLER_CUSTOM_EVENT 1000
+
+class qsamplerCustomEvent : public QCustomEvent
+{
+public:
+
+ // Constructor.
+ qsamplerCustomEvent(lscp_event_t event, const char *pchData, int cchData)
+ : QCustomEvent(QSAMPLER_CUSTOM_EVENT)
+ {
+ m_event = event;
+ m_data.setLatin1(pchData, cchData);
+ }
+
+ // Accessors.
+ lscp_event_t event() { return m_event; }
+ QString& data() { return m_data; }
+
+private:
+
+ // The proper event type.
+ lscp_event_t m_event;
+ // The event data as a string.
+ QString m_data;
+};
+
+
//-------------------------------------------------------------------------
// qsamplerMainForm -- Main window form implementation.
@@ -277,6 +310,19 @@
}
+// Custome event handler.
+void qsamplerMainForm::customEvent ( QCustomEvent *pCustomEvent )
+{
+ // For the time being, just pump it to messages.
+ if (pCustomEvent->type() == QSAMPLER_CUSTOM_EVENT) {
+ qsamplerCustomEvent *pEvent = (qsamplerCustomEvent *) pCustomEvent;
+ appendMessagesColor(tr("Notify event: %1 data: %2")
+ .arg(::lscp_event_to_text(pEvent->event()))
+ .arg(pEvent->data()), "#996699");
+ }
+}
+
+
// Context menu event handler.
void qsamplerMainForm::contextMenuEvent( QContextMenuEvent *pEvent )
{
@@ -438,10 +484,13 @@
m_pWorkspace->setUpdatesEnabled(false);
QWidgetList wlist = m_pWorkspace->windowList();
for (int iChannel = 0; iChannel < (int) wlist.count(); iChannel++) {
- qsamplerChannelStrip *pChannel = (qsamplerChannelStrip *) wlist.at(iChannel);
- if (bForce && ::lscp_remove_channel(m_pClient, pChannel->channelID()) != LSCP_OK)
- appendMessagesClient("lscp_remove_channel");
- delete pChannel;
+ qsamplerChannelStrip *pChannelStrip = (qsamplerChannelStrip *) wlist.at(iChannel);
+ if (pChannelStrip) {
+ qsamplerChannel *pChannel = pChannelStrip->channel();
+ if (bForce && pChannel && ::lscp_remove_channel(m_pClient, pChannel->channelID()) != LSCP_OK)
+ appendMessagesClient("lscp_remove_channel");
+ delete pChannelStrip;
+ }
}
m_pWorkspace->setUpdatesEnabled(true);
// We're now clean, for sure.
@@ -550,18 +599,28 @@
ts << endl;
QWidgetList wlist = m_pWorkspace->windowList();
for (int iChannel = 0; iChannel < (int) wlist.count(); iChannel++) {
- qsamplerChannelStrip *pChannel = (qsamplerChannelStrip *) wlist.at(iChannel);
- int iChannelID = pChannel->channelID();
- ts << "# " << pChannel->caption() << endl;
- ts << "ADD CHANNEL" << endl;
- ts << "SET CHANNEL AUDIO_OUTPUT_TYPE " << iChannelID << " " << pChannel->audioDriver() << endl;
- ts << "SET CHANNEL MIDI_INPUT_TYPE " << iChannelID << " " << pChannel->midiDriver() << endl;
- // ts << "SET CHANNEL MIDI_INPUT_PORT " << iChannelID << " " << pChannel->midiPort() << endl;
- ts << "SET CHANNEL MIDI_INPUT_CHANNEL " << iChannelID << " " << pChannel->midiChannel() << endl;
- ts << "LOAD ENGINE " << pChannel->engineName() << " " << iChannelID << endl;
- ts << "LOAD INSTRUMENT NON_MODAL " << pChannel->instrumentFile() << " " << pChannel->instrumentNr() << " " << iChannelID << endl;
- ts << "SET CHANNEL VOLUME " << iChannelID << " " << pChannel->volume() << endl;
- ts << endl;
+ qsamplerChannelStrip *pChannelStrip = (qsamplerChannelStrip *) wlist.at(iChannel);
+ if (pChannelStrip) {
+ qsamplerChannel *pChannel = pChannelStrip->channel();
+ if (pChannel) {
+ int iChannelID = pChannel->channelID();
+ ts << "# " << pChannelStrip->caption() << endl;
+ ts << "ADD CHANNEL" << endl;
+ ts << "SET CHANNEL AUDIO_OUTPUT_TYPE " << iChannelID << " " << pChannel->audioDriver() << endl;
+ ts << "SET CHANNEL MIDI_INPUT_TYPE " << iChannelID << " " << pChannel->midiDriver() << endl;
+ ts << "SET CHANNEL MIDI_INPUT_PORT " << iChannelID << " " << pChannel->midiPort() << endl;
+ ts << "SET CHANNEL MIDI_INPUT_CHANNEL " << iChannelID << " ";
+ if (pChannel->midiChannel() > 0)
+ ts << pChannel->midiChannel();
+ else
+ ts << "ALL";
+ ts << endl;
+ ts << "LOAD ENGINE " << pChannel->engineName() << " " << iChannelID << endl;
+ ts << "LOAD INSTRUMENT NON_MODAL '" << pChannel->instrumentFile() << "' " << pChannel->instrumentNr() << " " << iChannelID << endl;
+ ts << "SET CHANNEL VOLUME " << iChannelID << " " << pChannel->volume() << endl;
+ ts << endl;
+ }
+ }
// Try to keep it snappy :)
QApplication::eventLoop()->processEvents(QEventLoop::ExcludeUserInput);
}
@@ -633,6 +692,34 @@
}
+// Reset the sampler instance.
+void qsamplerMainForm::fileReset (void)
+{
+ if (m_pClient == NULL)
+ return;
+
+ // Ask user whether he/she want's an internal sampler reset...
+ if (QMessageBox::warning(this, tr("Warning"),
+ tr("Resetting the sampler instance will close\n"
+ "all device and channel configurations.\n\n"
+ "Please note that this operation may cause\n"
+ "temporary MIDI and Audio disruption\n\n"
+ "Do you want to reset the sampler engine now?"),
+ tr("Reset"), tr("Cancel")) > 0)
+ return;
+
+ // Just do the reset, after closing down current session...
+ if (closeSession(true) && ::lscp_reset_sampler(m_pClient) != LSCP_OK) {
+ appendMessagesClient("lscp_reset_sampler");
+ appendMessagesError(tr("Could not reset sampler instance.\n\nSorry."));
+ return;
+ }
+
+ // Log this.
+ appendMessages(tr("Sampler reset."));
+}
+
+
// Restart the client/server instance.
void qsamplerMainForm::fileRestart (void)
{
@@ -707,7 +794,11 @@
if (m_pClient == NULL)
return;
- qsamplerChannelStrip *pChannel = activeChannel();
+ qsamplerChannelStrip *pChannelStrip = activeChannelStrip();
+ if (pChannelStrip == NULL)
+ return;
+
+ qsamplerChannel *pChannel = pChannelStrip->channel();
if (pChannel == NULL)
return;
@@ -717,7 +808,7 @@
tr("About to remove channel:\n\n"
"%1\n\n"
"Are you sure?")
- .arg(pChannel->caption()),
+ .arg(pChannelStrip->caption()),
tr("OK"), tr("Cancel")) > 0)
return;
}
@@ -733,7 +824,8 @@
appendMessages(tr("Channel %1 removed.").arg(pChannel->channelID()));
// Just delete the channel strip.
- delete pChannel;
+ delete pChannelStrip;
+
// Do we auto-arrange?
if (m_pOptions && m_pOptions->bAutoArrange)
channelsArrange();
@@ -750,12 +842,12 @@
if (m_pClient == NULL)
return;
- qsamplerChannelStrip *pChannel = activeChannel();
- if (pChannel == NULL)
+ qsamplerChannelStrip *pChannelStrip = activeChannelStrip();
+ if (pChannelStrip == NULL)
return;
// Just invoque the channel strip procedure.
- pChannel->channelSetup();
+ pChannelStrip->showChannelSetup(false);
}
@@ -765,7 +857,11 @@
if (m_pClient == NULL)
return;
- qsamplerChannelStrip *pChannel = activeChannel();
+ qsamplerChannelStrip *pChannelStrip = activeChannelStrip();
+ if (pChannelStrip == NULL)
+ return;
+
+ qsamplerChannel *pChannel = pChannelStrip->channel();
if (pChannel == NULL)
return;
@@ -780,7 +876,7 @@
appendMessages(tr("Channel %1 reset.").arg(pChannel->channelID()));
// Refresh channel strip info.
- pChannel->updateChannelInfo();
+ pChannelStrip->updateChannelInfo();
}
@@ -841,9 +937,9 @@
qsamplerOptionsForm *pOptionsForm = new qsamplerOptionsForm(this);
if (pOptionsForm) {
// Check out some initial nullities(tm)...
- qsamplerChannelStrip *pChannel = activeChannel();
- if (m_pOptions->sDisplayFont.isEmpty() && pChannel)
- m_pOptions->sDisplayFont = pChannel->displayFont().toString();
+ qsamplerChannelStrip *pChannelStrip = activeChannelStrip();
+ if (m_pOptions->sDisplayFont.isEmpty() && pChannelStrip)
+ m_pOptions->sDisplayFont = pChannelStrip->displayFont().toString();
if (m_pOptions->sMessagesFont.isEmpty() && m_pMessages)
m_pOptions->sMessagesFont = m_pMessages->messagesFont().toString();
// To track down deferred or immediate changes.
@@ -853,6 +949,7 @@
bool bOldServerStart = m_pOptions->bServerStart;
QString sOldServerCmdLine = m_pOptions->sServerCmdLine;
QString sOldDisplayFont = m_pOptions->sDisplayFont;
+ bool bOldDisplayEffect = m_pOptions->bDisplayEffect;
int iOldMaxVolume = m_pOptions->iMaxVolume;
QString sOldMessagesFont = m_pOptions->sMessagesFont;
bool bOldStdoutCapture = m_pOptions->bStdoutCapture;
@@ -877,6 +974,9 @@
(!bOldCompletePath && m_pOptions->bCompletePath) ||
(iOldMaxRecentFiles != m_pOptions->iMaxRecentFiles))
updateRecentFilesMenu();
+ if (( bOldDisplayEffect && !m_pOptions->bDisplayEffect) ||
+ (!bOldDisplayEffect && m_pOptions->bDisplayEffect))
+ updateDisplayEffect();
if (sOldDisplayFont != m_pOptions->sDisplayFont)
updateDisplayFont();
if (iOldMaxVolume != m_pOptions->iMaxVolume)
@@ -919,19 +1019,19 @@
m_pWorkspace->setUpdatesEnabled(false);
int y = 0;
for (int iChannel = 0; iChannel < (int) wlist.count(); iChannel++) {
- qsamplerChannelStrip *pChannel = (qsamplerChannelStrip *) wlist.at(iChannel);
- /* if (pChannel->testWState(WState_Maximized | WState_Minimized)) {
+ qsamplerChannelStrip *pChannelStrip = (qsamplerChannelStrip *) wlist.at(iChannel);
+ /* if (pChannelStrip->testWState(WState_Maximized | WState_Minimized)) {
// Prevent flicker...
- pChannel->hide();
- pChannel->showNormal();
+ pChannelStrip->hide();
+ pChannelStrip->showNormal();
} */
- pChannel->adjustSize();
+ pChannelStrip->adjustSize();
int iWidth = m_pWorkspace->width();
- if (iWidth < pChannel->width())
- iWidth = pChannel->width();
- // int iHeight = pChannel->height() + pChannel->parentWidget()->baseSize().height();
- int iHeight = pChannel->parentWidget()->frameGeometry().height();
- pChannel->parentWidget()->setGeometry(0, y, iWidth, iHeight);
+ if (iWidth < pChannelStrip->width())
+ iWidth = pChannelStrip->width();
+ // int iHeight = pChannelStrip->height() + pChannelStrip->parentWidget()->baseSize().height();
+ int iHeight = pChannelStrip->parentWidget()->frameGeometry().height();
+ pChannelStrip->parentWidget()->setGeometry(0, y, iWidth, iHeight);
y += iHeight;
}
m_pWorkspace->setUpdatesEnabled(true);
@@ -979,6 +1079,11 @@
sText += tr("Debugging option enabled.");
sText += "
";
#endif
+#ifndef CONFIG_LIBGIG
+ sText += "";
+ sText += tr("GIG (libgig) file support disabled.");
+ sText += "
";
+#endif
sText += "
\n";
sText += tr("Using") + ": ";
sText += ::lscp_client_package();
@@ -1012,13 +1117,14 @@
setCaption(tr(QSAMPLER_TITLE " - [%1]").arg(sSessioName));
// Update the main menu state...
- qsamplerChannelStrip *pChannel = activeChannel();
+ qsamplerChannelStrip *pChannelStrip = activeChannelStrip();
bool bHasClient = (m_pOptions != NULL && m_pClient != NULL);
- bool bHasChannel = (bHasClient && pChannel != NULL);
+ bool bHasChannel = (bHasClient && pChannelStrip != NULL);
fileNewAction->setEnabled(bHasClient);
fileOpenAction->setEnabled(bHasClient);
fileSaveAction->setEnabled(bHasClient && m_iDirtyCount > 0);
fileSaveAsAction->setEnabled(bHasClient);
+ fileResetAction->setEnabled(bHasClient);
fileRestartAction->setEnabled(bHasClient || m_pServer == NULL);
editAddChannelAction->setEnabled(bHasClient);
editRemoveChannelAction->setEnabled(bHasChannel);
@@ -1037,7 +1143,7 @@
}
// Channel status...
if (bHasChannel)
- m_status[QSAMPLER_STATUS_CHANNEL]->setText(pChannel->caption());
+ m_status[QSAMPLER_STATUS_CHANNEL]->setText(pChannelStrip->caption());
else
m_status[QSAMPLER_STATUS_CHANNEL]->clear();
// Session status...
@@ -1056,7 +1162,7 @@
// Channel change receiver slot.
-void qsamplerMainForm::channelChanged( qsamplerChannelStrip * )
+void qsamplerMainForm::channelStripChanged( qsamplerChannelStrip * )
{
// Just mark the dirty form.
m_iDirtyCount++;
@@ -1130,8 +1236,31 @@
m_pWorkspace->setUpdatesEnabled(false);
for (int iChannel = 0; iChannel < (int) wlist.count(); iChannel++) {
- qsamplerChannelStrip *pChannel = (qsamplerChannelStrip *) wlist.at(iChannel);
- pChannel->setDisplayFont(font);
+ qsamplerChannelStrip *pChannelStrip = (qsamplerChannelStrip *) wlist.at(iChannel);
+ if (pChannelStrip)
+ pChannelStrip->setDisplayFont(font);
+ }
+ m_pWorkspace->setUpdatesEnabled(true);
+}
+
+
+// Update channel strips background effect.
+void qsamplerMainForm::updateDisplayEffect (void)
+{
+ QPixmap pm;
+ if (m_pOptions->bDisplayEffect)
+ pm = QPixmap::fromMimeSource("displaybg1.png");
+
+ // Full channel list update...
+ QWidgetList wlist = m_pWorkspace->windowList();
+ if (wlist.isEmpty())
+ return;
+
+ m_pWorkspace->setUpdatesEnabled(false);
+ for (int iChannel = 0; iChannel < (int) wlist.count(); iChannel++) {
+ qsamplerChannelStrip *pChannelStrip = (qsamplerChannelStrip *) wlist.at(iChannel);
+ if (pChannelStrip)
+ pChannelStrip->setDisplayBackground(pm);
}
m_pWorkspace->setUpdatesEnabled(true);
}
@@ -1150,8 +1279,9 @@
m_pWorkspace->setUpdatesEnabled(false);
for (int iChannel = 0; iChannel < (int) wlist.count(); iChannel++) {
- qsamplerChannelStrip *pChannel = (qsamplerChannelStrip *) wlist.at(iChannel);
- pChannel->setMaxVolume(m_pOptions->iMaxVolume);
+ qsamplerChannelStrip *pChannelStrip = (qsamplerChannelStrip *) wlist.at(iChannel);
+ if (pChannelStrip)
+ pChannelStrip->setMaxVolume(m_pOptions->iMaxVolume);
}
m_pWorkspace->setUpdatesEnabled(true);
}
@@ -1256,53 +1386,59 @@
return;
// Prepare for auto-arrange?
- qsamplerChannelStrip *pChannel = NULL;
+ qsamplerChannelStrip *pChannelStrip = NULL;
int y = 0;
if (m_pOptions && m_pOptions->bAutoArrange) {
QWidgetList wlist = m_pWorkspace->windowList();
for (int iChannel = 0; iChannel < (int) wlist.count(); iChannel++) {
- pChannel = (qsamplerChannelStrip *) wlist.at(iChannel);
- // y += pChannel->height() + pChannel->parentWidget()->baseSize().height();
- y += pChannel->parentWidget()->frameGeometry().height();
+ pChannelStrip = (qsamplerChannelStrip *) wlist.at(iChannel);
+ // y += pChannelStrip->height() + pChannelStrip->parentWidget()->baseSize().height();
+ y += pChannelStrip->parentWidget()->frameGeometry().height();
}
}
// Add a new channel itema...
WFlags wflags = Qt::WStyle_Customize | Qt::WStyle_Tool | Qt::WStyle_Title | Qt::WStyle_NoBorder;
- pChannel = new qsamplerChannelStrip(m_pWorkspace, 0, wflags);
- pChannel->setMaxVolume(m_pOptions->iMaxVolume);
- pChannel->setup(this, iChannelID);
- // We'll need a display font.
- QFont font;
- if (m_pOptions && font.fromString(m_pOptions->sDisplayFont))
- pChannel->setDisplayFont(font);
- // Track channel setup changes.
- QObject::connect(pChannel, SIGNAL(channelChanged(qsamplerChannelStrip *)), this, SLOT(channelChanged(qsamplerChannelStrip *)));
+ pChannelStrip = new qsamplerChannelStrip(m_pWorkspace, 0, wflags);
+ // Set some initial aesthetic options...
+ if (m_pOptions) {
+ // Background display effect...
+ pChannelStrip->setDisplayEffect(m_pOptions->bDisplayEffect);
+ // We'll need a display font.
+ QFont font;
+ if (font.fromString(m_pOptions->sDisplayFont))
+ pChannelStrip->setDisplayFont(font);
+ // Maximum allowed volume setting.
+ pChannelStrip->setMaxVolume(m_pOptions->iMaxVolume);
+ }
+ // Actual channel setup.
+ pChannelStrip->setup(this, iChannelID);
+ QObject::connect(pChannelStrip, SIGNAL(channelChanged(qsamplerChannelStrip *)), this, SLOT(channelStripChanged(qsamplerChannelStrip *)));
// Before we show it up, may be we'll
// better ask for some initial values?
if (bPrompt)
- pChannel->channelSetup();
+ pChannelStrip->showChannelSetup(true);
// Now we show up us to the world.
- pChannel->show();
+ pChannelStrip->show();
// Only then, we'll auto-arrange...
if (m_pOptions && m_pOptions->bAutoArrange) {
int iWidth = m_pWorkspace->width();
// int iHeight = pChannel->height() + pChannel->parentWidget()->baseSize().height();
- int iHeight = pChannel->parentWidget()->frameGeometry().height();
- pChannel->parentWidget()->setGeometry(0, y, iWidth, iHeight);
+ int iHeight = pChannelStrip->parentWidget()->frameGeometry().height();
+ pChannelStrip->parentWidget()->setGeometry(0, y, iWidth, iHeight);
}
}
// Retrieve the active channel strip.
-qsamplerChannelStrip *qsamplerMainForm::activeChannel (void)
+qsamplerChannelStrip *qsamplerMainForm::activeChannelStrip (void)
{
return (qsamplerChannelStrip *) m_pWorkspace->activeWindow();
}
// Retrieve a channel strip by index.
-qsamplerChannelStrip *qsamplerMainForm::channelAt ( int iChannel )
+qsamplerChannelStrip *qsamplerMainForm::channelStripAt ( int iChannel )
{
QWidgetList wlist = m_pWorkspace->windowList();
if (wlist.isEmpty())
@@ -1323,10 +1459,12 @@
if (!wlist.isEmpty()) {
channelsMenu->insertSeparator();
for (int iChannel = 0; iChannel < (int) wlist.count(); iChannel++) {
- qsamplerChannelStrip *pChannel = (qsamplerChannelStrip *) wlist.at(iChannel);
- int iItemID = channelsMenu->insertItem(pChannel->caption(), this, SLOT(channelsMenuActivated(int)));
- channelsMenu->setItemParameter(iItemID, iChannel);
- channelsMenu->setItemChecked(iItemID, activeChannel() == pChannel);
+ qsamplerChannelStrip *pChannelStrip = (qsamplerChannelStrip *) wlist.at(iChannel);
+ if (pChannelStrip) {
+ int iItemID = channelsMenu->insertItem(pChannelStrip->caption(), this, SLOT(channelsMenuActivated(int)));
+ channelsMenu->setItemParameter(iItemID, iChannel);
+ channelsMenu->setItemChecked(iItemID, activeChannelStrip() == pChannelStrip);
+ }
}
}
}
@@ -1335,10 +1473,10 @@
// Windows menu activation slot
void qsamplerMainForm::channelsMenuActivated ( int iChannel )
{
- qsamplerChannelStrip *pChannel = channelAt(iChannel);
- if (pChannel)
- pChannel->showNormal();
- pChannel->setFocus();
+ qsamplerChannelStrip *pChannelStrip = channelStripAt(iChannel);
+ if (pChannelStrip)
+ pChannelStrip->showNormal();
+ pChannelStrip->setFocus();
}
@@ -1384,9 +1522,9 @@
m_iTimerSlot = 0;
QWidgetList wlist = m_pWorkspace->windowList();
for (int iChannel = 0; iChannel < (int) wlist.count(); iChannel++) {
- qsamplerChannelStrip *pChannel = (qsamplerChannelStrip *) wlist.at(iChannel);
- if (pChannel->isVisible())
- pChannel->updateChannelUsage();
+ qsamplerChannelStrip *pChannelStrip = (qsamplerChannelStrip *) wlist.at(iChannel);
+ if (pChannelStrip && pChannelStrip->isVisible())
+ pChannelStrip->updateChannelUsage();
}
}
}
@@ -1523,15 +1661,17 @@
//-------------------------------------------------------------------------
// qsamplerMainForm -- Client stuff.
-
// The LSCP client callback procedure.
-lscp_status_t qsampler_client_callback ( lscp_client_t */*pClient*/, lscp_event_t /*event*/, const char */*pchBuffer*/, int /*cchBuffer*/, void */*pvData*/ )
+lscp_status_t qsampler_client_callback ( lscp_client_t */*pClient*/, lscp_event_t event, const char *pchData, int cchData, void *pvData )
{
- // FIXME: DO NOT EVER call any GUI code here,
+ qsamplerMainForm *pMainForm = (qsamplerMainForm *) pvData;
+ if (pMainForm == NULL)
+ return LSCP_FAILED;
+
+ // ATTN: DO NOT EVER call any GUI code here,
// as this is run under some other thread context.
// A custom event must be posted here...
- //
- // QApplication::postEvent((qjackctlMainForm *) pvData, new QCustomEvent(...));
+ QApplication::postEvent(pMainForm, new qsamplerCustomEvent(event, pchData, cchData));
return LSCP_OK;
}