/* 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_MEDIAOBJECT_H
#define PHONON_MEDIAOBJECT_H
#include
#include
#include
#include
#include
#include
#include
#include
#include
#include
#include
QT_BEGIN_NAMESPACE
namespace Phonon
{
class MediaSource;
namespace WaveOut
{
class WorkerThread;
class AudioOutput;
class MediaObject : public QObject, public Phonon::MediaObjectInterface
{
Q_OBJECT
Q_INTERFACES(Phonon::MediaObjectInterface)
public:
MediaObject(QObject *parent);
~MediaObject();
Phonon::State state() const;
bool hasVideo() const;
bool isSeekable() const;
qint64 currentTime() const;
qint32 tickInterval() const;
void setTickInterval(qint32 newTickInterval);
void play();
void pause();
void stop();
void seek(qint64 time);
QString errorString() const;
Phonon::ErrorType errorType() const;
qint64 totalTime() const;
qint32 prefinishMark() const;
void setPrefinishMark(qint32 newPrefinishMark);
qint32 transitionTime() const;
void setTransitionTime(qint32);
qint64 remainingTime() const;
MediaSource source() const;
void setSource(const MediaSource &source);
void setNextSource(const MediaSource &source);
Q_SIGNALS:
void stateChanged(Phonon::State newstate, Phonon::State oldstate);
void tick(qint64 time);
void metaDataChanged(QMultiMap);
void seekableChanged(bool);
void hasVideoChanged(bool);
void bufferStatus(int);
void finished();
void prefinishMarkReached(qint32);
void aboutToFinish();
void totalTimeChanged(qint64 length) const;
void currentSourceChanged(const MediaSource &);
void outOfData(QIODevice *ioStream, QByteArray *buffer, bool *m_bufferingFinshed);
protected:
void setAudioOutput(QObject *audioOutput);
private Q_SLOTS:
void setVolume(qreal newVolume);
private:
bool m_nextBufferIndex;
bool prepareBuffers();
void unPrepareBuffers();
bool getWaveOutDevice();
bool openWaveFile(QString fileName);
bool readHeader();
bool boolUpdateBuffer();
bool fillBuffers();
void swapBuffers();
void setState(Phonon::State newState);
void setError(ErrorType errorType, QString errorMessage);
void deleteValidWaveOutDevice();
void playBuffer(WAVEHDR *waveHeader);
static void CALLBACK WaveOutCallBack(HWAVEOUT hWaveOut, UINT uMsg, DWORD dwInstance, DWORD dwParam1, DWORD dwParam2);
struct {
WAVEHDR *waveHeader;
QByteArray data;
} m_soundBuffer1, m_soundBuffer2;
WAVEFORMATEX m_waveFormatEx;
HWAVEOUT m_hWaveOut;
QFile *m_file;
QIODevice *m_stream;
QString m_errorString;
WorkerThread *m_thread;
MediaSource m_source;
MediaSource m_nextSource;
AudioOutput *m_audioOutput;
ErrorType m_errorType;
qreal m_volume;
qint64 m_mediaSize;
qint64 m_totalTime;
qint64 m_currentTime;
qint64 m_transitionTime;
qint64 m_prefinishMark;
qint64 m_tickIntervalResolution;
qint32 m_tickInterval;
qint32 m_tick;
Phonon::State m_state;
bool m_bufferingFinished;
bool m_paused;
bool m_stopped;
bool m_hasNextSource;
bool m_hasSource;
bool m_sourceIsValid;
bool m_bufferPrepared;
friend class Backend;
};
}
}
QT_END_NAMESPACE
#endif // PHONON_MEDIAOBJECT_H