src/3rdparty/phonon/mmf/effectfactory.h
author Eckhart Koeppen <eckhart.koppen@nokia.com>
Wed, 21 Apr 2010 11:15:19 +0300
branchRCL_3
changeset 11 25a739ee40f4
parent 4 3b1da2848fc7
permissions -rw-r--r--
3a438a6e0b41f1ef657ef0e648d352db636204aa

/*  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 <http://www.gnu.org/licenses/>.

*/

#ifndef PHONON_MMF_EFFECTFACTORY_H
#define PHONON_MMF_EFFECTFACTORY_H

#include "abstractaudioeffect.h"
#include "effectparameter.h"

QT_BEGIN_NAMESPACE

namespace Phonon
{
namespace MMF
{

/**
 * @short Contains utility functions related to effects.
 */
class EffectFactory : public QObject
{
    Q_OBJECT

public:
    EffectFactory(QObject *parent);
    ~EffectFactory();

    enum Type
    {
        TypeAudioEqualizer = 0
    ,   TypeBassBoost
    ,   TypeDistanceAttenuation
    ,   TypeEnvironmentalReverb
    ,   TypeListenerOrientation
    ,   TypeLoudness
    ,   TypeSourceOrientation
    ,   TypeStereoWidening
    };

    /**
     * @short Creates an audio effect of type @p type.
     */
    AbstractAudioEffect *createAudioEffect(Type type, QObject *parent);

    /**
     * @short Return the properties for effect @p type.
     *
     * This handles the effects for
     * BackendInterface::objectDescriptionProperties().
     */
    QHash<QByteArray, QVariant> audioEffectDescriptions(Type type);

    /**
     * @short Returns the indexes for the supported effects.
     *
     * This handles the effects for
     * BackendInterface::objectDescriptionIndexes().
     */
    QList<int> effectIndexes();

private:
    void initialize();

    struct EffectData
    {
        bool                            m_supported;
        QHash<QByteArray, QVariant>     m_descriptions;
        QList<EffectParameter>          m_parameters;
    };

    template<typename BackendNode> EffectData getData();
    const EffectData& data(Type type) const;

private:
    bool                                m_initialized;
    QHash<Type, EffectData>             m_effectData;

};

}
}

QT_END_NAMESPACE

#endif