X-Git-Url: https://git.sesse.net/?a=blobdiff_plain;ds=sidebyside;f=quicksync_encoder.h;h=9e1e9f944fabecb9c6c4173ae954dfd2360c570c;hb=refs%2Fheads%2Fmultichannel_audio;hp=25b19725dee6841faf83c453af49fab38a279ca3;hpb=ab03e5e6f24b1651b4ca7df95e20aa5786939209;p=nageru diff --git a/quicksync_encoder.h b/quicksync_encoder.h index 25b1972..9e1e9f9 100644 --- a/quicksync_encoder.h +++ b/quicksync_encoder.h @@ -27,8 +27,8 @@ #define _H264ENCODE_H #include +#include #include -#include #include #include #include @@ -37,13 +37,13 @@ extern "C" { #include } -#include "ref_counted_frame.h" #include "ref_counted_gl_sync.h" -class AudioEncoder; +class DiskSpaceEstimator; class Mux; -class QuickSyncEncoderImpl; class QSurface; +class QuickSyncEncoderImpl; +class RefCountedFrame; class X264Encoder; namespace movit { @@ -55,7 +55,7 @@ class ResourcePool; // .cpp file. class QuickSyncEncoder { public: - QuickSyncEncoder(const std::string &filename, movit::ResourcePool *resource_pool, QSurface *surface, const std::string &va_display, int width, int height, AVOutputFormat *oformat, AudioEncoder *stream_audio_encoder, X264Encoder *x264_encoder); + QuickSyncEncoder(const std::string &filename, movit::ResourcePool *resource_pool, QSurface *surface, const std::string &va_display, int width, int height, AVOutputFormat *oformat, X264Encoder *x264_encoder, DiskSpaceEstimator *disk_space_estimator); ~QuickSyncEncoder(); void set_stream_mux(Mux *mux); // Does not take ownership. Must be called unless x264 is used for the stream. @@ -64,6 +64,7 @@ public: RefCountedGLsync end_frame(int64_t pts, int64_t duration, const std::vector &input_frames); void shutdown(); // Blocking. Does not require an OpenGL context. void release_gl_resources(); // Requires an OpenGL context. Must be run after shutdown. + int64_t global_delay() const; // So we never get negative dts. private: std::unique_ptr impl;