X-Git-Url: https://git.sesse.net/?a=blobdiff_plain;f=jpeg_frame_view.h;h=591ff13e96daa0a38770ec9dfea9be5bd5b8dc88;hb=393a2a974ea26d9eac26b52aabc12f48b0dbfeb2;hp=2f31c1b1d88206150935b2d02a147be61ed98f68;hpb=530f3b3aa10aafaf22da10e53d3d243df26bf174;p=nageru diff --git a/jpeg_frame_view.h b/jpeg_frame_view.h index 2f31c1b..591ff13 100644 --- a/jpeg_frame_view.h +++ b/jpeg_frame_view.h @@ -14,6 +14,7 @@ struct JPEGID { unsigned stream_idx; int64_t pts; + bool interpolated; }; struct Frame { std::unique_ptr y, cb, cr; @@ -36,19 +37,16 @@ class JPEGFrameView : public QGLWidget { public: JPEGFrameView(QWidget *parent); - void setFrame(unsigned stream_idx, int64_t pts) - { - this->stream_idx = stream_idx; - this->pts = pts; - update_frame(); - } + void setFrame(unsigned stream_idx, int64_t pts, bool interpolated); + static void insert_interpolated_frame(unsigned stream_idx, int64_t pts, std::shared_ptr frame); void mousePressEvent(QMouseEvent *event) override; - unsigned get_stream_idx() const { return stream_idx; } + unsigned get_stream_idx() const { return current_stream_idx; } void setDecodedFrame(std::shared_ptr frame); + signals: void clicked(); @@ -58,10 +56,8 @@ protected: void paintGL() override; private: - void update_frame(); - - unsigned stream_idx; - int64_t pts; + // The stream index of the latest frame we displayed. + unsigned current_stream_idx; std::unique_ptr chain; std::shared_ptr current_frame; // So that we hold on to the pixels.