![]() |
Home · All Classes · Main Classes · Grouped Classes · Modules · Functions | ![]() |
provides multimedia data for MediaObjects. More...
#include <Phonon>
Author: Matthias Kretz <kretz@kde.org>
provides multimedia data for MediaObjects.
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. Note that it is possible to provide data from any source by implementing an AbstractMediaStream.
The class has several functions to acquire information about the source it manages, e.g., fileName(), url(), and diskType(). 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);
Currently, Qt's backends support files in local and remote locations. Support for other sources, such as CD/DVD, are planned for the future.
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 a URL, which can be either a local file or a file on the network. |
Phonon::MediaSource::Disc | 2 | The MediaSource object describes a disc. |
Phonon::MediaSource::Stream | 3 | The MediaSource object describes a data stream. This is also the type used for QIODevices. |
See also MediaSource::type() and AbstractMediaStream.
Creates an invalid MediaSource object.
See also Invalid.
Creates a MediaSource object for a local file or a Qt resource.
fileName file name of a local media file or a Qt resource that was compiled in.
Creates a MediaSource object for a URL.
url URL to a media file or stream.
Creates a MediaSource object for discs.
discType See DiscType deviceName A platform dependent device name. This can be useful if the computer has more than one CD drive. It is recommended to use Solid to retrieve the device name in a portable way.
Creates a MediaSource object for a data stream.
Your application can provide the media data by subclassing AbstractMediaStream and passing a pointer to that object. Phonon will never delete the stream.
stream The AbstractMediaStream subclass to provide the media data.
See also setAutoDelete.
Creates a MediaSource object for a QIODevice.
This constructor can be very handy in the combination of QByteArray and QBuffer.
ioDevice An arbitrary readable QIODevice subclass. If the device is not opened MediaSource will open it as QIODevice::ReadOnly. Sequential I/O devices are possible, too. For those MediaObject::isSeekable() will have to return false obviously.
See also setAutoDelete().
Constructs a copy of the other media source.
This constructor is fast thanks to explicit sharing.
Destroys the MediaSource object.
Returns the setting of the auto-delete option. The default is false.
See also setAutoDelete().
Returns the device name of the MediaSource if type() == Disc; otherwise returns QString().
Returns the disc type of the MediaSource if type() == Disc; otherwise returns NoDisc.
Returns the file name of the MediaSource if type() == LocalFile; otherwise returns QString().
Tell the MediaSource to take ownership of the AbstractMediaStream or QIODevice that was passed in the constructor.
The default setting is false, for safety. If you turn it on, you should only access the AbstractMediaStream/QIODevice object as long as you keep a MediaSource object around. As long as you keep the MediaSource object wrapping the stream/device the object will not get deleted.
See also autoDelete().
Returns the media stream of the MediaSource if type() == Stream; otherwise returns 0. QIODevices are handled as streams, too.
Returns the type of the MediaSource (depends on the constructor that was used).
See also Type.
Returns the URL of the MediaSource if type() == URL or type() == LocalFile; otherwise returns QUrl().
Assigns the other media source to this media source and returns a reference to it.
This operation is fast thanks to explicit sharing.
Returns true if this media source is equal to the other media source; otherwise returns false.
Copyright © 2008 Trolltech | Trademarks | Qt 4.4.0-beta1 |