/* * Copyright 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. */ #import "TGRTCDefaultVideoEncoderFactory.h" #import "RTCH264ProfileLevelId.h" #import "TGRTCVideoEncoderH264.h" #import "api/video_codec/RTCVideoCodecConstants.h" #import "api/video_codec/RTCVideoEncoderVP8.h" #import "base/RTCVideoCodecInfo.h" #if defined(RTC_ENABLE_VP9) #import "api/video_codec/RTCVideoEncoderVP9.h" #endif #if !defined(DISABLE_H265) #import "RTCH265ProfileLevelId.h" #import "TGRTCVideoEncoderH265.h" #endif @implementation TGRTCDefaultVideoEncoderFactory @synthesize preferredCodec; + (NSArray *)supportedCodecs { NSDictionary *constrainedHighParams = @{ @"profile-level-id" : kRTCMaxSupportedH264ProfileLevelConstrainedHigh, @"level-asymmetry-allowed" : @"1", @"packetization-mode" : @"1", }; RTCVideoCodecInfo *constrainedHighInfo = [[RTCVideoCodecInfo alloc] initWithName:kRTCVideoCodecH264Name parameters:constrainedHighParams]; NSDictionary *constrainedBaselineParams = @{ @"profile-level-id" : kRTCMaxSupportedH264ProfileLevelConstrainedBaseline, @"level-asymmetry-allowed" : @"1", @"packetization-mode" : @"1", }; RTCVideoCodecInfo *constrainedBaselineInfo = [[RTCVideoCodecInfo alloc] initWithName:kRTCVideoCodecH264Name parameters:constrainedBaselineParams]; RTCVideoCodecInfo *vp8Info = [[RTCVideoCodecInfo alloc] initWithName:kRTCVideoCodecVp8Name]; #if defined(RTC_ENABLE_VP9) RTCVideoCodecInfo *vp9Info = [[RTCVideoCodecInfo alloc] initWithName:kRTCVideoCodecVp9Name]; #endif #if !defined(DISABLE_H265) RTCVideoCodecInfo *h265Info = [[RTCVideoCodecInfo alloc] initWithName:kRTCVideoCodecH265Name]; #endif NSMutableArray *result = [[NSMutableArray alloc] initWithArray:@[ constrainedHighInfo, constrainedBaselineInfo, vp8Info, #if defined(RTC_ENABLE_VP9) vp9Info, #endif ]]; #if !defined(DISABLE_H265) #ifdef WEBRTC_IOS if (@available(iOS 11.0, *)) { if ([[AVAssetExportSession allExportPresets] containsObject:AVAssetExportPresetHEVCHighestQuality]) { [result addObject:h265Info]; } } #else // WEBRTC_IOS if (@available(macOS 10.13, *)) { if ([[AVAssetExportSession allExportPresets] containsObject:AVAssetExportPresetHEVCHighestQuality]) { [result addObject:h265Info]; } } #endif // WEBRTC_IOS #endif return result; } - (id)createEncoder:(RTCVideoCodecInfo *)info { if ([info.name isEqualToString:kRTCVideoCodecH264Name]) { return [[TGRTCVideoEncoderH264 alloc] initWithCodecInfo:info]; } else if ([info.name isEqualToString:kRTCVideoCodecVp8Name]) { return [RTCVideoEncoderVP8 vp8Encoder]; } #if defined(RTC_ENABLE_VP9) if ([info.name isEqualToString:kRTCVideoCodecVp9Name]) { return [RTCVideoEncoderVP9 vp9Encoder]; } #endif #if !defined(DISABLE_H265) #ifdef WEBRTC_IOS if (@available(iOS 11, *)) { if ([info.name isEqualToString:kRTCVideoCodecH265Name]) { return [[TGRTCVideoEncoderH265 alloc] initWithCodecInfo:info]; } } #else // WEBRTC_IOS if (@available(macOS 10.13, *)) { if ([info.name isEqualToString:kRTCVideoCodecH265Name]) { return [[TGRTCVideoEncoderH265 alloc] initWithCodecInfo:info]; } } #endif // WEBRTC_IOS #endif // !DISABLE_H265 return nil; } - (NSArray *)supportedCodecs { NSMutableArray *codecs = [[[self class] supportedCodecs] mutableCopy]; NSMutableArray *orderedCodecs = [NSMutableArray array]; NSUInteger index = [codecs indexOfObject:self.preferredCodec]; if (index != NSNotFound) { [orderedCodecs addObject:[codecs objectAtIndex:index]]; [codecs removeObjectAtIndex:index]; } [orderedCodecs addObjectsFromArray:codecs]; return [orderedCodecs copy]; } @end