/* This file is part of the KDE project Copyright (C) 2007-2008 Matthias Kretz 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 of the License, or (at your option) version 3, or any later version accepted by the membership of KDE e.V. (or its successor approved by the membership of KDE e.V.), Nokia Corporation (or its successors, if any) and the KDE Free Qt Foundation, which shall act as a proxy defined in Section 6 of version 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_PLATFORMPLUGIN_H #define PHONON_PLATFORMPLUGIN_H #include #include #include #include "phonon_export.h" #include "objectdescription.h" QT_BEGIN_HEADER QT_BEGIN_NAMESPACE #ifndef QT_NO_PHONON_PLATFORMPLUGIN class QUrl; class QObject; class QIcon; namespace Phonon { class AbstractMediaStream; class PlatformPlugin { public: virtual ~PlatformPlugin() {} /** * Creates a AbstractMediaStream object that provides the data for the given \p url. On KDE * this uses KIO. */ virtual AbstractMediaStream *createMediaStream(const QUrl &url, QObject *parent) = 0; /** * Returns the icon for the given icon name. */ virtual QIcon icon(const QString &name) const = 0; /** * Shows a notification popup */ virtual void notification(const char *notificationName, const QString &text, const QStringList &actions = QStringList(), QObject *receiver = 0, const char *actionSlot = 0) const = 0; /** * Returns the name of the application. For most Qt application this is * QCoreApplication::applicationName(), but for KDE this is overridden by KAboutData. */ virtual QString applicationName() const = 0; /** * Creates a backend object. This way the platform can decide the backend preference. */ virtual QObject *createBackend() = 0; /** * Using the library loader of the platform, loads a given backend. */ virtual QObject *createBackend(const QString &library, const QString &version) = 0; /** * Tries to check whether the default backend supports a given MIME type without loading the * actual backend library. On KDE this reads the MIME type list from the .desktop file of * the backend. */ virtual bool isMimeTypeAvailable(const QString &mimeType) const = 0; /** * Saves the volume for the given output. */ virtual void saveVolume(const QString &outputName, qreal volume) = 0; /** * Loads the volume for the given output. */ virtual qreal loadVolume(const QString &outputName) const = 0; virtual QList objectDescriptionIndexes(ObjectDescriptionType type) const = 0; virtual QHash objectDescriptionProperties(ObjectDescriptionType type, int index) const = 0; /** * Returns a list of (driver, handle) pairs for the given AudioOutputDevice description. */ virtual QList > deviceAccessListFor(const Phonon::AudioOutputDevice &) const { return QList >(); } }; } // namespace Phonon Q_DECLARE_INTERFACE(Phonon::PlatformPlugin, "3PlatformPlugin.phonon.kde.org") #endif //QT_NO_PHONON_PLATFORMPLUGIN QT_END_NAMESPACE QT_END_HEADER #endif // PHONON_PLATFORMPLUGIN_H