/* 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 .
*/
#ifndef PHONON_MMF_AUDIOOUTPUT_H
#define PHONON_MMF_AUDIOOUTPUT_H
#include
QT_BEGIN_NAMESPACE
namespace Phonon
{
namespace MMF
{
class Backend;
class VolumeObserver;
/**
* @short AudioOutputInterface implementation for MMF.
*
* Forwards volume commands to the VolumeObserver instance,
* which is provided by the backend when MediaNode objects are
* connected.
*
* \section volume Volume
*
* Phonon's concept on volume is from 0.0 to 1.0, and from 1< it does
* voltage multiplication. CDrmPlayerUtility goes from 1 to
* CDrmPlayerUtility::MaxVolume(). We apply some basic math to convert
* between the two.
*
* @author Frans Englich
*/
class AudioOutput : public QObject
, public AudioOutputInterface
{
Q_OBJECT
Q_INTERFACES(Phonon::AudioOutputInterface)
public:
AudioOutput(Backend *backend, QObject *parent);
virtual qreal volume() const;
virtual void setVolume(qreal volume);
virtual int outputDevice() const;
/**
* Has no effect.
*/
virtual bool setOutputDevice(int);
/**
* Has no effect.
*/
virtual bool setOutputDevice(const Phonon::AudioOutputDevice &);
/**
* Called by backend when nodes are connected.
*/
void setVolumeObserver(VolumeObserver* observer);
Q_SIGNALS:
void volumeChanged(qreal volume);
void audioDeviceFailed();
private:
qreal m_volume;
// Not owned
VolumeObserver* m_observer;
};
}
}
QT_END_NAMESPACE
#endif