/[svn]/qsampler/trunk/src/qsamplerChannelStrip.ui.h
ViewVC logotype

Annotation of /qsampler/trunk/src/qsamplerChannelStrip.ui.h

Parent Directory Parent Directory | Revision Log Revision Log


Revision 961 - (hide annotations) (download) (as text)
Sun Dec 3 18:26:13 2006 UTC (17 years, 4 months ago) by capela
File MIME type: text/x-c++hdr
File size: 12168 byte(s)
- Adding preliminary MIDI instrument mapping support; now
  with an instrument list widget and editing capabilities.

1 capela 109 // qsamplerChannelStrip.ui.h
2     //
3     // ui.h extension file, included from the uic-generated form implementation.
4     /****************************************************************************
5 capela 920 Copyright (C) 2004-2006, rncbc aka Rui Nuno Capela. All rights reserved.
6 capela 109
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 capela 920 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 capela 109
21     *****************************************************************************/
22    
23     #include <qvalidator.h>
24     #include <qmessagebox.h>
25 capela 395 #include <qdragobject.h>
26 capela 109 #include <qfileinfo.h>
27     #include <qtooltip.h>
28 capela 118 #include <qpopupmenu.h>
29 capela 267 #include <qobjectlist.h>
30 capela 409 #include <qurl.h>
31 capela 109
32     #include <math.h>
33    
34     #include "qsamplerMainForm.h"
35     #include "qsamplerChannelForm.h"
36    
37     #include "config.h"
38    
39 capela 395 // Channel status/usage usage limit control.
40     #define QSAMPLER_ERROR_LIMIT 3
41 capela 109
42 capela 395
43 capela 109 // Kind of constructor.
44     void qsamplerChannelStrip::init (void)
45     {
46     // Initialize locals.
47 capela 264 m_pChannel = NULL;
48 capela 109 m_iDirtyChange = 0;
49 capela 395 m_iErrorCount = 0;
50 capela 109
51     // Try to restore normal window positioning.
52     adjustSize();
53     }
54    
55    
56     // Kind of destructor.
57     void qsamplerChannelStrip::destroy (void)
58     {
59 capela 264 // Destroy existing channel descriptor.
60     if (m_pChannel)
61     delete m_pChannel;
62     m_pChannel = NULL;
63 capela 109 }
64    
65    
66 capela 395 // Drag'n'drop file handler.
67     bool qsamplerChannelStrip::decodeDragFile ( const QMimeSource *pEvent, QString& sInstrumentFile )
68     {
69     if (m_pChannel == NULL)
70     return false;
71     if (QTextDrag::canDecode(pEvent)) {
72     QString sText;
73     if (QTextDrag::decode(pEvent, sText)) {
74     QStringList files = QStringList::split('\n', sText);
75     for (QStringList::Iterator iter = files.begin(); iter != files.end(); iter++) {
76 capela 409 *iter = QUrl((*iter).stripWhiteSpace().replace(QRegExp("^file:"), QString::null)).path();
77 capela 395 if (qsamplerChannel::isInstrumentFile(*iter)) {
78     sInstrumentFile = *iter;
79     return true;
80     }
81     }
82     }
83     }
84     // Fail.
85     return false;
86     }
87    
88    
89     // Window drag-n-drop event handlers.
90     void qsamplerChannelStrip::dragEnterEvent ( QDragEnterEvent* pDragEnterEvent )
91     {
92     QString sInstrumentFile;
93     pDragEnterEvent->accept(decodeDragFile(pDragEnterEvent, sInstrumentFile));
94     }
95    
96    
97     void qsamplerChannelStrip::dropEvent ( QDropEvent* pDropEvent )
98     {
99     QString sInstrumentFile;
100    
101     if (decodeDragFile(pDropEvent, sInstrumentFile)) {
102     // Go and set the dropped instrument filename...
103     m_pChannel->setInstrument(sInstrumentFile, 0);
104     // Open up the channel dialog.
105     channelSetup();
106     }
107     }
108    
109    
110 capela 109 // Channel strip setup formal initializer.
111 capela 303 void qsamplerChannelStrip::setup ( qsamplerChannel *pChannel )
112 capela 109 {
113 capela 303 // Destroy any previous channel descriptor;
114     // (remember that once setup we own it!)
115 capela 264 if (m_pChannel)
116     delete m_pChannel;
117 capela 109
118 capela 303 // Set the new one...
119     m_pChannel = pChannel;
120 capela 586
121 capela 265 // Stabilize this around.
122     updateChannelInfo();
123 capela 395
124     // We'll accept drops from now on...
125     if (m_pChannel)
126     setAcceptDrops(true);
127 capela 109 }
128    
129 capela 264 // Channel secriptor accessor.
130     qsamplerChannel *qsamplerChannelStrip::channel (void)
131 capela 109 {
132 capela 264 return m_pChannel;
133 capela 109 }
134    
135    
136     // Messages view font accessors.
137     QFont qsamplerChannelStrip::displayFont (void)
138     {
139     return EngineNameTextLabel->font();
140     }
141    
142     void qsamplerChannelStrip::setDisplayFont ( const QFont & font )
143     {
144     EngineNameTextLabel->setFont(font);
145 capela 145 MidiPortChannelTextLabel->setFont(font);
146 capela 109 InstrumentNameTextLabel->setFont(font);
147 capela 145 InstrumentStatusTextLabel->setFont(font);
148 capela 109 }
149    
150 capela 263
151 capela 267 // Channel display background effect.
152     void qsamplerChannelStrip::setDisplayEffect ( bool bDisplayEffect )
153     {
154     QPixmap pm;
155     if (bDisplayEffect)
156     pm = QPixmap::fromMimeSource("displaybg1.png");
157     setDisplayBackground(pm);
158     }
159    
160    
161     // Update main display background pixmap.
162     void qsamplerChannelStrip::setDisplayBackground ( const QPixmap& pm )
163     {
164     // Set the main origin...
165     ChannelInfoFrame->setPaletteBackgroundPixmap(pm);
166    
167     // Iterate for every child text label...
168     QObjectList *pList = ChannelInfoFrame->queryList("QLabel");
169     if (pList) {
170     for (QLabel *pLabel = (QLabel *) pList->first(); pLabel; pLabel = (QLabel *) pList->next())
171     pLabel->setPaletteBackgroundPixmap(pm);
172     delete pList;
173     }
174 capela 586
175 capela 267 // And this standalone too.
176     StreamVoiceCountTextLabel->setPaletteBackgroundPixmap(pm);
177     }
178    
179    
180 capela 395 // Maximum volume slider accessors.
181     void qsamplerChannelStrip::setMaxVolume ( int iMaxVolume )
182     {
183     m_iDirtyChange++;
184     VolumeSlider->setRange(0, iMaxVolume);
185     VolumeSpinBox->setRange(0, iMaxVolume);
186     m_iDirtyChange--;
187     }
188    
189    
190 capela 263 // Channel setup dialog slot.
191 capela 295 bool qsamplerChannelStrip::channelSetup (void)
192 capela 263 {
193 capela 400 if (m_pChannel == NULL)
194     return false;
195    
196 capela 395 // Invoke the channel setup dialog.
197     bool bResult = m_pChannel->channelSetup(this);
198 capela 590 // Notify that this channel has changed.
199 capela 400 if (bResult)
200     emit channelChanged(this);
201 capela 263
202 capela 400 return bResult;
203     }
204    
205    
206 capela 751 // Channel mute slot.
207     bool qsamplerChannelStrip::channelMute ( bool bMute )
208     {
209     if (m_pChannel == NULL)
210     return false;
211    
212     // Invoke the channel mute method.
213     bool bResult = m_pChannel->setChannelMute(bMute);
214     // Notify that this channel has changed.
215     if (bResult)
216     emit channelChanged(this);
217    
218     return bResult;
219     }
220    
221    
222     // Channel solo slot.
223     bool qsamplerChannelStrip::channelSolo ( bool bSolo )
224     {
225     if (m_pChannel == NULL)
226     return false;
227    
228     // Invoke the channel solo method.
229     bool bResult = m_pChannel->setChannelSolo(bSolo);
230     // Notify that this channel has changed.
231     if (bResult)
232     emit channelChanged(this);
233    
234     return bResult;
235     }
236    
237    
238 capela 400 // Channel reset slot.
239     bool qsamplerChannelStrip::channelReset (void)
240     {
241     if (m_pChannel == NULL)
242     return false;
243    
244     // Invoke the channel reset method.
245     bool bResult = m_pChannel->channelReset();
246 capela 590 // Notify that this channel has changed.
247 capela 400 if (bResult)
248 capela 395 emit channelChanged(this);
249 capela 295
250 capela 395 return bResult;
251 capela 109 }
252    
253    
254 capela 371 // Update the channel instrument name.
255     bool qsamplerChannelStrip::updateInstrumentName ( bool bForce )
256     {
257     if (m_pChannel == NULL)
258     return false;
259    
260 capela 590 // Do we refresh the actual name?
261 capela 371 if (bForce)
262     m_pChannel->updateInstrumentName();
263    
264     // Instrument name...
265 schoenebeck 519 if (m_pChannel->instrumentName().isEmpty()) {
266     if (m_pChannel->instrumentStatus() >= 0)
267     InstrumentNameTextLabel->setText(' ' + qsamplerChannel::loadingInstrument());
268     else
269     InstrumentNameTextLabel->setText(' ' + qsamplerChannel::noInstrumentName());
270     } else
271 capela 371 InstrumentNameTextLabel->setText(' ' + m_pChannel->instrumentName());
272    
273     return true;
274     }
275    
276    
277 capela 400 // Do the dirty volume change.
278     bool qsamplerChannelStrip::updateChannelVolume (void)
279     {
280     if (m_pChannel == NULL)
281     return false;
282    
283     // Convert...
284     #ifdef CONFIG_ROUND
285     int iVolume = (int) ::round(100.0 * m_pChannel->volume());
286     #else
287     double fIPart = 0.0;
288     double fFPart = ::modf(100.0 * m_pChannel->volume(), &fIPart);
289     int iVolume = (int) fIPart;
290     if (fFPart >= +0.5)
291     iVolume++;
292     else
293     if (fFPart <= -0.5)
294     iVolume--;
295     #endif
296    
297     // And clip...
298     if (iVolume < 0)
299     iVolume = 0;
300    
301     // Flag it here, to avoid infinite recursion.
302     m_iDirtyChange++;
303     VolumeSlider->setValue(iVolume);
304     VolumeSpinBox->setValue(iVolume);
305     m_iDirtyChange--;
306    
307     return true;
308     }
309    
310    
311 capela 109 // Update whole channel info state.
312 capela 297 bool qsamplerChannelStrip::updateChannelInfo (void)
313 capela 109 {
314 capela 264 if (m_pChannel == NULL)
315 capela 297 return false;
316 capela 586
317 capela 400 // Check for error limit/recycle...
318     if (m_iErrorCount > QSAMPLER_ERROR_LIMIT)
319     return true;
320    
321 capela 109 // Update strip caption.
322 capela 295 QString sText = m_pChannel->channelName();
323 capela 109 setCaption(sText);
324     ChannelSetupPushButton->setText(sText);
325    
326     // Check if we're up and connected.
327 capela 961 qsamplerMainForm *pMainForm = qsamplerMainForm::getInstance();
328     if (pMainForm->client() == NULL)
329     return false;
330 capela 109
331 capela 264 // Read actual channel information.
332     m_pChannel->updateChannelInfo();
333 capela 109
334     // Engine name...
335 capela 264 if (m_pChannel->engineName().isEmpty())
336 capela 388 EngineNameTextLabel->setText(' ' + qsamplerChannel::noEngineName());
337 capela 109 else
338 capela 371 EngineNameTextLabel->setText(' ' + m_pChannel->engineName());
339 capela 109
340 capela 371 // Instrument name...
341     updateInstrumentName(false);
342 capela 109
343     // MIDI Port/Channel...
344 capela 280 if (m_pChannel->midiChannel() == LSCP_MIDI_CHANNEL_ALL)
345     MidiPortChannelTextLabel->setText(QString("%1 / *").arg(m_pChannel->midiPort()));
346 capela 261 else
347 capela 280 MidiPortChannelTextLabel->setText(QString("%1 / %2").arg(m_pChannel->midiPort()).arg(m_pChannel->midiChannel() + 1));
348 capela 261
349 capela 400 // Instrument status...
350     int iInstrumentStatus = m_pChannel->instrumentStatus();
351     if (iInstrumentStatus < 0) {
352     InstrumentStatusTextLabel->setPaletteForegroundColor(Qt::red);
353     InstrumentStatusTextLabel->setText(tr("ERR%1").arg(iInstrumentStatus));
354     m_iErrorCount++;
355 capela 297 return false;
356 capela 400 }
357     // All seems normal...
358     InstrumentStatusTextLabel->setPaletteForegroundColor(iInstrumentStatus < 100 ? Qt::yellow : Qt::green);
359     InstrumentStatusTextLabel->setText(QString::number(iInstrumentStatus) + '%');
360     m_iErrorCount = 0;
361 capela 264
362 capela 751 #ifdef CONFIG_MUTE_SOLO
363     // Mute/Solo button state coloring...
364     const QColor& rgbNormal = ChannelSetupPushButton->paletteBackgroundColor();
365     bool bMute = m_pChannel->channelMute();
366     ChannelMutePushButton->setPaletteBackgroundColor(bMute ? Qt::red : rgbNormal);
367     ChannelMutePushButton->setDown(bMute);
368     bool bSolo = m_pChannel->channelSolo();
369     ChannelSoloPushButton->setPaletteBackgroundColor(bSolo ? Qt::yellow : rgbNormal);
370     ChannelSoloPushButton->setDown(bSolo);
371     #else
372     ChannelMutePushButton->setEnabled(false);
373     ChannelSoloPushButton->setEnabled(false);
374     #endif
375    
376 capela 400 // And update the both GUI volume elements;
377     // return success if, and only if, intrument is fully loaded...
378     return updateChannelVolume() && (iInstrumentStatus == 100);
379 capela 109 }
380    
381    
382     // Update whole channel usage state.
383 capela 297 bool qsamplerChannelStrip::updateChannelUsage (void)
384 capela 109 {
385 capela 264 if (m_pChannel == NULL)
386 capela 297 return false;
387 capela 109
388 capela 961 qsamplerMainForm *pMainForm = qsamplerMainForm::getInstance();
389     if (pMainForm->client() == NULL)
390     return false;
391    
392 capela 400 // This only makes sense on fully loaded channels...
393     if (m_pChannel->instrumentStatus() < 100)
394     return false;
395 capela 586
396 capela 109 // Get current channel voice count.
397 capela 961 int iVoiceCount = ::lscp_get_channel_voice_count(pMainForm->client(), m_pChannel->channelID());
398 capela 109 // Get current stream count.
399 capela 961 int iStreamCount = ::lscp_get_channel_stream_count(pMainForm->client(), m_pChannel->channelID());
400 capela 109 // Get current channel buffer fill usage.
401     // As benno has suggested this is the percentage usage
402     // of the least filled buffer stream...
403 capela 961 int iStreamUsage = ::lscp_get_channel_stream_usage(pMainForm->client(), m_pChannel->channelID());;
404 capela 176
405 capela 109 // Update the GUI elements...
406     StreamUsageProgressBar->setProgress(iStreamUsage);
407     StreamVoiceCountTextLabel->setText(QString("%1 / %2").arg(iStreamCount).arg(iVoiceCount));
408 capela 586
409 capela 297 // We're clean.
410     return true;
411 capela 109 }
412    
413    
414     // Volume change slot.
415     void qsamplerChannelStrip::volumeChanged ( int iVolume )
416     {
417 capela 264 if (m_pChannel == NULL)
418     return;
419    
420 capela 109 // Avoid recursion.
421     if (m_iDirtyChange > 0)
422     return;
423    
424     // Convert and clip.
425     float fVolume = (float) iVolume / 100.0;
426 capela 119 if (fVolume < 0.001)
427 capela 109 fVolume = 0.0;
428    
429     // Update the GUI elements.
430 capela 264 if (m_pChannel->setVolume(fVolume)) {
431 capela 109 updateChannelVolume();
432     emit channelChanged(this);
433     }
434     }
435    
436    
437 capela 118 // Context menu event handler.
438     void qsamplerChannelStrip::contextMenuEvent( QContextMenuEvent *pEvent )
439     {
440 capela 303 if (m_pChannel == NULL)
441 capela 264 return;
442 capela 586
443 capela 303 // We'll just show up the main form's edit menu (thru qsamplerChannel).
444     m_pChannel->contextMenuEvent(pEvent);
445 capela 118 }
446    
447    
448 capela 586 // Error count hackish accessors.
449     void qsamplerChannelStrip::resetErrorCount (void)
450     {
451     m_iErrorCount = 0;
452     }
453    
454    
455 capela 109 // end of qsamplerChannelStrip.ui.h

  ViewVC Help
Powered by ViewVC