X-Git-Url: https://git.sesse.net/?a=blobdiff_plain;f=jpeg_frame_view.h;h=bc36283774e987c69dd14692210722ac4d10bca8;hb=bdef311c334b674ba39a931805fb7d32ce8698da;hp=b8e26c4a3a98f35170d73e8445098e11488d7d01;hpb=3035f82f46c322a9ba8f091b162ee36985688de9;p=nageru diff --git a/jpeg_frame_view.h b/jpeg_frame_view.h index b8e26c4..bc36283 100644 --- a/jpeg_frame_view.h +++ b/jpeg_frame_view.h @@ -1,48 +1,27 @@ #ifndef _JPEG_FRAME_VIEW_H #define _JPEG_FRAME_VIEW_H 1 -#include -#include - -#include +#include "frame_on_disk.h" +#include "jpeg_frame.h" +#include "ycbcr_converter.h" +#include +#include +#include #include #include #include #include - -#include +#include #include -#include "jpeg_frame.h" -#include "ycbcr_converter.h" - -struct JPEGID { - unsigned stream_idx; - int64_t pts; - bool interpolated; -}; enum CacheMissBehavior { DECODE_IF_NOT_IN_CACHE, RETURN_NULLPTR_IF_NOT_IN_CACHE }; -// This is, well, a hack. We hope for no collisions. -inline JPEGID create_jpegid_for_interpolated_fade(unsigned stream_idx, int64_t pts, unsigned secondary_stream_idx, int64_t secondary_pts) -{ - JPEGID id; - id.stream_idx = (stream_idx << 8) | secondary_stream_idx; - - uint64_t rot = secondary_stream_idx; - rot = (rot << 32) | (rot >> 32); - id.pts = pts ^ int64_t(rot); - id.interpolated = true; - return id; -} - -std::string filename_for_frame(unsigned stream_idx, int64_t pts); 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); +std::shared_ptr decode_jpeg_with_cache(FrameOnDisk id, CacheMissBehavior cache_miss_behavior, bool *did_decode); class JPEGFrameView : public QGLWidget { Q_OBJECT @@ -50,8 +29,8 @@ class JPEGFrameView : public QGLWidget { public: JPEGFrameView(QWidget *parent); - void setFrame(unsigned stream_idx, int64_t pts, bool interpolated, int secondary_stream_idx = -1, int64_t secondary_pts = -1, float fade_alpha = 0.0f); - static void insert_interpolated_frame(JPEGID id, std::shared_ptr frame); + void setFrame(unsigned stream_idx, FrameOnDisk frame, FrameOnDisk secondary_frame = {}, float fade_alpha = 0.0f); + void setFrame(std::shared_ptr frame); void mousePressEvent(QMouseEvent *event) override;