/[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 920 - (hide annotations) (download) (as text)
Sun Sep 24 12:47:51 2006 UTC (17 years, 7 months ago) by capela
File MIME type: text/x-c++hdr
File size: 12062 byte(s)
GPL address update.

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 264 if (m_pChannel->client() == NULL)
328 capela 297 return false;
329 capela 109
330 capela 264 // Read actual channel information.
331     m_pChannel->updateChannelInfo();
332 capela 109
333     // Engine name...
334 capela 264 if (m_pChannel->engineName().isEmpty())
335 capela 388 EngineNameTextLabel->setText(' ' + qsamplerChannel::noEngineName());
336 capela 109 else
337 capela 371 EngineNameTextLabel->setText(' ' + m_pChannel->engineName());
338 capela 109
339 capela 371 // Instrument name...
340     updateInstrumentName(false);
341 capela 109
342     // MIDI Port/Channel...
343 capela 280 if (m_pChannel->midiChannel() == LSCP_MIDI_CHANNEL_ALL)
344     MidiPortChannelTextLabel->setText(QString("%1 / *").arg(m_pChannel->midiPort()));
345 capela 261 else
346 capela 280 MidiPortChannelTextLabel->setText(QString("%1 / %2").arg(m_pChannel->midiPort()).arg(m_pChannel->midiChannel() + 1));
347 capela 261
348 capela 400 // Instrument status...
349     int iInstrumentStatus = m_pChannel->instrumentStatus();
350     if (iInstrumentStatus < 0) {
351     InstrumentStatusTextLabel->setPaletteForegroundColor(Qt::red);
352     InstrumentStatusTextLabel->setText(tr("ERR%1").arg(iInstrumentStatus));
353     m_iErrorCount++;
354 capela 297 return false;
355 capela 400 }
356     // All seems normal...
357     InstrumentStatusTextLabel->setPaletteForegroundColor(iInstrumentStatus < 100 ? Qt::yellow : Qt::green);
358     InstrumentStatusTextLabel->setText(QString::number(iInstrumentStatus) + '%');
359     m_iErrorCount = 0;
360 capela 264
361 capela 751 #ifdef CONFIG_MUTE_SOLO
362     // Mute/Solo button state coloring...
363     const QColor& rgbNormal = ChannelSetupPushButton->paletteBackgroundColor();
364     bool bMute = m_pChannel->channelMute();
365     ChannelMutePushButton->setPaletteBackgroundColor(bMute ? Qt::red : rgbNormal);
366     ChannelMutePushButton->setDown(bMute);
367     bool bSolo = m_pChannel->channelSolo();
368     ChannelSoloPushButton->setPaletteBackgroundColor(bSolo ? Qt::yellow : rgbNormal);
369     ChannelSoloPushButton->setDown(bSolo);
370     #else
371     ChannelMutePushButton->setEnabled(false);
372     ChannelSoloPushButton->setEnabled(false);
373     #endif
374    
375 capela 400 // And update the both GUI volume elements;
376     // return success if, and only if, intrument is fully loaded...
377     return updateChannelVolume() && (iInstrumentStatus == 100);
378 capela 109 }
379    
380    
381     // Update whole channel usage state.
382 capela 297 bool qsamplerChannelStrip::updateChannelUsage (void)
383 capela 109 {
384 capela 264 if (m_pChannel == NULL)
385 capela 297 return false;
386 capela 264 if (m_pChannel->client() == NULL)
387 capela 297 return false;
388 capela 109
389 capela 400 // This only makes sense on fully loaded channels...
390     if (m_pChannel->instrumentStatus() < 100)
391     return false;
392 capela 586
393 capela 109 // Get current channel voice count.
394 capela 264 int iVoiceCount = ::lscp_get_channel_voice_count(m_pChannel->client(), m_pChannel->channelID());
395 capela 109 // Get current stream count.
396 capela 264 int iStreamCount = ::lscp_get_channel_stream_count(m_pChannel->client(), m_pChannel->channelID());
397 capela 109 // Get current channel buffer fill usage.
398     // As benno has suggested this is the percentage usage
399     // of the least filled buffer stream...
400 capela 264 int iStreamUsage = ::lscp_get_channel_stream_usage(m_pChannel->client(), m_pChannel->channelID());;
401 capela 176
402 capela 109 // Update the GUI elements...
403     StreamUsageProgressBar->setProgress(iStreamUsage);
404     StreamVoiceCountTextLabel->setText(QString("%1 / %2").arg(iStreamCount).arg(iVoiceCount));
405 capela 586
406 capela 297 // We're clean.
407     return true;
408 capela 109 }
409    
410    
411     // Volume change slot.
412     void qsamplerChannelStrip::volumeChanged ( int iVolume )
413     {
414 capela 264 if (m_pChannel == NULL)
415     return;
416    
417 capela 109 // Avoid recursion.
418     if (m_iDirtyChange > 0)
419     return;
420    
421     // Convert and clip.
422     float fVolume = (float) iVolume / 100.0;
423 capela 119 if (fVolume < 0.001)
424 capela 109 fVolume = 0.0;
425    
426     // Update the GUI elements.
427 capela 264 if (m_pChannel->setVolume(fVolume)) {
428 capela 109 updateChannelVolume();
429     emit channelChanged(this);
430     }
431     }
432    
433    
434 capela 118 // Context menu event handler.
435     void qsamplerChannelStrip::contextMenuEvent( QContextMenuEvent *pEvent )
436     {
437 capela 303 if (m_pChannel == NULL)
438 capela 264 return;
439 capela 586
440 capela 303 // We'll just show up the main form's edit menu (thru qsamplerChannel).
441     m_pChannel->contextMenuEvent(pEvent);
442 capela 118 }
443    
444    
445 capela 586 // Error count hackish accessors.
446     void qsamplerChannelStrip::resetErrorCount (void)
447     {
448     m_iErrorCount = 0;
449     }
450    
451    
452 capela 109 // end of qsamplerChannelStrip.ui.h

  ViewVC Help
Powered by ViewVC