QMediaPlayer Class

The QMediaPlayer class allows the playing of a media source. 更多...

头文件: #include <QMediaPlayer>
qmake: QT += multimedia
基类: QMediaObject

公有类型

enum Error { NoError, ResourceError, FormatError, NetworkError, AccessDeniedError, ServiceMissingError }
enum Flag { LowLatency, StreamPlayback, VideoSurface }
flags Flags
enum MediaStatus { UnknownMediaStatus, NoMedia, LoadingMedia, LoadedMedia, ..., InvalidMedia }
enum State { StoppedState, PlayingState, PausedState }

属性

公有函数

QMediaPlayer(QObject *parent = Q_NULLPTR, Flags flags = Flags())
~QMediaPlayer()
QAudio::Role audioRole() const
int bufferStatus() const
QMediaContent currentMedia() const
QNetworkConfiguration currentNetworkConfiguration() const
qint64 duration() const
Error error() const
QString errorString() const
bool isAudioAvailable() const
bool isMuted() const
bool isSeekable() const
bool isVideoAvailable() const
QMediaContent media() const
MediaStatus mediaStatus() const
const QIODevice *mediaStream() const
qreal playbackRate() const
QMediaPlaylist *playlist() const
qint64 position() const
void setAudioRole(QAudio::Role audioRole)
void setVideoOutput(QVideoWidget *output)
void setVideoOutput(QGraphicsVideoItem *output)
void setVideoOutput(QAbstractVideoSurface *surface)
State state() const
QList<QAudio::Role> supportedAudioRoles() const
int volume() const

重新实现的公有函数

virtual QMultimedia::AvailabilityStatus availability() const override

公有槽函数

void pause()
void play()
void setMedia(const QMediaContent &media, QIODevice *stream = Q_NULLPTR)
void setMuted(bool muted)
void setNetworkConfigurations(const QList<QNetworkConfiguration> &configurations)
void setPlaybackRate(qreal rate)
void setPlaylist(QMediaPlaylist *playlist)
void setPosition(qint64 position)
void setVolume(int volume)
void stop()
  • 1 个公有槽函数继承自 QObject

信号

void audioAvailableChanged(bool available)
void audioRoleChanged(QAudio::Role role)
void bufferStatusChanged(int percentFilled)
void currentMediaChanged(const QMediaContent &media)
void durationChanged(qint64 duration)
void error(QMediaPlayer::Error error)
void mediaChanged(const QMediaContent &media)
void mediaStatusChanged(QMediaPlayer::MediaStatus status)
void mutedChanged(bool muted)
void networkConfigurationChanged(const QNetworkConfiguration &configuration)
void playbackRateChanged(qreal rate)
void positionChanged(qint64 position)
void seekableChanged(bool seekable)
void stateChanged(QMediaPlayer::State state)
void videoAvailableChanged(bool videoAvailable)
void volumeChanged(int volume)

静态公有成员

QMultimedia::SupportEstimate hasSupport(const QString &mimeType, const QStringList &codecs = QStringList(), Flags flags = Flags())
  • 10 个静态公有成员继承自 QObject

其他继承的成员

详细描述

QMediaPlayer 是一个高级的多媒体播放类.

QMediaPlayer 可以用来播放歌曲, 电影和网络广播等内容.QMediaContent 对象保存播放内容, 它可以视为带有附加信息的主URL或规范URL. QMediaContent 还支持回放功能.


  player = new QMediaPlayer;
  connect(player, SIGNAL(positionChanged(qint64)), this, SLOT(positionChanged(qint64)));
  player->setMedia(QUrl::fromLocalFile("/Users/me/Music/coolsong.mp3"));
  player->setVolume(50);
  player->play();

QVideoWidgetQMediaPlayer 一起渲染视频, QMediaPlaylist 用于播放列表.


  playlist = new QMediaPlaylist;
  playlist->addMedia(QUrl("http://example.com/movie1.mp4"));
  playlist->addMedia(QUrl("http://example.com/movie2.mp4"));
  playlist->addMedia(QUrl("http://example.com/movie3.mp4"));
  playlist->setCurrentIndex(1);

  player = new QMediaPlayer;
  player->setPlaylist(playlist);

  videoWidget = new QVideoWidget;
  player->setVideoOutput(videoWidget);
  videoWidget->show();

  player->play();

Since QMediaPlayerQMediaObject子类, 你可以使用 QMediaObject 的函数:

参见 QMediaObject, QMediaService, QVideoWidget, QMediaPlaylist.

成员类型

enum QMediaPlayer::Error

Defines a media player error condition.

ConstantValueDescription
QMediaPlayer::NoError0No error has occurred.
QMediaPlayer::ResourceError1A media resource couldn't be resolved.
QMediaPlayer::FormatError2The format of a media resource isn't (fully) supported. Playback may still be possible, but without an audio or video component.
QMediaPlayer::NetworkError3A network error occurred.
QMediaPlayer::AccessDeniedError4There are not the appropriate permissions to play a media resource.
QMediaPlayer::ServiceMissingError5A valid playback service was not found, playback cannot proceed.

enum QMediaPlayer::Flag
flags QMediaPlayer::Flags

ConstantValueDescription
QMediaPlayer::LowLatency0x01The player is expected to be used with simple audio formats, but playback should start without significant delay. Such playback service can be used for beeps, ringtones, etc.
QMediaPlayer::StreamPlayback0x02The player is expected to play QIODevice based streams. If passed to QMediaPlayer constructor, the service supporting streams playback will be chosen.
QMediaPlayer::VideoSurface0x04The player is expected to be able to render to a QAbstractVideoSurface output.

The Flags type is a typedef for QFlags<Flag>. It stores an OR combination of Flag values.

enum QMediaPlayer::MediaStatus

Defines the status of a media player's current media.

ConstantValueDescription
QMediaPlayer::UnknownMediaStatus0The status of the media cannot be determined.
QMediaPlayer::NoMedia1The is no current media. The player is in the StoppedState.
QMediaPlayer::LoadingMedia2The current media is being loaded. The player may be in any state.
QMediaPlayer::LoadedMedia3The current media has been loaded. The player is in the StoppedState.
QMediaPlayer::StalledMedia4Playback of the current media has stalled due to insufficient buffering or some other temporary interruption. The player is in the PlayingState or PausedState.
QMediaPlayer::BufferingMedia5The player is buffering data but has enough data buffered for playback to continue for the immediate future. The player is in the PlayingState or PausedState.
QMediaPlayer::BufferedMedia6The player has fully buffered the current media. The player is in the PlayingState or PausedState.
QMediaPlayer::EndOfMedia7Playback has reached the end of the current media. The player is in the StoppedState.
QMediaPlayer::InvalidMedia8The current media cannot be played. The player is in the StoppedState.

enum QMediaPlayer::State

Defines the current state of a media player.

ConstantValueDescription
QMediaPlayer::StoppedState0The media player is not playing content, playback will begin from the start of the current track.
QMediaPlayer::PlayingState1The media player is currently playing content.
QMediaPlayer::PausedState2The media player has paused playback, playback of the current track will resume from the position the player was paused at.

属性

audioAvailable : const bool

This property holds the audio availabilty status for the current media.

As the life time of QMediaPlayer can be longer than the playback of one QMediaContent, this property may change over time, the audioAvailableChanged signal can be used to monitor it's status.

访问函数:

bool isAudioAvailable() const

Notifier signal:

void audioAvailableChanged(bool available)

audioRole : QAudio::Role

This property holds the role of the audio stream played by the media player.

It can be set to specify the type of audio being played, allowing the system to make appropriate decisions when it comes to volume, routing or post-processing.

The audio role must be set before calling setMedia().

This property was introduced in Qt 5.6.

访问函数:

QAudio::Role audioRole() const
void setAudioRole(QAudio::Role audioRole)

参见 supportedAudioRoles().

bufferStatus : const int

This property holds the percentage of the temporary buffer filled before playback begins or resumes, from 0 (empty) to 100 (full).

When the player object is buffering; this property holds the percentage of the temporary buffer that is filled. The buffer will need to reach 100% filled before playback can start or resume, at which time mediaStatus() will return BufferedMedia or BufferingMedia. If the value is anything lower than 100, mediaStatus() will return StalledMedia.

访问函数:

int bufferStatus() const

Notifier signal:

void bufferStatusChanged(int percentFilled)

参见 mediaStatus().

currentMedia : const QMediaContent

This property holds the current active media content being played by the player object. This value could be different from QMediaPlayer::media property if a playlist is used. In this case currentMedia indicates the current media content being processed by the player, while QMediaPlayer::media property contains the original playlist.

访问函数:

QMediaContent currentMedia() const

Notifier signal:

void currentMediaChanged(const QMediaContent &media)

参见 QMediaContent and media().

duration : const qint64

This property holds the duration of the current media.

The value is the total playback time in milliseconds of the current media. The value may change across the life time of the QMediaPlayer object and may not be available when initial playback begins, connect to the durationChanged() signal to receive status notifications.

访问函数:

qint64 duration() const

Notifier signal:

void durationChanged(qint64 duration)

error : const QString

This property holds a string describing the last error condition.

访问函数:

QString errorString() const

参见 error().

media : QMediaContent

This property holds the active media source being used by the player object.

The player object will use the QMediaContent for selection of the content to be played.

By default this property has a null QMediaContent.

Setting this property to a null QMediaContent will cause the player to discard all information relating to the current media source and to cease all I/O operations related to that media.

访问函数:

QMediaContent media() const
void setMedia(const QMediaContent &media, QIODevice *stream = Q_NULLPTR)

Notifier signal:

void mediaChanged(const QMediaContent &media)

参见 QMediaContent and currentMedia().

mediaStatus : const MediaStatus

This property holds the status of the current media stream.

The stream status describes how the playback of the current stream is progressing.

By default this property is QMediaPlayer::NoMedia

访问函数:

MediaStatus mediaStatus() const

Notifier signal:

void mediaStatusChanged(QMediaPlayer::MediaStatus status)

参见 state.

muted : bool

This property holds the muted state of the current media.

The value will be true if the playback volume is muted; otherwise false.

访问函数:

bool isMuted() const
void setMuted(bool muted)

Notifier signal:

void mutedChanged(bool muted)

playbackRate : qreal

This property holds the playback rate of the current media.

This value is a multiplier applied to the media's standard play rate. By default this value is 1.0, indicating that the media is playing at the standard pace. Values higher than 1.0 will increase the rate of play. Values less than zero can be set and indicate the media will rewind at the multiplier of the standard pace.

Not all playback services support change of the playback rate. It is framework defined as to the status and quality of audio and video while fast forwarding or rewinding.

访问函数:

qreal playbackRate() const
void setPlaybackRate(qreal rate)

Notifier signal:

void playbackRateChanged(qreal rate)

playlist : QMediaPlaylist *

This property holds the media playlist being used by the player object.

The player object will use the current playlist item for selection of the content to be played.

By default this property is set to null.

If the media playlist is used as a source, QMediaPlayer::currentMedia is updated with a current playlist item. The current source should be selected with QMediaPlaylist::setCurrentIndex(int) instead of QMediaPlayer::setMedia(), otherwise the current playlist will be discarded.

访问函数:

QMediaPlaylist *playlist() const
void setPlaylist(QMediaPlaylist *playlist)

参见 QMediaContent.

position : qint64

This property holds the playback position of the current media.

The value is the current playback position, expressed in milliseconds since the beginning of the media. Periodically changes in the position will be indicated with the signal positionChanged(), the interval between updates can be set with QMediaObject's method setNotifyInterval().

访问函数:

qint64 position() const
void setPosition(qint64 position)

Notifier signal:

void positionChanged(qint64 position)

seekable : const bool

This property holds the seek-able status of the current media

If seeking is supported this property will be true; false otherwise. The status of this property may change across the life time of the QMediaPlayer object, use the seekableChanged signal to monitor changes.

访问函数:

bool isSeekable() const

Notifier signal:

void seekableChanged(bool seekable)

state : const State

This property holds the media player's playback state.

By default this property is QMediaPlayer::Stopped

访问函数:

State state() const

Notifier signal:

void stateChanged(QMediaPlayer::State state)

参见 mediaStatus(), play(), pause(), and stop().

videoAvailable : const bool

This property holds the video availability status for the current media.

If available, the QVideoWidget class can be used to view the video. As the life time of QMediaPlayer can be longer than the playback of one QMediaContent, this property may change over time, the videoAvailableChanged signal can be used to monitor it's status.

访问函数:

bool isVideoAvailable() const

Notifier signal:

void videoAvailableChanged(bool videoAvailable)

参见 QVideoWidget and QMediaContent.

volume : int

This property holds the current playback volume.

The playback volume is scaled linearly, ranging from 0 (silence) to 100 (full volume). Values outside this range will be clamped.

By default the volume is 100.

UI volume controls should usually be scaled nonlinearly. For example, using a logarithmic scale will produce linear changes in perceived loudness, which is what a user would normally expect from a volume control. See QAudio::convertVolume() for more details.

访问函数:

int volume() const
void setVolume(int volume)

Notifier signal:

void volumeChanged(int volume)

成员函数

QMediaPlayer::QMediaPlayer(QObject *parent = Q_NULLPTR, Flags flags = Flags())

Construct a QMediaPlayer instance parented to parent and with flags.

QMediaPlayer::~QMediaPlayer()

Destroys the player object.

[signal] void QMediaPlayer::audioAvailableChanged(bool available)

Signals the availability of audio content has changed to available.

Note: Notifier signal for property audioAvailable.

[signal] void QMediaPlayer::audioRoleChanged(QAudio::Role role)

Signals that the audio role of the media player has changed.

This function was introduced in Qt 5.6.

[override virtual] QMultimedia::AvailabilityStatus QMediaPlayer::availability() const

Reimplemented from QMediaObject::availability().

[signal] void QMediaPlayer::bufferStatusChanged(int percentFilled)

Signal the amount of the local buffer filled as a percentage by percentFilled.

Note: Notifier signal for property bufferStatus.

[signal] void QMediaPlayer::currentMediaChanged(const QMediaContent &media)

Signals that the current playing content has been changed to media.

Note: Notifier signal for property currentMedia.

参见 currentMedia() and mediaChanged().

QNetworkConfiguration QMediaPlayer::currentNetworkConfiguration() const

Returns the current network access point in use. If a default contructed QNetworkConfiguration is returned this feature is not available or that none of the current supplied configurations are in use.

[signal] void QMediaPlayer::durationChanged(qint64 duration)

Signal the duration of the content has changed to duration, expressed in milliseconds.

Note: Notifier signal for property duration.

Error QMediaPlayer::error() const

Returns the current error state.

[signal] void QMediaPlayer::error(QMediaPlayer::Error error)

Signals that an error condition has occurred.

Note: Signal error is overloaded in this class. To connect to this one using the function pointer syntax, you must specify the signal type in a static cast, as shown in this example:


  connect(mediaPlayer, static_cast<void(QMediaPlayer::*)(QMediaPlayer::Error)>(&QMediaPlayer::error),
      [=](QMediaPlayer::Error error){ /* ... */ });

参见 errorString().

[static] QMultimedia::SupportEstimate QMediaPlayer::hasSupport(const QString &mimeType, const QStringList &codecs = QStringList(), Flags flags = Flags())

Returns the level of support a media player has for a mimeType and a set of codecs.

The flags argument allows additional requirements such as performance indicators to be specified.

[signal] void QMediaPlayer::mediaChanged(const QMediaContent &media)

Signals that the media source has been changed to media.

Note: Notifier signal for property media.

参见 media() and currentMediaChanged().

[signal] void QMediaPlayer::mediaStatusChanged(QMediaPlayer::MediaStatus status)

Signals that the status of the current media has changed.

Note: Notifier signal for property mediaStatus.

参见 mediaStatus().

const QIODevice *QMediaPlayer::mediaStream() const

Returns the stream source of media data.

This is only valid if a stream was passed to setMedia().

参见 setMedia().

[signal] void QMediaPlayer::mutedChanged(bool muted)

Signal the mute state has changed to muted.

Note: Notifier signal for property muted.

[signal] void QMediaPlayer::networkConfigurationChanged(const QNetworkConfiguration &configuration)

Signal that the active in use network access point has been changed to configuration and all subsequent network access will use this configuration.

[slot] void QMediaPlayer::pause()

Pause playing the current source.

[slot] void QMediaPlayer::play()

Start or resume playing the current source.

[signal] void QMediaPlayer::playbackRateChanged(qreal rate)

Signals the playbackRate has changed to rate.

Note: Notifier signal for property playbackRate.

[signal] void QMediaPlayer::positionChanged(qint64 position)

Signal the position of the content has changed to position, expressed in milliseconds.

Note: Notifier signal for property position.

[signal] void QMediaPlayer::seekableChanged(bool seekable)

Signals the seekable status of the player object has changed.

Note: Notifier signal for property seekable.

[slot] void QMediaPlayer::setMedia(const QMediaContent &media, QIODevice *stream = Q_NULLPTR)

Sets the current media source.

If a stream is supplied; media data will be read from it instead of resolving the media source. In this case the media source may still be used to resolve additional information about the media such as mime type. The stream must be open and readable.

Setting the media to a null QMediaContent will cause the player to discard all information relating to the current media source and to cease all I/O operations related to that media.

Note: This function returns immediately after recording the specified source of the media. It does not wait for the media to finish loading and does not check for errors. Listen for the mediaStatusChanged() and error() signals to be notified when the media is loaded and when an error occurs during loading.

Note: Setter function for property media.

参见 media().

[slot] void QMediaPlayer::setNetworkConfigurations(const QList<QNetworkConfiguration> &configurations)

Sets the network access points for remote media playback. configurations contains, in ascending preferential order, a list of configuration that can be used for network access.

This will invalidate the choice of previous configurations.

void QMediaPlayer::setVideoOutput(QVideoWidget *output)

Attach a QVideoWidget video output to the media player.

If the media player has already video output attached, it will be replaced with a new one.

void QMediaPlayer::setVideoOutput(QGraphicsVideoItem *output)

Attach a QGraphicsVideoItem video output to the media player.

If the media player has already video output attached, it will be replaced with a new one.

void QMediaPlayer::setVideoOutput(QAbstractVideoSurface *surface)

Sets a video surface as the video output of a media player.

If a video output has already been set on the media player the new surface will replace it.

[signal] void QMediaPlayer::stateChanged(QMediaPlayer::State state)

Signal the state of the Player object has changed.

Note: Notifier signal for property state.

[slot] void QMediaPlayer::stop()

Stop playing, and reset the play position to the beginning.

QList<QAudio::Role> QMediaPlayer::supportedAudioRoles() const

Returns a list of supported audio roles.

If setting the audio role is not supported, an empty list is returned.

This function was introduced in Qt 5.6.

参见 audioRole.

[signal] void QMediaPlayer::videoAvailableChanged(bool videoAvailable)

Signal the availability of visual content has changed to videoAvailable.

Note: Notifier signal for property videoAvailable.

[signal] void QMediaPlayer::volumeChanged(int volume)

Signal the playback volume has changed to volume.

Note: Notifier signal for property volume.