/* 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 "abstractplayer.h"
#include "defs.h"
#include "utils.h"
QT_BEGIN_NAMESPACE
using namespace Phonon;
using namespace Phonon::MMF;
/*! \class MMF::AbstractPlayer
\internal
*/
//-----------------------------------------------------------------------------
// Constructor / destructor
//-----------------------------------------------------------------------------
MMF::AbstractPlayer::AbstractPlayer(const AbstractPlayer *player)
: m_videoOutput(0)
, m_volume(InitialVolume)
, m_state(GroundState)
, m_error(NoError)
, m_tickInterval(DefaultTickInterval)
, m_transitionTime(0)
, m_prefinishMark(0)
{
if(player) {
m_videoOutput = player->m_videoOutput;
m_volume = player->m_volume;
m_tickInterval = player->m_tickInterval;
m_transitionTime = player->m_transitionTime;
m_prefinishMark = player->m_prefinishMark;
// This is to prevent unwanted state transitions occurring as a result
// of MediaObject::switchToNextSource() during playlist playback.
if (StoppedState == player->m_state)
m_state = player->m_state;
}
}
//-----------------------------------------------------------------------------
// MediaObjectInterface
//-----------------------------------------------------------------------------
qint32 MMF::AbstractPlayer::tickInterval() const
{
return m_tickInterval;
}
void MMF::AbstractPlayer::setTickInterval(qint32 interval)
{
m_tickInterval = interval;
doSetTickInterval(interval);
}
qint32 MMF::AbstractPlayer::prefinishMark() const
{
return m_prefinishMark;
}
void MMF::AbstractPlayer::setPrefinishMark(qint32 mark)
{
m_prefinishMark = mark;
}
qint32 MMF::AbstractPlayer::transitionTime() const
{
return m_transitionTime;
}
void MMF::AbstractPlayer::setTransitionTime(qint32 time)
{
m_transitionTime = time;
}
void MMF::AbstractPlayer::volumeChanged(qreal volume)
{
m_volume = volume;
}
//-----------------------------------------------------------------------------
// Video output
//-----------------------------------------------------------------------------
void MMF::AbstractPlayer::setVideoOutput(AbstractVideoOutput* videoOutput)
{
m_videoOutput = videoOutput;
videoOutputChanged();
}
void MMF::AbstractPlayer::videoOutputChanged()
{
// Default behaviour is empty - overridden by VideoPlayer
}
void MMF::AbstractPlayer::setError(const QString &errorMessage)
{
TRACE_CONTEXT(AbstractPlayer::setError, EAudioInternal);
TRACE_ENTRY("state %d", m_state);
m_error = Phonon::NormalError;
m_errorString = errorMessage;
changeState(ErrorState);
TRACE_EXIT_0();
}
void MMF::AbstractPlayer::setError(const QString &errorMessage, int symbianError)
{
setError(errorMessage + ": " + Utils::symbianErrorToString(symbianError));
}
Phonon::ErrorType MMF::AbstractPlayer::errorType() const
{
const Phonon::ErrorType result = (ErrorState == m_state)
? m_error : NoError;
return result;
}
QString MMF::AbstractPlayer::errorString() const
{
return m_errorString;
}
Phonon::State MMF::AbstractPlayer::phononState() const
{
return phononState(m_state);
}
Phonon::State MMF::AbstractPlayer::phononState(PrivateState state) const
{
const Phonon::State phononState =
GroundState == state
? Phonon::LoadingState
: static_cast(state);
return phononState;
}
AbstractPlayer::PrivateState AbstractPlayer::privateState() const
{
return m_state;
}
Phonon::State MMF::AbstractPlayer::state() const
{
return phononState(m_state);
}
void MMF::AbstractPlayer::setState(PrivateState newState)
{
m_state = newState;
}
void MMF::AbstractPlayer::changeState(PrivateState newState)
{
TRACE_CONTEXT(AbstractPlayer::changeState, EAudioInternal);
TRACE_ENTRY("state %d newState %d", privateState(), newState);
// TODO: add some invariants to check that the transition is valid
const Phonon::State oldPhononState = phononState(privateState());
// We need to change the state before we emit stateChanged(), because
// some user code, for instance the mediaplayer, switch on MediaObject's
// state.
setState(newState);
const Phonon::State newPhononState = phononState(newState);
if (oldPhononState != newPhononState) {
TRACE("emit stateChanged(%d, %d)", newPhononState, oldPhononState);
emit stateChanged(newPhononState, oldPhononState);
}
TRACE_EXIT_0();
}
QT_END_NAMESPACE