vrplayer fixes
This commit is contained in:
parent
88be8505a9
commit
6daec38c65
@ -312,6 +312,8 @@ void MainWindow::onMediaDurationInSeconds(int duration)
|
|||||||
int secs = 0;
|
int secs = 0;
|
||||||
char buf[20];
|
char buf[20];
|
||||||
|
|
||||||
|
//return;
|
||||||
|
|
||||||
/* setup progress bar */
|
/* setup progress bar */
|
||||||
slider->setMinimum(0);
|
slider->setMinimum(0);
|
||||||
slider->setMaximum(duration * 100); /* in hundredth of a sec */
|
slider->setMaximum(duration * 100); /* in hundredth of a sec */
|
||||||
|
@ -2,4 +2,7 @@
|
|||||||
|
|
||||||
MediaPacket::MediaPacket()
|
MediaPacket::MediaPacket()
|
||||||
{
|
{
|
||||||
|
av_pkt = 0;
|
||||||
|
delay_in_us = 0;
|
||||||
|
seq = 0;
|
||||||
}
|
}
|
||||||
|
@ -62,8 +62,8 @@ label1:
|
|||||||
sendMutex->lock();
|
sendMutex->lock();
|
||||||
send_audio_pkt(channel, stream_id, pkt->av_pkt);
|
send_audio_pkt(channel, stream_id, pkt->av_pkt);
|
||||||
sendMutex->unlock();
|
sendMutex->unlock();
|
||||||
delete pkt;
|
|
||||||
usleep(pkt->delay_in_us);
|
usleep(pkt->delay_in_us);
|
||||||
|
delete pkt;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -22,76 +22,81 @@ PlayVideo::PlayVideo(QObject *parent,
|
|||||||
void PlayVideo::play()
|
void PlayVideo::play()
|
||||||
{
|
{
|
||||||
MediaPacket *pkt;
|
MediaPacket *pkt;
|
||||||
|
int usl;
|
||||||
|
|
||||||
while (1)
|
while (1)
|
||||||
{
|
{
|
||||||
vcrMutex.lock();
|
vcrMutex.lock();
|
||||||
switch (vcrFlag)
|
switch (vcrFlag)
|
||||||
{
|
{
|
||||||
case VCR_PLAY:
|
case VCR_PLAY:
|
||||||
vcrFlag = 0;
|
vcrFlag = 0;
|
||||||
vcrMutex.unlock();
|
vcrMutex.unlock();
|
||||||
if (pausedTime)
|
if (pausedTime)
|
||||||
{
|
{
|
||||||
elapsedTime = av_gettime() - pausedTime;
|
elapsedTime = av_gettime() - pausedTime;
|
||||||
pausedTime = 0;
|
pausedTime = 0;
|
||||||
}
|
}
|
||||||
isStopped = false;
|
isStopped = false;
|
||||||
continue;
|
|
||||||
break;
|
|
||||||
|
|
||||||
case VCR_PAUSE:
|
|
||||||
vcrMutex.unlock();
|
|
||||||
if (!pausedTime)
|
|
||||||
{
|
|
||||||
/* save amount of video played so far */
|
|
||||||
pausedTime = av_gettime() - elapsedTime;
|
|
||||||
}
|
|
||||||
usleep(1000 * 100);
|
|
||||||
isStopped = false;
|
|
||||||
continue;
|
|
||||||
break;
|
|
||||||
|
|
||||||
case VCR_STOP:
|
|
||||||
vcrMutex.unlock();
|
|
||||||
if (isStopped)
|
|
||||||
{
|
|
||||||
usleep(1000 * 100);
|
|
||||||
continue;
|
continue;
|
||||||
}
|
break;
|
||||||
clearVideoQ();
|
|
||||||
elapsedTime = 0;
|
|
||||||
pausedTime = 0;
|
|
||||||
la_seekPos = -1;
|
|
||||||
xrdpvr_seek_media(0, 0);
|
|
||||||
isStopped = true;
|
|
||||||
continue;
|
|
||||||
break;
|
|
||||||
|
|
||||||
default:
|
case VCR_PAUSE:
|
||||||
vcrMutex.unlock();
|
vcrMutex.unlock();
|
||||||
goto label1;
|
if (!pausedTime)
|
||||||
break;
|
{
|
||||||
|
/* save amount of video played so far */
|
||||||
|
pausedTime = av_gettime() - elapsedTime;
|
||||||
|
}
|
||||||
|
usleep(1000 * 100);
|
||||||
|
isStopped = false;
|
||||||
|
continue;
|
||||||
|
break;
|
||||||
|
|
||||||
|
case VCR_STOP:
|
||||||
|
vcrMutex.unlock();
|
||||||
|
if (isStopped)
|
||||||
|
{
|
||||||
|
usleep(1000 * 100);
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
clearVideoQ();
|
||||||
|
elapsedTime = 0;
|
||||||
|
pausedTime = 0;
|
||||||
|
la_seekPos = -1;
|
||||||
|
xrdpvr_seek_media(0, 0);
|
||||||
|
isStopped = true;
|
||||||
|
continue;
|
||||||
|
break;
|
||||||
|
|
||||||
|
default:
|
||||||
|
vcrMutex.unlock();
|
||||||
|
goto label1;
|
||||||
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
label1:
|
label1:
|
||||||
|
|
||||||
if (videoQueue->isEmpty())
|
if (videoQueue->isEmpty())
|
||||||
{
|
{
|
||||||
qDebug() << "PlayVideo::play: GOT EMPTY";
|
|
||||||
usleep(1000 * 100);
|
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
pkt = videoQueue->dequeue();
|
pkt = videoQueue->dequeue();
|
||||||
sendMutex->lock();
|
sendMutex->lock();
|
||||||
send_video_pkt(channel, stream_id, pkt->av_pkt);
|
send_video_pkt(channel, stream_id, pkt->av_pkt);
|
||||||
sendMutex->unlock();
|
sendMutex->unlock();
|
||||||
|
usl = pkt->delay_in_us;
|
||||||
|
if (usl < 0)
|
||||||
|
{
|
||||||
|
usl = 0;
|
||||||
|
}
|
||||||
|
if (usl > 100 * 1000)
|
||||||
|
{
|
||||||
|
usl = 100 * 1000;
|
||||||
|
}
|
||||||
|
usleep(usl);
|
||||||
delete pkt;
|
delete pkt;
|
||||||
usleep(pkt->delay_in_us);
|
|
||||||
|
|
||||||
updateMediaPos();
|
updateMediaPos();
|
||||||
|
|
||||||
if (elapsedTime == 0)
|
if (elapsedTime == 0)
|
||||||
elapsedTime = av_gettime();
|
elapsedTime = av_gettime();
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user