Detailed Description
The QVideoProbe class allows you to monitor video frames being played or recorded.
QMediaPlayer *player = new QMediaPlayer();
QVideoProbe *probe = new QVideoProbe;
connect(probe, SIGNAL(videoFrameProbed(QVideoFrame)), this, SLOT(processFrame(QVideoFrame)));
probe->setSource(player);
player->setVideoOutput(myVideoSurface);
player->setMedia(QUrl::fromLocalFile("observation.mp4"));
player->play();
This same approach works with the QCamera object as well, to receive viewfinder or video frames as they are captured.
Member Function Documentation
QVideoProbe::QVideoProbe(QObject * parent = 0)
Creates a new QVideoProbe class with parent. After setting the source to monitor with setSource(), the videoFrameProbed() signal will be emitted when video frames are flowing in the source media object.
QVideoProbe::~QVideoProbe()
Destroys this probe and disconnects from any media object.
void QVideoProbe::flush() [signal]
This signal should be emitted when it is required to release all frames. Application must release all outstanding references to video frames.
bool QVideoProbe::isActive() const
Returns true if this probe is monitoring something, or false otherwise.
The source being monitored does not need to be active.
bool QVideoProbe::setSource(QMediaObject * source)
Sets the media object to monitor to source.
If source is zero, this probe will be deactivated and this function wil return true.
If the media object does not support monitoring video, this function will return false.
Any previously monitored objects will no longer be monitored. Passing in the same object will be ignored, but monitoring will continue.
bool QVideoProbe::setSource(QMediaRecorder * mediaRecorder)
Starts monitoring the given mediaRecorder.
If there is no mediaObject associated with mediaRecorder, or if it is zero, this probe will be deactivated and this function wil return true.
If the media recorder instance does not support monitoring video, this function will return false.
Any previously monitored objects will no longer be monitored. Passing in the same object will be ignored, but monitoring will continue.
void QVideoProbe::videoFrameProbed(const QVideoFrame & frame) [signal]
This signal should be emitted when a video frame is processed in the media service.