aboutsummaryrefslogtreecommitdiff
path: root/src/plugins/General/rgscan
diff options
context:
space:
mode:
authortrialuser02 <trialuser02@90c681e8-e032-0410-971d-27865f9a5e38>2013-10-09 17:48:54 +0000
committertrialuser02 <trialuser02@90c681e8-e032-0410-971d-27865f9a5e38>2013-10-09 17:48:54 +0000
commit92239f61e83e7269edd138fb389b940b0c16eb26 (patch)
tree639fc71d29eb6410b64ef1f6f9b0d2684a624850 /src/plugins/General/rgscan
parent8aca0ef50efe1aed03521fe253d5eb4c029e317b (diff)
downloadqmmp-92239f61e83e7269edd138fb389b940b0c16eb26.tar.gz
qmmp-92239f61e83e7269edd138fb389b940b0c16eb26.tar.bz2
qmmp-92239f61e83e7269edd138fb389b940b0c16eb26.zip
replaygain scaner: fixed some bugs
git-svn-id: http://svn.code.sf.net/p/qmmp-dev/code/trunk/qmmp@3762 90c681e8-e032-0410-971d-27865f9a5e38
Diffstat (limited to 'src/plugins/General/rgscan')
-rw-r--r--src/plugins/General/rgscan/rgscaner.cpp89
1 files changed, 58 insertions, 31 deletions
diff --git a/src/plugins/General/rgscan/rgscaner.cpp b/src/plugins/General/rgscan/rgscaner.cpp
index 0fc2e3833..c31785977 100644
--- a/src/plugins/General/rgscan/rgscaner.cpp
+++ b/src/plugins/General/rgscan/rgscaner.cpp
@@ -141,51 +141,78 @@ void RGScaner::run()
qDebug("RGScaner: staring thread %lu", QThread::currentThreadId());
m_user_stop = false;
- const int buf_size = 8192; //samples
AudioParameters ap = m_decoder->audioParameters();
- //Qmmp::AudioFormat format = ap.format();
- float output_buf[buf_size];
- qint64 output_at = 0;
- qint64 total = 0;
- qint64 len = 0;
+ Qmmp::AudioFormat format = ap.format();
+ bool headroom = m_decoder->hasHeadroom();
+ const int buf_size = 8192; //samples
+ double out_left[buf_size >> 1], out_right[buf_size >> 1]; //replay gain buffers
+ float float_buf[buf_size]; //float buffer
+ char char_buf[buf_size*ap.sampleSize()]; //char buffer
qint64 totalSamples = m_decoder->totalTime() * ap.sampleRate() * ap.channels() / 1000;
- float max = 0;
- double out_left[buf_size/2];
- double out_right[buf_size/2];
-
+ qint64 sample_count = 0;
+ qint64 samples = 0;
+ double max = 0;
if(m_handle)
- {
DeinitGainAbalysis(m_handle);
- m_handle = 0;
- }
-
InitGainAnalysis(&m_handle, 44100);
forever
{
- // decode
- len = m_decoder->read((float *)(output_buf + output_at), buf_size - output_at);
- if (len > 0)
+ if(headroom)
+ {
+ samples = m_decoder->read(float_buf, buf_size);
+
+ if(samples <= 0)
+ break; //TODO add error handler
+
+ for(int i = 0; i < (samples >> 1); ++i)
+ {
+ out_left[i] = float_buf[i*2]*32768.0;
+ out_right[i] = float_buf[i*2+1]*32768.0;
+ max = qMax(fabs(out_left[i]), max);
+ max = qMax(fabs(out_right[i]), max);
+ }
+ }
+ else
{
- output_at += len;
- total += len;
- emit progress(100 * total / totalSamples);
+ qint64 len = m_decoder->read(char_buf, buf_size*ap.sampleSize());
+
+ if(len <= 0)
+ break; //TODO add error handler
+ samples = len / ap.sampleSize();
- for(int i = 0; i < len/2; ++i)
+ for(int i = 0; i < (samples >> 1); ++i)
{
- out_left[i] = output_buf[i*2]*32767.0;
- out_right[i] = output_buf[i*2+1]*32767.0;
- max = qMax(fabs(out_left[i]), (double)max);
- max = qMax(fabs(out_right[i]), (double)max);
+ switch (format)
+ {
+ case Qmmp::PCM_S8:
+ out_left[i] = char_buf[i*2]*32768.0/128.0;
+ out_right[i] = char_buf[i*2+1]*32768.0/128.0;
+ break;
+ case Qmmp::PCM_S16LE:
+ out_left[i] = ((short *)char_buf)[i*2];
+ out_right[i] = ((short *)char_buf)[i*2+1];
+ break;
+ case Qmmp::PCM_S24LE:
+ out_left[i] = ((qint32 *)char_buf)[i*2]*32768.0/((1U << 23));
+ out_right[i] = ((qint32 *)char_buf)[i*2+1]*32768.0/((1U << 23));
+ case Qmmp::PCM_S32LE:
+ out_left[i] = ((qint32 *)char_buf)[i*2]*32768.0/((1U << 31));
+ out_right[i] = ((qint32 *)char_buf)[i*2+1]*32768.0/((1U << 31));
+ default:
+ break;
+ }
+ max = qMax(fabs(out_left[i]), max);
+ max = qMax(fabs(out_right[i]), max);
}
- AnalyzeSamples(m_handle, out_left, out_right, len/2, 2);
- output_at = 0;
}
- else if (len <= 0)
- break;
+
+ AnalyzeSamples(m_handle, out_left, out_right, samples >> 1, 2);
+ sample_count += samples;
+ emit progress(100 * sample_count / totalSamples);
m_mutex.lock();
if(m_user_stop)
@@ -197,8 +224,8 @@ void RGScaner::run()
}
m_gain = GetTitleGain(m_handle);
- m_peak = max/32767.0;
- qDebug("peak = %f", m_peak);
+ m_peak = max/32768.0;
+ qDebug("RGScaner: peak = %f", m_peak);
qDebug("RGScaner: thread %ld finished", QThread::currentThreadId());
m_is_running = false;
emit progress(100);