X-Git-Url: https://git.sesse.net/?a=blobdiff_plain;f=jpeg_frame_view.h;h=65a6608991ce8337616afdaf3d7f6f12a64d9362;hb=c786b9e247c7169e7a8097b37259dfa6ecd5a953;hp=277241b69d70c77c5375a10dfec8b1fdfcb84f8b;hpb=1f40445577316ae2f2df53c09147fe254cbe9772;p=nageru diff --git a/jpeg_frame_view.h b/jpeg_frame_view.h index 277241b..65a6608 100644 --- a/jpeg_frame_view.h +++ b/jpeg_frame_view.h @@ -1,24 +1,31 @@ #ifndef _JPEG_FRAME_VIEW_H #define _JPEG_FRAME_VIEW_H 1 -#include -#include - -#include +#include "jpeg_frame.h" +#include "ycbcr_converter.h" +#include +#include +#include #include +#include +#include #include +#include +#include -#include +struct JPEGID { + unsigned stream_idx; + int64_t pts; +}; +enum CacheMissBehavior { + DECODE_IF_NOT_IN_CACHE, + RETURN_NULLPTR_IF_NOT_IN_CACHE +}; std::string filename_for_frame(unsigned stream_idx, int64_t pts); - -struct Frame { - std::unique_ptr y, cb, cr; - unsigned width, height; - unsigned chroma_subsampling_x, chroma_subsampling_y; - unsigned pitch_y, pitch_chroma; -}; +std::shared_ptr decode_jpeg(const std::string &filename); +std::shared_ptr decode_jpeg_with_cache(JPEGID id, CacheMissBehavior cache_miss_behavior, bool *did_decode); class JPEGFrameView : public QGLWidget { Q_OBJECT @@ -26,16 +33,20 @@ 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, int secondary_stream_idx = -1, int64_t secondary_pts = -1, float fade_alpha = 0.0f); + void setFrame(std::shared_ptr frame); + + void mousePressEvent(QMouseEvent *event) override; + + unsigned get_stream_idx() const { return current_stream_idx; } + + void setDecodedFrame(std::shared_ptr frame, std::shared_ptr secondary_frame, float fade_alpha); + void set_overlay(const std::string &text); // Blank for none. - unsigned get_stream_idx() const { return stream_idx; } + static void shutdown(); - void setDecodedFrame(std::shared_ptr frame); +signals: + void clicked(); protected: void initializeGL() override; @@ -43,15 +54,25 @@ protected: void paintGL() override; private: - void update_frame(); + // The stream index of the latest frame we displayed. + unsigned current_stream_idx = 0; - unsigned stream_idx; - int64_t pts; + std::unique_ptr ycbcr_converter; + movit::EffectChain *current_chain = nullptr; // Owned by ycbcr_converter. - std::unique_ptr chain; std::shared_ptr current_frame; // So that we hold on to the pixels. - movit::YCbCrInput *ycbcr_input; - movit::YCbCrFormat ycbcr_format; + std::shared_ptr current_secondary_frame; // Same. + + static constexpr int overlay_base_width = 16, overlay_base_height = 16; + int overlay_width = overlay_base_width, overlay_height = overlay_base_height; + std::unique_ptr overlay_image; // If nullptr, no overlay. + std::unique_ptr overlay_chain; // Just to get the overlay on screen in the easiest way possible. + movit::FlatInput *overlay_input; + bool overlay_input_needs_refresh = false; + + int gl_width, gl_height; + + static std::thread jpeg_decoder_thread; }; #endif // !defined(_JPEG_FRAME_VIEW_H)