/* * Copyright (c) 2017 The WebRTC project authors. All Rights Reserved. * * Use of this source code is governed by a BSD-style license * that can be found in the LICENSE file in the root of the source * tree. An additional intellectual property rights grant can be found * in the file PATENTS. All contributing project authors may * be found in the AUTHORS file in the root of the source tree. */ #ifndef API_VIDEO_CODECS_VIDEO_ENCODER_FACTORY_H_ #define API_VIDEO_CODECS_VIDEO_ENCODER_FACTORY_H_ #include #include #include "absl/types/optional.h" #include "api/units/data_rate.h" #include "api/video_codecs/sdp_video_format.h" namespace webrtc { class VideoEncoder; // A factory that creates VideoEncoders. // NOTE: This class is still under development and may change without notice. class VideoEncoderFactory { public: // TODO(magjed): Try to get rid of this struct. struct CodecInfo { // |has_internal_source| is true if encoders created by this factory of the // given codec will use internal camera sources, meaning that they don't // require/expect frames to be delivered via webrtc::VideoEncoder::Encode. // This flag is used as the internal_source parameter to // webrtc::ViEExternalCodec::RegisterExternalSendCodec. bool has_internal_source = false; }; // An injectable class that is continuously updated with encoding conditions // and selects the best encoder given those conditions. class EncoderSelectorInterface { public: virtual ~EncoderSelectorInterface() {} // Informs the encoder selector about which encoder that is currently being // used. virtual void OnCurrentEncoder(const SdpVideoFormat& format) = 0; // Called every time the available bitrate is updated. Should return a // non-empty if an encoder switch should be performed. virtual absl::optional OnAvailableBitrate( const DataRate& rate) = 0; // Called if the currently used encoder reports itself as broken. Should // return a non-empty if an encoder switch should be performed. virtual absl::optional OnEncoderBroken() = 0; }; // Returns a list of supported video formats in order of preference, to use // for signaling etc. virtual std::vector GetSupportedFormats() const = 0; // Returns a list of supported video formats in order of preference, that can // also be tagged with additional information to allow the VideoEncoderFactory // to separate between different implementations when CreateVideoEncoder is // called. virtual std::vector GetImplementations() const { return GetSupportedFormats(); } // Returns information about how this format will be encoded. The specified // format must be one of the supported formats by this factory. // TODO(magjed): Try to get rid of this method. Since is_hardware_accelerated // is unused, only factories producing internal source encoders (in itself a // deprecated feature) needs to override this method. virtual CodecInfo QueryVideoEncoder(const SdpVideoFormat& format) const { return CodecInfo(); } // Creates a VideoEncoder for the specified format. virtual std::unique_ptr CreateVideoEncoder( const SdpVideoFormat& format) = 0; virtual std::unique_ptr GetEncoderSelector() const { return nullptr; } virtual ~VideoEncoderFactory() {} }; } // namespace webrtc #endif // API_VIDEO_CODECS_VIDEO_ENCODER_FACTORY_H_