/* This file is part of the KDE project.
Copyright (C) 2009 Nokia Corporation and/or its subsidiary(-ies).
This library is free software: you can redistribute it and/or modify
it under the terms of the GNU Lesser General Public License as published by
the Free Software Foundation, either version 2.1 or 3 of the License.
This library is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU Lesser General Public License for more details.
You should have received a copy of the GNU Lesser General Public License
along with this library. If not, see .
*/
#include
#include "environmentalreverb.h"
QT_BEGIN_NAMESPACE
using namespace Phonon;
using namespace Phonon::MMF;
/*! \class MMF::EnvironmentalReverb
\internal
*/
// Define functions which depend on concrete native effect class name
PHONON_MMF_DEFINE_EFFECT_FUNCTIONS(EnvironmentalReverb)
enum Parameters
{
DecayHFRatio = AbstractAudioEffect::ParameterBase,
DecayTime,
Density,
Diffusion,
ReflectionsDelay,
ReflectionsLevel,
ReverbDelay,
ReverbLevel,
RoomHFLevel,
RoomLevel
};
EnvironmentalReverb::EnvironmentalReverb(QObject *parent, const QList& parameters)
: AbstractAudioEffect::AbstractAudioEffect(parent, parameters)
{
}
int EnvironmentalReverb::effectParameterChanged(const EffectParameter ¶m,
const QVariant &value)
{
const qreal externalLevel = value.toReal();
const int internalLevel = param.toInternalValue(externalLevel);
TInt err = 0;
switch(param.id()) {
case DecayHFRatio:
TRAP(err, concreteEffect()->SetDecayHFRatioL(internalLevel));
break;
case DecayTime:
TRAP(err, concreteEffect()->SetDecayTimeL(internalLevel));
break;
case Density:
TRAP(err, concreteEffect()->SetDensityL(internalLevel));
break;
case Diffusion:
TRAP(err, concreteEffect()->SetDiffusionL(internalLevel));
break;
case ReflectionsDelay:
TRAP(err, concreteEffect()->SetReflectionsDelayL(internalLevel));
break;
case ReflectionsLevel:
TRAP(err, concreteEffect()->SetReflectionsLevelL(internalLevel));
break;
case ReverbDelay:
TRAP(err, concreteEffect()->SetReverbDelayL(internalLevel));
break;
case ReverbLevel:
TRAP(err, concreteEffect()->SetReverbLevelL(internalLevel));
break;
case RoomHFLevel:
TRAP(err, concreteEffect()->SetRoomHFLevelL(internalLevel));
break;
case RoomLevel:
TRAP(err, concreteEffect()->SetRoomLevelL(internalLevel));
break;
default:
Q_ASSERT_X(false, Q_FUNC_INFO, "Unknown parameter");
}
return err;
}
//-----------------------------------------------------------------------------
// Static functions
//-----------------------------------------------------------------------------
const char* EnvironmentalReverb::description()
{
return "Reverb";
}
// Internal helper function
Phonon::MMF::EffectParameter createParameter(int id, const QString &name,
int defaultValue, int minValue, int maxValue,
Phonon::EffectParameter::Hint hint = Phonon::EffectParameter::IntegerHint)
{
const qreal externalDefaultValue =
Phonon::MMF::EffectParameter::toExternalValue
(defaultValue, minValue, maxValue);
Phonon::MMF::EffectParameter param(id, name, hint,
/* defaultValue */ QVariant(externalDefaultValue),
/* minimumValue */ QVariant(qreal(-1.0)),
/* maximumValue */ QVariant(qreal(+1.0)));
param.setInternalRange(minValue, maxValue);
return param;
}
bool EnvironmentalReverb::getParameters(CMdaAudioOutputStream *stream,
QList& parameters)
{
bool supported = false;
QScopedPointer effect;
TRAPD(err, effect.reset(CEnvironmentalReverb::NewL(*stream)));
if (KErrNone == err) {
supported = true;
TInt32 min, max;
TUint32 umin, umax;
// DecayHFRatio
// Ratio of high-frequency decay time to the value specified by
// DecayTime.
effect->DecayHFRatioRange(umin, umax);
parameters.append(createParameter(
DecayHFRatio, tr("Decay HF ratio (%)"), effect->DecayHFRatio(),
umin, umax));
// DecayTime
// Time over which reverberation is diminished.
effect->DecayTimeRange(umin, umax);
parameters.append(createParameter(
DecayTime, tr("Decay time (ms)"), effect->DecayTime(),
umin, umax));
// Density
// Delay between first and subsequent reflections.
// Note that the S60 platform documentation does not make clear
// the distinction between this value and the Diffusion value.
parameters.append(createParameter(
Density, tr("Density (%)"), effect->Density(), 0, 100));
// Diffusion
// Delay between first and subsequent reflections.
// Note that the S60 platform documentation does not make clear
// the distinction between this value and the Density value.
parameters.append(createParameter(
Diffusion, tr("Diffusion (%)"), effect->Diffusion(), 0, 100));
// ReflectionsDelay
// Amount of delay between the arrival the direct path from the
// source and the arrival of the first reflection.
parameters.append(createParameter(
ReflectionsDelay, tr("Reflections delay (ms)"),
effect->ReflectionsDelay(), 0, effect->ReflectionsDelayMax()));
// ReflectionsLevel
// Amplitude of reflections. This value is corrected by the RoomLevel
// to give the final reflection amplitude.
effect->ReflectionLevelRange(min, max);
parameters.append(createParameter(
ReflectionsLevel, tr("Reflections level (mB)"),
effect->ReflectionsLevel(),
min, max, EffectParameter::LogarithmicHint));
// ReverbDelay
// Amount of time between arrival of the first reflection and start of
// the late reverberation.
parameters.append(createParameter(
ReverbDelay, tr("Reverb delay (ms)"), effect->ReverbDelay(),
0, effect->ReverbDelayMax()));
// ReverbLevel
// Amplitude of reverberations. This value is corrected by the
// RoomLevel to give the final reverberation amplitude.
effect->ReverbLevelRange(min, max);
parameters.append(createParameter(
ReverbLevel, tr("Reverb level (mB)"), effect->ReverbLevel(),
min, max, EffectParameter::LogarithmicHint));
// RoomHFLevel
// Amplitude of low-pass filter used to attenuate the high frequency
// component of reflected sound.
effect->RoomHFLevelRange(min, max);
parameters.append(createParameter(
RoomHFLevel, tr("Room HF level"), effect->RoomHFLevel(),
min, max));
// RoomLevel
// Master volume control for all reflected sound.
effect->RoomLevelRange(min, max);
parameters.append(createParameter(
RoomLevel, tr("Room level (mB)"), effect->RoomLevel(),
min, max, EffectParameter::LogarithmicHint));
}
return supported;
}
QT_END_NAMESPACE