mirror of
https://github.com/moonlight-stream/moonlight-qt
synced 2024-12-13 04:42:27 +00:00
Always submit frames to Pacer if it's using a frame queue
This commit is contained in:
parent
404eaa44e4
commit
345e800abd
3 changed files with 18 additions and 5 deletions
|
@ -137,7 +137,7 @@ void Pacer::submitFrame(AVFrame* frame)
|
||||||
// Queue the frame until the V-sync callback if
|
// Queue the frame until the V-sync callback if
|
||||||
// we have a V-sync source, otherwise deliver it
|
// we have a V-sync source, otherwise deliver it
|
||||||
// immediately and hope for the best.
|
// immediately and hope for the best.
|
||||||
if (m_VsyncSource != nullptr) {
|
if (isUsingFrameQueue()) {
|
||||||
SDL_AtomicLock(&m_FrameQueueLock);
|
SDL_AtomicLock(&m_FrameQueueLock);
|
||||||
m_FrameQueue.enqueue(frame);
|
m_FrameQueue.enqueue(frame);
|
||||||
SDL_AtomicUnlock(&m_FrameQueueLock);
|
SDL_AtomicUnlock(&m_FrameQueueLock);
|
||||||
|
@ -147,3 +147,8 @@ void Pacer::submitFrame(AVFrame* frame)
|
||||||
av_frame_free(&frame);
|
av_frame_free(&frame);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
bool Pacer::isUsingFrameQueue()
|
||||||
|
{
|
||||||
|
return m_VsyncSource != nullptr;
|
||||||
|
}
|
||||||
|
|
|
@ -23,6 +23,8 @@ public:
|
||||||
|
|
||||||
void vsyncCallback();
|
void vsyncCallback();
|
||||||
|
|
||||||
|
bool isUsingFrameQueue();
|
||||||
|
|
||||||
private:
|
private:
|
||||||
QQueue<AVFrame*> m_FrameQueue;
|
QQueue<AVFrame*> m_FrameQueue;
|
||||||
QQueue<int> m_FrameQueueHistory;
|
QQueue<int> m_FrameQueueHistory;
|
||||||
|
|
|
@ -399,9 +399,15 @@ void FFmpegVideoDecoder::renderFrame(SDL_UserEvent* event)
|
||||||
void FFmpegVideoDecoder::dropFrame(SDL_UserEvent* event)
|
void FFmpegVideoDecoder::dropFrame(SDL_UserEvent* event)
|
||||||
{
|
{
|
||||||
AVFrame* frame = reinterpret_cast<AVFrame*>(event->data1);
|
AVFrame* frame = reinterpret_cast<AVFrame*>(event->data1);
|
||||||
// We should really call Pacer::submitFrame() here and let it
|
// If Pacer is using a frame queue, we can just queue the
|
||||||
// take care of it, but that will regress frame dropping for
|
// frame and let it decide whether to drop or not. If Pacer
|
||||||
// clients without an IVsyncSource implementation.
|
// is submitting directly for rendering, we drop the frame
|
||||||
av_frame_free(&frame);
|
// ourselves.
|
||||||
|
if (m_Pacer->isUsingFrameQueue()) {
|
||||||
|
m_Pacer->submitFrame(frame);
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
av_frame_free(&frame);
|
||||||
|
}
|
||||||
SDL_AtomicDecRef(&m_QueuedFrames);
|
SDL_AtomicDecRef(&m_QueuedFrames);
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue