/* 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 #include // for RApaLsSession #include // for CDataTypeArray #include // for TDataType #include "backend.h" #include "audiooutput.h" #include "mediaobject.h" #include "utils.h" #include "videowidget.h" using namespace Phonon; using namespace Phonon::MMF; Backend::Backend(QObject *parent) : QObject(parent) { TRACE_CONTEXT(Backend::Backend, EBackend); TRACE_ENTRY_0(); setProperty("identifier", QLatin1String("phonon_mmf")); setProperty("backendName", QLatin1String("MMF")); setProperty("backendComment", QLatin1String("Backend using Symbian Multimedia Framework (MMF)")); setProperty("backendVersion", QLatin1String("0.1")); setProperty("backendWebsite", QLatin1String("http://www.qtsoftware.com/")); TRACE_EXIT_0(); } QObject *Backend::createObject(BackendInterface::Class c, QObject *parent, const QList &) { TRACE_CONTEXT(Backend::createObject, EBackend); TRACE_ENTRY("class %d", c); QObject* result = NULL; switch(c) { case AudioOutputClass: result = new AudioOutput(this, parent); break; case MediaObjectClass: result = new MediaObject(parent); break; case VolumeFaderEffectClass: case VisualizationClass: case VideoDataOutputClass: case EffectClass: break; case VideoWidgetClass: result = new VideoWidget(qobject_cast(parent)); break; default: TRACE_PANIC(InvalidBackendInterfaceClass); } TRACE_RETURN("0x%08x", result); } QList Backend::objectDescriptionIndexes(ObjectDescriptionType) const { return QList(); } QHash Backend::objectDescriptionProperties(ObjectDescriptionType, int) const { return QHash(); } bool Backend::startConnectionChange(QSet) { return true; } bool Backend::connectNodes(QObject *source, QObject *target) { TRACE_CONTEXT(Backend::connectNodes, EBackend); TRACE_ENTRY("source 0x%08x target 0x%08x", source, target); MediaObject *const mediaObject = qobject_cast(source); AudioOutput *const audioOutput = qobject_cast(target); VideoWidget *const videoWidget = qobject_cast(target); bool result = false; if(mediaObject and audioOutput) { TRACE("mediaObject 0x%08x -> audioOutput 0x%08x", mediaObject, audioOutput); audioOutput->setVolumeObserver(mediaObject); result = true; } if(mediaObject and videoWidget) { TRACE("mediaObject 0x%08x -> videoWidget 0x%08x", mediaObject, videoWidget); mediaObject->setVideoOutput(&videoWidget->videoOutput()); result = true; } TRACE_RETURN("%d", result); } bool Backend::disconnectNodes(QObject *source, QObject *target) { TRACE_CONTEXT(Backend::disconnectNodes, EBackend); TRACE_ENTRY("source 0x%08x target 0x%08x", source, target); MediaObject *const mediaObject = qobject_cast(source); AudioOutput *const audioOutput = qobject_cast(target); VideoWidget *const videoWidget = qobject_cast(target); bool result = true; // TODO: disconnection TRACE_RETURN("%d", result); } bool Backend::endConnectionChange(QSet) { return true; } void getAvailableMimeTypesL(QStringList& result) { RApaLsSession apaSession; User::LeaveIfError(apaSession.Connect()); CleanupClosePushL(apaSession); static const TInt DataTypeArrayGranularity = 8; CDataTypeArray* array = new (ELeave) CDataTypeArray(DataTypeArrayGranularity); CleanupStack::PushL(array); apaSession.GetSupportedDataTypesL(*array); for(TInt i=0; iCount(); ++i) { const TPtrC mimeType = array->At(i).Des(); const MediaType mediaType = Utils::mimeTypeToMediaType(mimeType); if(MediaTypeAudio == mediaType or MediaTypeVideo == mediaType) { result.append(qt_TDesC2QString(mimeType)); } } CleanupStack::PopAndDestroy(2); // apaSession, array } QStringList Backend::availableMimeTypes() const { QStringList result; // There is no way to return an error from this function, so we just // have to trap and ignore exceptions... TRAP_IGNORE(getAvailableMimeTypesL(result)); result.sort(); return result; } Q_EXPORT_PLUGIN2(phonon_mmf, Phonon::MMF::Backend);