/* * Copyright (c) 2016 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. */ #include "media/engine/internal_encoder_factory.h" #include #include "absl/strings/match.h" #include "api/video_codecs/sdp_video_format.h" #include "media/base/codec.h" #include "media/base/media_constants.h" #include "modules/video_coding/codecs/av1/av1_svc_config.h" #include "modules/video_coding/codecs/av1/libaom_av1_encoder_supported.h" #include "modules/video_coding/codecs/h264/include/h264.h" #include "modules/video_coding/codecs/vp8/include/vp8.h" #include "modules/video_coding/codecs/vp8/vp8_scalability.h" #include "modules/video_coding/codecs/vp9/include/vp9.h" #include "modules/video_coding/svc/scalability_mode_util.h" #include "rtc_base/logging.h" namespace webrtc { std::vector InternalEncoderFactory::SupportedFormats() { std::vector supported_codecs; supported_codecs.push_back(SdpVideoFormat(cricket::kVp8CodecName)); for (const webrtc::SdpVideoFormat& format : webrtc::SupportedVP9Codecs()) supported_codecs.push_back(format); for (const webrtc::SdpVideoFormat& format : webrtc::SupportedH264Codecs()) supported_codecs.push_back(format); if (kIsLibaomAv1EncoderSupported) supported_codecs.push_back(SdpVideoFormat(cricket::kAv1CodecName)); return supported_codecs; } std::vector InternalEncoderFactory::GetSupportedFormats() const { return SupportedFormats(); } std::unique_ptr InternalEncoderFactory::CreateVideoEncoder( const SdpVideoFormat& format) { if (absl::EqualsIgnoreCase(format.name, cricket::kVp8CodecName)) return VP8Encoder::Create(); if (absl::EqualsIgnoreCase(format.name, cricket::kVp9CodecName)) return VP9Encoder::Create(cricket::VideoCodec(format)); if (absl::EqualsIgnoreCase(format.name, cricket::kH264CodecName)) return H264Encoder::Create(cricket::VideoCodec(format)); if (kIsLibaomAv1EncoderSupported && absl::EqualsIgnoreCase(format.name, cricket::kAv1CodecName)) return CreateLibaomAv1EncoderIfSupported(); RTC_LOG(LS_ERROR) << "Trying to created encoder of unsupported format " << format.name; return nullptr; } VideoEncoderFactory::CodecSupport InternalEncoderFactory::QueryCodecSupport( const SdpVideoFormat& format, absl::optional scalability_mode_string) const { // Query for supported formats and check if the specified format is supported. // Begin with filtering out unsupported scalability modes. if (scalability_mode_string) { static constexpr VideoEncoderFactory::CodecSupport kUnsupported = { .is_supported = false, .is_power_efficient = false}; absl::optional scalability_mode = ScalabilityModeFromString(*scalability_mode_string); if (!scalability_mode.has_value()) { return kUnsupported; } if (absl::EqualsIgnoreCase(format.name, cricket::kVp8CodecName)) { if (!VP8SupportsScalabilityMode(*scalability_mode)) { return kUnsupported; } } else if (absl::EqualsIgnoreCase(format.name, cricket::kVp9CodecName)) { if (!VP9Encoder::SupportsScalabilityMode(*scalability_mode)) { return kUnsupported; } } else if (absl::EqualsIgnoreCase(format.name, cricket::kH264CodecName)) { if (!H264Encoder::SupportsScalabilityMode(*scalability_mode)) { return kUnsupported; } } else if (kIsLibaomAv1EncoderSupported && absl::EqualsIgnoreCase(format.name, cricket::kAv1CodecName)) { if (!LibaomAv1EncoderSupportsScalabilityMode(*scalability_mode)) { return kUnsupported; } } else { return kUnsupported; } } return {.is_supported = format.IsCodecInList(GetSupportedFormats())}; } } // namespace webrtc