Reland "Simple Default ObjC video codec factories."
This is a reland of 30915a742d86df55ac5c04501c0e8104675a612e Original change's description: > Simple Default ObjC video codec factories. > > Move the simple video encoder/decoder factory from AppRTCMobile into the > public API so users who don't have special requirements for video codecs > can easily get started. > > Also clean up the API a little. > > This CL replaces the more flexible default factories in > https://webrtc-review.googlesource.com/c/src/+/7741 and clients that > want to implement their own codecs will have to supply their own > encoder/decoder factories as well. The benefits of the approach in > this CL are a simpler API and less effects on the rest of the code. > > Bug: None > Change-Id: I4ed94090d778b4fc38b49864de1d4de4ff125d6a > Reviewed-on: https://webrtc-review.googlesource.com/15141 > Reviewed-by: Kári Helgason <kthelgason@webrtc.org> > Reviewed-by: Magnus Jedvert <magjed@webrtc.org> > Commit-Queue: Anders Carlsson <andersc@webrtc.org> > Cr-Commit-Position: refs/heads/master@{#20441} Bug: None Change-Id: If0910cc540dc835dfec4eeb5bea527d88482d110 Reviewed-on: https://webrtc-review.googlesource.com/16780 Reviewed-by: Magnus Jedvert <magjed@webrtc.org> Commit-Queue: Anders Carlsson <andersc@webrtc.org> Cr-Commit-Position: refs/heads/master@{#20476}
This commit is contained in:
committed by
Commit Bot
parent
1c9623c70d
commit
1d4c152a38
@ -230,10 +230,6 @@ if (is_ios || (is_mac && target_cpu != "x86")) {
|
|||||||
"objc/AppRTCMobile/ARDTURNClient+Internal.h",
|
"objc/AppRTCMobile/ARDTURNClient+Internal.h",
|
||||||
"objc/AppRTCMobile/ARDTURNClient.h",
|
"objc/AppRTCMobile/ARDTURNClient.h",
|
||||||
"objc/AppRTCMobile/ARDTURNClient.m",
|
"objc/AppRTCMobile/ARDTURNClient.m",
|
||||||
"objc/AppRTCMobile/ARDVideoDecoderFactory.h",
|
|
||||||
"objc/AppRTCMobile/ARDVideoDecoderFactory.m",
|
|
||||||
"objc/AppRTCMobile/ARDVideoEncoderFactory.h",
|
|
||||||
"objc/AppRTCMobile/ARDVideoEncoderFactory.m",
|
|
||||||
"objc/AppRTCMobile/ARDWebSocketChannel.h",
|
"objc/AppRTCMobile/ARDWebSocketChannel.h",
|
||||||
"objc/AppRTCMobile/ARDWebSocketChannel.m",
|
"objc/AppRTCMobile/ARDWebSocketChannel.m",
|
||||||
"objc/AppRTCMobile/RTCIceCandidate+JSON.h",
|
"objc/AppRTCMobile/RTCIceCandidate+JSON.h",
|
||||||
|
|||||||
@ -22,6 +22,7 @@
|
|||||||
#import "WebRTC/RTCPeerConnectionFactory.h"
|
#import "WebRTC/RTCPeerConnectionFactory.h"
|
||||||
#import "WebRTC/RTCRtpSender.h"
|
#import "WebRTC/RTCRtpSender.h"
|
||||||
#import "WebRTC/RTCTracing.h"
|
#import "WebRTC/RTCTracing.h"
|
||||||
|
#import "WebRTC/RTCVideoCodecFactory.h"
|
||||||
#import "WebRTC/RTCVideoTrack.h"
|
#import "WebRTC/RTCVideoTrack.h"
|
||||||
|
|
||||||
#import "ARDAppEngineClient.h"
|
#import "ARDAppEngineClient.h"
|
||||||
@ -31,8 +32,6 @@
|
|||||||
#import "ARDSignalingMessage.h"
|
#import "ARDSignalingMessage.h"
|
||||||
#import "ARDTURNClient+Internal.h"
|
#import "ARDTURNClient+Internal.h"
|
||||||
#import "ARDUtilities.h"
|
#import "ARDUtilities.h"
|
||||||
#import "ARDVideoDecoderFactory.h"
|
|
||||||
#import "ARDVideoEncoderFactory.h"
|
|
||||||
#import "ARDWebSocketChannel.h"
|
#import "ARDWebSocketChannel.h"
|
||||||
#import "RTCIceCandidate+JSON.h"
|
#import "RTCIceCandidate+JSON.h"
|
||||||
#import "RTCSessionDescription+JSON.h"
|
#import "RTCSessionDescription+JSON.h"
|
||||||
@ -218,8 +217,8 @@ static int const kKbpsMultiplier = 1000;
|
|||||||
_isLoopback = isLoopback;
|
_isLoopback = isLoopback;
|
||||||
self.state = kARDAppClientStateConnecting;
|
self.state = kARDAppClientStateConnecting;
|
||||||
|
|
||||||
ARDVideoDecoderFactory *decoderFactory = [[ARDVideoDecoderFactory alloc] init];
|
RTCDefaultVideoDecoderFactory *decoderFactory = [[RTCDefaultVideoDecoderFactory alloc] init];
|
||||||
ARDVideoEncoderFactory *encoderFactory = [[ARDVideoEncoderFactory alloc] init];
|
RTCDefaultVideoEncoderFactory *encoderFactory = [[RTCDefaultVideoEncoderFactory alloc] init];
|
||||||
encoderFactory.preferredCodec = [settings currentVideoCodecSettingFromStore];
|
encoderFactory.preferredCodec = [settings currentVideoCodecSettingFromStore];
|
||||||
_factory = [[RTCPeerConnectionFactory alloc] initWithEncoderFactory:encoderFactory
|
_factory = [[RTCPeerConnectionFactory alloc] initWithEncoderFactory:encoderFactory
|
||||||
decoderFactory:decoderFactory];
|
decoderFactory:decoderFactory];
|
||||||
|
|||||||
@ -10,9 +10,9 @@
|
|||||||
|
|
||||||
#import "ARDSettingsModel+Private.h"
|
#import "ARDSettingsModel+Private.h"
|
||||||
#import "ARDSettingsStore.h"
|
#import "ARDSettingsStore.h"
|
||||||
#import "ARDVideoEncoderFactory.h"
|
|
||||||
#import "WebRTC/RTCCameraVideoCapturer.h"
|
#import "WebRTC/RTCCameraVideoCapturer.h"
|
||||||
#import "WebRTC/RTCMediaConstraints.h"
|
#import "WebRTC/RTCMediaConstraints.h"
|
||||||
|
#import "WebRTC/RTCVideoCodecFactory.h"
|
||||||
|
|
||||||
NS_ASSUME_NONNULL_BEGIN
|
NS_ASSUME_NONNULL_BEGIN
|
||||||
|
|
||||||
@ -66,9 +66,7 @@ NS_ASSUME_NONNULL_BEGIN
|
|||||||
}
|
}
|
||||||
|
|
||||||
- (NSArray<RTCVideoCodecInfo *> *)availableVideoCodecs {
|
- (NSArray<RTCVideoCodecInfo *> *)availableVideoCodecs {
|
||||||
NSArray<RTCVideoCodecInfo *> *supportedCodecs =
|
return [RTCDefaultVideoEncoderFactory supportedCodecs];
|
||||||
[[[ARDVideoEncoderFactory alloc] init] supportedCodecs];
|
|
||||||
return supportedCodecs;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
- (RTCVideoCodecInfo *)currentVideoCodecSettingFromStore {
|
- (RTCVideoCodecInfo *)currentVideoCodecSettingFromStore {
|
||||||
|
|||||||
@ -1,16 +0,0 @@
|
|||||||
/*
|
|
||||||
* 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 <Foundation/Foundation.h>
|
|
||||||
#import "WebRTC/RTCVideoCodecFactory.h"
|
|
||||||
|
|
||||||
@interface ARDVideoDecoderFactory : NSObject<RTCVideoDecoderFactory>
|
|
||||||
|
|
||||||
@end
|
|
||||||
@ -1,18 +0,0 @@
|
|||||||
/*
|
|
||||||
* 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 <Foundation/Foundation.h>
|
|
||||||
#import "WebRTC/RTCVideoCodecFactory.h"
|
|
||||||
|
|
||||||
@interface ARDVideoEncoderFactory : NSObject<RTCVideoEncoderFactory>
|
|
||||||
|
|
||||||
@property(nonatomic, retain) RTCVideoCodecInfo* preferredCodec;
|
|
||||||
|
|
||||||
@end
|
|
||||||
@ -318,6 +318,8 @@ if (is_ios || is_mac) {
|
|||||||
|
|
||||||
rtc_static_library("peerconnectionfactory_objc") {
|
rtc_static_library("peerconnectionfactory_objc") {
|
||||||
sources = [
|
sources = [
|
||||||
|
"objc/Framework/Classes/PeerConnection/RTCDefaultVideoDecoderFactory.m",
|
||||||
|
"objc/Framework/Classes/PeerConnection/RTCDefaultVideoEncoderFactory.m",
|
||||||
"objc/Framework/Classes/PeerConnection/RTCPeerConnectionFactory+Native.h",
|
"objc/Framework/Classes/PeerConnection/RTCPeerConnectionFactory+Native.h",
|
||||||
"objc/Framework/Classes/PeerConnection/RTCPeerConnectionFactory+Private.h",
|
"objc/Framework/Classes/PeerConnection/RTCPeerConnectionFactory+Private.h",
|
||||||
"objc/Framework/Classes/PeerConnection/RTCPeerConnectionFactory.mm",
|
"objc/Framework/Classes/PeerConnection/RTCPeerConnectionFactory.mm",
|
||||||
|
|||||||
@ -8,20 +8,20 @@
|
|||||||
* be found in the AUTHORS file in the root of the source tree.
|
* be found in the AUTHORS file in the root of the source tree.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#import "ARDVideoDecoderFactory.h"
|
#import "WebRTC/RTCVideoCodecFactory.h"
|
||||||
|
|
||||||
#import "WebRTC/RTCVideoCodecH264.h"
|
#import "WebRTC/RTCVideoCodecH264.h"
|
||||||
#import "WebRTC/RTCVideoDecoderVP8.h"
|
#import "WebRTC/RTCVideoDecoderVP8.h"
|
||||||
#import "WebRTC/RTCVideoDecoderVP9.h"
|
#import "WebRTC/RTCVideoDecoderVP9.h"
|
||||||
|
|
||||||
@implementation ARDVideoDecoderFactory
|
@implementation RTCDefaultVideoDecoderFactory
|
||||||
|
|
||||||
- (id<RTCVideoDecoder>)createDecoder:(RTCVideoCodecInfo *)info {
|
- (id<RTCVideoDecoder>)createDecoder:(RTCVideoCodecInfo *)info {
|
||||||
if ([info.name isEqualToString:@"H264"]) {
|
if ([info.name isEqualToString:kRTCVideoCodecH264Name]) {
|
||||||
return [[RTCVideoDecoderH264 alloc] init];
|
return [[RTCVideoDecoderH264 alloc] init];
|
||||||
} else if ([info.name isEqualToString:@"VP8"]) {
|
} else if ([info.name isEqualToString:kRTCVideoCodecVp8Name]) {
|
||||||
return [RTCVideoDecoderVP8 vp8Decoder];
|
return [RTCVideoDecoderVP8 vp8Decoder];
|
||||||
} else if ([info.name isEqualToString:@"VP9"]) {
|
} else if ([info.name isEqualToString:kRTCVideoCodecVp9Name]) {
|
||||||
return [RTCVideoDecoderVP9 vp9Decoder];
|
return [RTCVideoDecoderVP9 vp9Decoder];
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -30,9 +30,9 @@
|
|||||||
|
|
||||||
- (NSArray<RTCVideoCodecInfo *> *)supportedCodecs {
|
- (NSArray<RTCVideoCodecInfo *> *)supportedCodecs {
|
||||||
return @[
|
return @[
|
||||||
[[RTCVideoCodecInfo alloc] initWithName:@"H264" parameters:nil],
|
[[RTCVideoCodecInfo alloc] initWithName:kRTCVideoCodecH264Name],
|
||||||
[[RTCVideoCodecInfo alloc] initWithName:@"VP8" parameters:nil],
|
[[RTCVideoCodecInfo alloc] initWithName:kRTCVideoCodecVp8Name],
|
||||||
[[RTCVideoCodecInfo alloc] initWithName:@"VP9" parameters:nil]
|
[[RTCVideoCodecInfo alloc] initWithName:kRTCVideoCodecVp9Name]
|
||||||
];
|
];
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -8,18 +8,43 @@
|
|||||||
* be found in the AUTHORS file in the root of the source tree.
|
* be found in the AUTHORS file in the root of the source tree.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#import "ARDVideoEncoderFactory.h"
|
#import "WebRTC/RTCVideoCodecFactory.h"
|
||||||
|
|
||||||
#import "ARDSettingsModel.h"
|
|
||||||
#import "WebRTC/RTCVideoCodec.h"
|
#import "WebRTC/RTCVideoCodec.h"
|
||||||
#import "WebRTC/RTCVideoCodecH264.h"
|
#import "WebRTC/RTCVideoCodecH264.h"
|
||||||
#import "WebRTC/RTCVideoEncoderVP8.h"
|
#import "WebRTC/RTCVideoEncoderVP8.h"
|
||||||
#import "WebRTC/RTCVideoEncoderVP9.h"
|
#import "WebRTC/RTCVideoEncoderVP9.h"
|
||||||
|
|
||||||
@implementation ARDVideoEncoderFactory
|
@implementation RTCDefaultVideoEncoderFactory
|
||||||
|
|
||||||
@synthesize preferredCodec;
|
@synthesize preferredCodec;
|
||||||
|
|
||||||
|
+ (NSArray<RTCVideoCodecInfo *> *)supportedCodecs {
|
||||||
|
NSDictionary<NSString *, NSString *> *constrainedHighParams = @{
|
||||||
|
@"profile-level-id" : kRTCLevel31ConstrainedHigh,
|
||||||
|
@"level-asymmetry-allowed" : @"1",
|
||||||
|
@"packetization-mode" : @"1",
|
||||||
|
};
|
||||||
|
RTCVideoCodecInfo *constrainedHighInfo =
|
||||||
|
[[RTCVideoCodecInfo alloc] initWithName:kRTCVideoCodecH264Name
|
||||||
|
parameters:constrainedHighParams];
|
||||||
|
|
||||||
|
NSDictionary<NSString *, NSString *> *constrainedBaselineParams = @{
|
||||||
|
@"profile-level-id" : kRTCLevel31ConstrainedBaseline,
|
||||||
|
@"level-asymmetry-allowed" : @"1",
|
||||||
|
@"packetization-mode" : @"1",
|
||||||
|
};
|
||||||
|
RTCVideoCodecInfo *constrainedBaselineInfo =
|
||||||
|
[[RTCVideoCodecInfo alloc] initWithName:kRTCVideoCodecH264Name
|
||||||
|
parameters:constrainedBaselineParams];
|
||||||
|
|
||||||
|
RTCVideoCodecInfo *vp8Info = [[RTCVideoCodecInfo alloc] initWithName:kRTCVideoCodecVp8Name];
|
||||||
|
|
||||||
|
RTCVideoCodecInfo *vp9Info = [[RTCVideoCodecInfo alloc] initWithName:kRTCVideoCodecVp9Name];
|
||||||
|
|
||||||
|
return @[ constrainedHighInfo, constrainedBaselineInfo, vp8Info, vp9Info ];
|
||||||
|
}
|
||||||
|
|
||||||
- (id<RTCVideoEncoder>)createEncoder:(RTCVideoCodecInfo *)info {
|
- (id<RTCVideoEncoder>)createEncoder:(RTCVideoCodecInfo *)info {
|
||||||
if ([info.name isEqualToString:kRTCVideoCodecH264Name]) {
|
if ([info.name isEqualToString:kRTCVideoCodecH264Name]) {
|
||||||
return [[RTCVideoEncoderH264 alloc] initWithCodecInfo:info];
|
return [[RTCVideoEncoderH264 alloc] initWithCodecInfo:info];
|
||||||
@ -33,35 +58,7 @@
|
|||||||
}
|
}
|
||||||
|
|
||||||
- (NSArray<RTCVideoCodecInfo *> *)supportedCodecs {
|
- (NSArray<RTCVideoCodecInfo *> *)supportedCodecs {
|
||||||
NSMutableArray<RTCVideoCodecInfo *> *codecs = [NSMutableArray array];
|
NSMutableArray<RTCVideoCodecInfo *> *codecs = [[[self class] supportedCodecs] mutableCopy];
|
||||||
|
|
||||||
NSDictionary<NSString *, NSString *> *constrainedHighParams = @{
|
|
||||||
@"profile-level-id" : kRTCLevel31ConstrainedHigh,
|
|
||||||
@"level-asymmetry-allowed" : @"1",
|
|
||||||
@"packetization-mode" : @"1",
|
|
||||||
};
|
|
||||||
RTCVideoCodecInfo *constrainedHighInfo =
|
|
||||||
[[RTCVideoCodecInfo alloc] initWithName:kRTCVideoCodecH264Name
|
|
||||||
parameters:constrainedHighParams];
|
|
||||||
[codecs addObject:constrainedHighInfo];
|
|
||||||
|
|
||||||
NSDictionary<NSString *, NSString *> *constrainedBaselineParams = @{
|
|
||||||
@"profile-level-id" : kRTCLevel31ConstrainedBaseline,
|
|
||||||
@"level-asymmetry-allowed" : @"1",
|
|
||||||
@"packetization-mode" : @"1",
|
|
||||||
};
|
|
||||||
RTCVideoCodecInfo *constrainedBaselineInfo =
|
|
||||||
[[RTCVideoCodecInfo alloc] initWithName:kRTCVideoCodecH264Name
|
|
||||||
parameters:constrainedBaselineParams];
|
|
||||||
[codecs addObject:constrainedBaselineInfo];
|
|
||||||
|
|
||||||
RTCVideoCodecInfo *vp8Info =
|
|
||||||
[[RTCVideoCodecInfo alloc] initWithName:kRTCVideoCodecVp8Name parameters:nil];
|
|
||||||
[codecs addObject:vp8Info];
|
|
||||||
|
|
||||||
RTCVideoCodecInfo *vp9Info =
|
|
||||||
[[RTCVideoCodecInfo alloc] initWithName:kRTCVideoCodecVp9Name parameters:nil];
|
|
||||||
[codecs addObject:vp9Info];
|
|
||||||
|
|
||||||
NSMutableArray<RTCVideoCodecInfo *> *orderedCodecs = [NSMutableArray array];
|
NSMutableArray<RTCVideoCodecInfo *> *orderedCodecs = [NSMutableArray array];
|
||||||
NSUInteger index = [codecs indexOfObject:self.preferredCodec];
|
NSUInteger index = [codecs indexOfObject:self.preferredCodec];
|
||||||
@ -33,4 +33,22 @@ RTC_EXPORT
|
|||||||
|
|
||||||
@end
|
@end
|
||||||
|
|
||||||
|
#pragma mark - Default factories
|
||||||
|
|
||||||
|
/** These codec factories include support for all codecs bundled with WebRTC. If using custom
|
||||||
|
* codecs, create custom implementations of RTCVideoEncoderFactory and RTCVideoDecoderFactory.
|
||||||
|
*/
|
||||||
|
RTC_EXPORT
|
||||||
|
@interface RTCDefaultVideoEncoderFactory : NSObject <RTCVideoEncoderFactory>
|
||||||
|
|
||||||
|
@property(nonatomic, retain) RTCVideoCodecInfo *preferredCodec;
|
||||||
|
|
||||||
|
+ (NSArray<RTCVideoCodecInfo *> *)supportedCodecs;
|
||||||
|
|
||||||
|
@end
|
||||||
|
|
||||||
|
RTC_EXPORT
|
||||||
|
@interface RTCDefaultVideoDecoderFactory : NSObject <RTCVideoDecoderFactory>
|
||||||
|
@end
|
||||||
|
|
||||||
NS_ASSUME_NONNULL_END
|
NS_ASSUME_NONNULL_END
|
||||||
|
|||||||
Reference in New Issue
Block a user