diff options
Diffstat (limited to 'src/plugins/Input/cue/decoder_cue.cpp')
| -rw-r--r-- | src/plugins/Input/cue/decoder_cue.cpp | 32 |
1 files changed, 32 insertions, 0 deletions
diff --git a/src/plugins/Input/cue/decoder_cue.cpp b/src/plugins/Input/cue/decoder_cue.cpp index 8e570e478..70bd81e48 100644 --- a/src/plugins/Input/cue/decoder_cue.cpp +++ b/src/plugins/Input/cue/decoder_cue.cpp @@ -39,6 +39,10 @@ DecoderCUE::DecoderCUE(QObject *parent, DecoderFactory *d, const QString &url) m_decoder = 0; m_output2 = 0; m_input2 = 0; + for (int i = 1; i < 10; ++i) + m_bands2[i] = 0; + m_preamp2 = 0; + m_useEQ2 = FALSE; } DecoderCUE::~DecoderCUE() @@ -98,6 +102,8 @@ bool DecoderCUE::initialize() m_length = parser.length(track); m_offset = parser.offset(track); m_decoder = df->create(this, m_input2, m_output2, path); + m_decoder->setEQ(m_bands2, m_preamp2); + m_decoder->setEQEnabled(m_useEQ2); CUEStateHandler *csh = new CUEStateHandler(this, m_offset, m_length); m_decoder->setStateHandler(csh); connect(csh, SIGNAL(finished()), SLOT(finish())); @@ -214,6 +220,32 @@ void DecoderCUE::pause() } } +void DecoderCUE::setEQ(int bands[10], int preamp) +{ + for (int i = 0; i < 10; ++i) + m_bands2[i] = bands[i]; + m_preamp2 = preamp; + if (m_decoder) + { + m_decoder->mutex()->lock (); + m_decoder->setEQ(m_bands2, m_preamp2); + m_decoder->setEQEnabled(m_useEQ2); + m_decoder->mutex()->unlock(); + } +} + +void DecoderCUE::setEQEnabled(bool on) +{ + m_useEQ2 = on; + if (m_decoder) + { + m_decoder->mutex()->lock (); + m_decoder->setEQ(m_bands2, m_preamp2); + m_decoder->setEQEnabled(on); + m_decoder->mutex()->unlock(); + } +} + void DecoderCUE::run() { m_decoder->start(); |
