Browse Source

Merge pull request #6368 from bluerobotics/patrickelectric/fix#164

Fix video popup on windows
QGC4.4
Don Gagne 7 years ago committed by GitHub
parent
commit
f68eccd494
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
  1. 63
      src/FlightDisplay/FlightDisplayView.qml
  2. 2
      src/FlightDisplay/VideoManager.h
  3. 6
      src/VideoStreaming/VideoReceiver.cc
  4. 1
      src/VideoStreaming/VideoReceiver.h
  5. 8
      src/VideoStreaming/gstqtvideosink/painters/videonode.cpp

63
src/FlightDisplay/FlightDisplayView.qml

@ -212,7 +212,23 @@ QGCView { @@ -212,7 +212,23 @@ QGCView {
_flightVideo.state = "unpopup"
videoWindow.visible = false
}
}
/* This timer will startVideo again after the popup window appears and is loaded.
* Such approach was the only one to avoid a crash for windows users
*/
Timer {
id: videoPopUpTimer
interval: 2000;
running: false;
repeat: false
onTriggered: {
// If state is popup, the next one will be popup-finished
if (_flightVideo.state == "popup") {
_flightVideo.state = "popup-finished"
}
QGroundControl.videoManager.startVideo()
}
}
QGCMapPalette { id: mapPal; lightColors: _mainIsMap ? _flightMap.isSatelliteMap : true }
@ -270,6 +286,20 @@ QGCView { @@ -270,6 +286,20 @@ QGCView {
anchors.left: _panel.left
anchors.bottom: _panel.bottom
visible: QGroundControl.videoManager.hasVideo && (!_mainIsMap || _isPipVisible)
onParentChanged: {
/* If video comes back from popup
* correct anchors.
* Such thing is not possible with ParentChange.
*/
if(parent == _panel) {
// Do anchors again after popup
anchors.left = _panel.left
anchors.bottom = _panel.bottom
anchors.margins = ScreenTools.defaultFontPixelHeight
}
}
states: [
State {
name: "pipMode"
@ -296,37 +326,42 @@ QGCView { @@ -296,37 +326,42 @@ QGCView {
State {
name: "popup"
StateChangeScript {
script: QGroundControl.videoManager.stopVideo()
script: {
// Stop video, restart it again with Timer
// Avoiding crashs if ParentChange is not yet done
QGroundControl.videoManager.stopVideo()
videoPopUpTimer.running = true
}
}
PropertyChanges {
target: _flightVideoPipControl
inPopup: true
}
},
State {
name: "popup-finished"
ParentChange {
target: _flightVideo
parent: videoItem
x: 0
y: 0
width: videoWindow.width
height: videoWindow.height
}
PropertyChanges {
target: _flightVideoPipControl
inPopup: true
width: videoItem.width
height: videoItem.height
}
},
State {
name: "unpopup"
StateChangeScript {
script: QGroundControl.videoManager.stopVideo()
script: {
QGroundControl.videoManager.stopVideo()
videoPopUpTimer.running = true
}
}
ParentChange {
target: _flightVideo
parent: _panel
}
PropertyChanges {
target: _flightVideo
anchors.left: _panel.left
anchors.bottom: _panel.bottom
anchors.margins: ScreenTools.defaultFontPixelHeight
}
PropertyChanges {
target: _flightVideoPipControl
inPopup: false
}

2
src/FlightDisplay/VideoManager.h

@ -56,7 +56,7 @@ public: @@ -56,7 +56,7 @@ public:
// Override from QGCTool
void setToolbox (QGCToolbox *toolbox);
Q_INVOKABLE void startVideo() {_videoReceiver->stop();};
Q_INVOKABLE void startVideo() {_videoReceiver->start();};
Q_INVOKABLE void stopVideo() {_videoReceiver->stop();};
signals:

6
src/VideoStreaming/VideoReceiver.cc

@ -218,6 +218,7 @@ VideoReceiver::start() @@ -218,6 +218,7 @@ VideoReceiver::start()
return;
}
#if defined(QGC_GST_STREAMING)
_stop = false;
qCDebug(VideoReceiverLog) << "start()";
if (_uri.isEmpty()) {
@ -433,6 +434,7 @@ void @@ -433,6 +434,7 @@ void
VideoReceiver::stop()
{
#if defined(QGC_GST_STREAMING)
_stop = true;
qCDebug(VideoReceiverLog) << "stop()";
if(!_streaming) {
_shutdownPipeline();
@ -870,9 +872,11 @@ VideoReceiver::_updateTimer() @@ -870,9 +872,11 @@ VideoReceiver::_updateTimer()
}
if(elapsed > (time_t)timeout && _videoSurface) {
stop();
// We want to start it back again with _updateTimer
_stop = false;
}
} else {
if(!running() && !_uri.isEmpty() && _videoSettings->streamEnabled()->rawValue().toBool()) {
if(!_stop && !running() && !_uri.isEmpty() && _videoSettings->streamEnabled()->rawValue().toBool()) {
start();
}
}

1
src/VideoStreaming/VideoReceiver.h

@ -114,6 +114,7 @@ private: @@ -114,6 +114,7 @@ private:
bool _streaming;
bool _starting;
bool _stopping;
bool _stop;
Sink* _sink;
GstElement* _tee;

8
src/VideoStreaming/gstqtvideosink/painters/videonode.cpp

@ -52,14 +52,18 @@ void VideoNode::setMaterialTypeSolidBlack() @@ -52,14 +52,18 @@ void VideoNode::setMaterialTypeSolidBlack()
void VideoNode::setCurrentFrame(GstBuffer* buffer)
{
Q_ASSERT (m_materialType == MaterialTypeVideo);
if (m_materialType != MaterialTypeVideo) {
return;
}
static_cast<VideoMaterial*>(material())->setCurrentFrame(buffer);
markDirty(DirtyMaterial);
}
void VideoNode::updateColors(int brightness, int contrast, int hue, int saturation)
{
Q_ASSERT (m_materialType == MaterialTypeVideo);
if (m_materialType != MaterialTypeVideo) {
return;
}
static_cast<VideoMaterial*>(material())->updateColors(brightness, contrast, hue, saturation);
markDirty(DirtyMaterial);
}

Loading…
Cancel
Save