Work on flexible mode and screen sharing.
Implement VP8 style screensharing but with spatial layers. Implement flexible mode. Files from other patches: generic_encoder.cc layer_filtering_transport.cc BUG=webrtc:4914 Review URL: https://codereview.webrtc.org/1328113004 Cr-Commit-Position: refs/heads/master@{#10572}
This commit is contained in:
@ -21,6 +21,8 @@
|
||||
|
||||
namespace webrtc {
|
||||
|
||||
class ScreenshareLayersVP9;
|
||||
|
||||
class VP9EncoderImpl : public VP9Encoder {
|
||||
public:
|
||||
VP9EncoderImpl();
|
||||
@ -45,6 +47,20 @@ class VP9EncoderImpl : public VP9Encoder {
|
||||
|
||||
void OnDroppedFrame() override {}
|
||||
|
||||
struct LayerFrameRefSettings {
|
||||
int8_t upd_buf = -1; // -1 - no update, 0..7 - update buffer 0..7
|
||||
int8_t ref_buf1 = -1; // -1 - no reference, 0..7 - reference buffer 0..7
|
||||
int8_t ref_buf2 = -1; // -1 - no reference, 0..7 - reference buffer 0..7
|
||||
int8_t ref_buf3 = -1; // -1 - no reference, 0..7 - reference buffer 0..7
|
||||
};
|
||||
|
||||
struct SuperFrameRefSettings {
|
||||
LayerFrameRefSettings layer[kMaxVp9NumberOfSpatialLayers];
|
||||
uint8_t start_layer = 0; // The first spatial layer to be encoded.
|
||||
uint8_t stop_layer = 0; // The last spatial layer to be encoded.
|
||||
bool is_keyframe = false;
|
||||
};
|
||||
|
||||
private:
|
||||
// Determine number of encoder threads to use.
|
||||
int NumberOfThreads(int width, int height, int number_of_cores);
|
||||
@ -59,6 +75,15 @@ class VP9EncoderImpl : public VP9Encoder {
|
||||
bool ExplicitlyConfiguredSpatialLayers() const;
|
||||
bool SetSvcRates();
|
||||
|
||||
// Used for flexible mode to set the flags and buffer references used
|
||||
// by the encoder. Also calculates the references used by the RTP
|
||||
// packetizer.
|
||||
//
|
||||
// Has to be called for every frame (keyframes included) to update the
|
||||
// state used to calculate references.
|
||||
vpx_svc_ref_frame_config GenerateRefsAndFlags(
|
||||
const SuperFrameRefSettings& settings);
|
||||
|
||||
virtual int GetEncodedLayerFrame(const vpx_codec_cx_pkt* pkt);
|
||||
|
||||
// Callback function for outputting packets per spatial layer.
|
||||
@ -89,9 +114,17 @@ class VP9EncoderImpl : public VP9Encoder {
|
||||
GofInfoVP9 gof_; // Contains each frame's temporal information for
|
||||
// non-flexible mode.
|
||||
uint8_t tl0_pic_idx_; // Only used in non-flexible mode.
|
||||
size_t gof_idx_; // Only used in non-flexible mode.
|
||||
size_t frames_since_kf_;
|
||||
uint8_t num_temporal_layers_;
|
||||
uint8_t num_spatial_layers_;
|
||||
|
||||
// Used for flexible mode.
|
||||
bool is_flexible_mode_;
|
||||
int64_t buffer_updated_at_frame_[kNumVp9Buffers];
|
||||
int64_t frames_encoded_;
|
||||
uint8_t num_ref_pics_[kMaxVp9NumberOfSpatialLayers];
|
||||
uint8_t p_diff_[kMaxVp9NumberOfSpatialLayers][kMaxVp9RefPics];
|
||||
rtc::scoped_ptr<ScreenshareLayersVP9> spatial_layer_;
|
||||
};
|
||||
|
||||
|
||||
|
||||
Reference in New Issue
Block a user