VideoStreamEncoder: Introduce frame cadence adapter.
This change introduces a new FrameCadenceAdapter class which takes the role of being a VideoFrameSinkInterface<> instead of VideoStreamEncoder. The FrameCadenceAdapter will see its functionality grow in future CLs and eventually enable screenshare capture sources to have zero hertz as the minimum capture frequency. This CL moves logic related to UMA collection and constraints into the adapter. The adapter has two major modes. Future functionality is planned to be added under the WebRTC-ZeroHertzScreenshare field trial. Unit tests are added that verify passthrough operation when WebRTC-ZeroHertzScreenshare isn't specified or disabled. Just specifying the WebRTC-ZeroHertzScreenshare field trial isn't enough to activate the feature, but the caller has to additionally configure screen content type, minimum FPS 0, and maximum FPS > 0 for the new mode. go/rtc-0hz-present Bug: chromium:1255737 Change-Id: I1799110ed40843152786ad80df10acfb83a608b1 Reviewed-on: https://webrtc-review.googlesource.com/c/src/+/236682 Commit-Queue: Markus Handell <handellm@webrtc.org> Reviewed-by: Henrik Boström <hbos@webrtc.org> Reviewed-by: Ilya Nikolaevskiy <ilnik@webrtc.org> Reviewed-by: Stefan Holmer <stefan@webrtc.org> Reviewed-by: Niels Moller <nisse@webrtc.org> Cr-Commit-Position: refs/heads/main@{#35315}
This commit is contained in:
committed by
WebRTC LUCI CQ
parent
0b5656312b
commit
b4e96d48a2
@ -39,7 +39,7 @@ namespace webrtc {
|
||||
//
|
||||
// 2. Moving responsibility for simulcast and for software fallback into this
|
||||
// class.
|
||||
class VideoStreamEncoderInterface : public rtc::VideoSinkInterface<VideoFrame> {
|
||||
class VideoStreamEncoderInterface {
|
||||
public:
|
||||
// Interface for receiving encoded video frames and notifications about
|
||||
// configuration changes.
|
||||
@ -58,6 +58,8 @@ class VideoStreamEncoderInterface : public rtc::VideoSinkInterface<VideoFrame> {
|
||||
VideoLayersAllocation allocation) = 0;
|
||||
};
|
||||
|
||||
virtual ~VideoStreamEncoderInterface() = default;
|
||||
|
||||
// If the resource is overusing, the VideoStreamEncoder will try to reduce
|
||||
// resolution or frame rate until no resource is overusing.
|
||||
// TODO(https://crbug.com/webrtc/11565): When the ResourceAdaptationProcessor
|
||||
|
||||
Reference in New Issue
Block a user