MediaSource Class
(Phonon::MediaSource)The MediaSource class provides multimedia data for media objects. More...
Header: | #include <Phonon/MediaSource> |
Since: | Qt 4.4 |
Public Types
enum | Type { Invalid, LocalFile, Url, Disc, Stream, Empty } |
Public Functions
MediaSource(const QString & fileName) | |
MediaSource(const QUrl & url) | |
MediaSource(Phonon::DiscType discType, const QString & deviceName = QString()) | |
MediaSource(QIODevice * ioDevice) | |
MediaSource(const MediaSource & other) | |
~MediaSource() | |
bool | autoDelete() const |
QString | deviceName() const |
Phonon::DiscType | discType() const |
QString | fileName() const |
void | setAutoDelete(bool enable) |
Type | type() const |
QUrl | url() const |
MediaSource & | operator=(const MediaSource & other) |
bool | operator==(const MediaSource & other) const |
Detailed Description
The MediaSource class provides multimedia data for media objects.
The MediaSource class manages a source of multimedia content, such as a music or video file, of which data is given to a MediaObject.
The media source knows how fetch its data from several sources, e.g., from files, a QIODevice, or a CD. The possible source types are described by the Type enum. The type of the source is set by the media source itself, and is dependent on the constructor used to create it. Note that it is possible to provide data from any source by implementing a QIODevice.
The class has several functions to acquire information about the source it manages, e.g., fileName() and url(). The return from these functions are dependent on the type() of the media source.
Normally, a programmer does not need to be concerned with media sources. It's constructors are implicit, so one can, for instance, send an URL or filename directly to the constructors of the MediaObject.
MediaObject m; QString fileName("/home/foo/bar.ogg"); QUrl url("http://www.example.com/stream.mp3"); QBuffer *someBuffer; m.setCurrentSource(fileName); m.setCurrentSource(url); m.setCurrentSource(someBuffer); m.setCurrentSource(Phonon::Cd);
A MediaSource object cannot be reused for another multimedia source. It is possible to play the same source again, and also stop and start a non-seekable media source, such as a radio stream, with the same MediaSource object.
Qt Backends
Currently, Qt's backends support files in local and remote locations. Support for other sources, such as CD/DVD, are planned for the future.
See also MediaObject and Phonon Module.
Member Type Documentation
enum MediaSource::Type
Identifies the type of media described by the MediaSource object.
Constant | Value | Description |
---|---|---|
Phonon::MediaSource::Invalid | -1 | The MediaSource object does not describe any valid source. |
Phonon::MediaSource::LocalFile | 0 | The MediaSource object describes a local file. |
Phonon::MediaSource::Url | 1 | The MediaSource object describes an URL, which can be either a local file or a file on the network. |
Phonon::MediaSource::Disc | 2 | The MediaSource object describes a disc, e.g., a CD. |
Phonon::MediaSource::Stream | 3 | The MediaSource object describes a data stream. This is the type used for QIODevices. Note that a stream opened with a QUrl, will still be of the Url type. |
Phonon::MediaSource::Empty | 4 | The media source doesn't have a source. |
See also MediaSource::type().
Member Function Documentation
MediaSource::MediaSource(const QString & fileName)
Creates a MediaSource object for the file specified by fileName. You can also use this constructor with Qt resources
MediaSource::MediaSource(const QUrl & url)
Creates a MediaSource object for a the URL specified by url.
If the multimedia content you would like to play back is on a remote network location, you should use this constructor; though, it also possible to specify an URL to a local file.
See also QUrl.
MediaSource::MediaSource(Phonon::DiscType discType, const QString & deviceName = QString())
Creates a MediaSource object for the type of disc specified by discType in the named device referred to by deviceName.
Note: deviceName is a platform dependent device name. It can be useful to specify this if the computer has more than one CD drive. On KDE, it is recommended to use the Solid hardware discovery framework to retrieve the device name in a portable way.
MediaSource::MediaSource(QIODevice * ioDevice)
Creates a MediaSource object for the QIODevice specified by ioDevice.
This constructor can be very handy in the combination of QByteArray and QBuffer.
If you need to fetch multimedia data from a source that is not supported by MediaSource, you should subclass QIODevice and use this MediaSource constructor. It is important that you reimplement QIODevice::isSequential(), as it is used by MediaSource to determine if the media source is seekable.
ioDevice is an arbitrary readable QIODevice subclass. If the device is not opened MediaSource will open it as QIODevice::ReadOnly.
Note: Sequential devices can also be used, but MediaObject::isSeekable() will return false as a result.
Warning: On Windows, we only support QIODevices containing the avi
, mp3
, or mpg
formats. Use the constructor that takes a file name to open files (the Qt backend does not use a QFile internally).
See also setAutoDelete().
MediaSource::MediaSource(const MediaSource & other)
Constructs a copy of the other media source.
This constructor is fast thanks to explicit sharing.
MediaSource::~MediaSource()
Destroys the MediaSource object. You should never delete a MediaSource yourself, the MediaObject will handle this.
bool MediaSource::autoDelete() const
Returns the setting of the auto-delete option. The default is false.
See also setAutoDelete().
QString MediaSource::deviceName() const
Returns the device name of the MediaSource if type() == Disc; otherwise returns QString().
See also type().
Phonon::DiscType MediaSource::discType() const
Returns the disc type of the MediaSource if type() == Disc; otherwise returns NoDisc.
See also type().
QString MediaSource::fileName() const
Returns the file name of the MediaSource if type() == LocalFile; otherwise, returns QString().
See also type().
void MediaSource::setAutoDelete(bool enable)
If enable is true, the media source will take ownership of the object passed in the MediaSource's constructor object that was passed in the constructor; otherwise, the programmer is responsible for deletion of this object.
This setting is false by default. If you enable it, you should only access the stream or device as long as you keep the media source object around. As long as you keep the media source wrapping the stream or device, the object will not get deleted.
See also autoDelete().
Type MediaSource::type() const
Returns the type of the MediaSource (depends on the constructor that was used).
See also Type.
QUrl MediaSource::url() const
Returns the URL of the MediaSource if type() == URL or type() == LocalFile; otherwise returns QUrl().
See also type().
MediaSource & MediaSource::operator=(const MediaSource & other)
Assigns the other media source to this media source and returns a reference to it.
This operation is fast thanks to explicit sharing.
bool MediaSource::operator==(const MediaSource & other) const
Returns true if this media source is equal to the other media source; otherwise returns false.
© 2016 The Qt Company Ltd. Documentation contributions included herein are the copyrights of their respective owners. The documentation provided herein is licensed under the terms of the GNU Free Documentation License version 1.3 as published by the Free Software Foundation. Qt and respective logos are trademarks of The Qt Company Ltd. in Finland and/or other countries worldwide. All other trademarks are property of their respective owners.