Chromium Code Reviews| Index: webrtc/api/objc/RTCVideoTrack.mm |
| diff --git a/webrtc/api/objc/RTCVideoTrack.mm b/webrtc/api/objc/RTCVideoTrack.mm |
| new file mode 100644 |
| index 0000000000000000000000000000000000000000..cd44a897a6d3310d66c863a71fb4d5d749d8b621 |
| --- /dev/null |
| +++ b/webrtc/api/objc/RTCVideoTrack.mm |
| @@ -0,0 +1,101 @@ |
| +/* |
| + * Copyright 2015 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 "RTCVideoTrack.h" |
| + |
| +#import "webrtc/api/objc/RTCVideoTrack+Private.h" |
|
tkchin_webrtc
2016/01/20 22:12:00
alphabetical
hjon
2016/01/21 00:23:43
Done.
|
| +#import "webrtc/api/objc/RTCMediaSource+Private.h" |
| +#import "webrtc/api/objc/RTCMediaStreamTrack+Private.h" |
| +#import "webrtc/api/objc/RTCPeerConnectionFactory+Private.h" |
| +#import "webrtc/api/objc/RTCVideoRendererAdapter.h" |
| +#import "webrtc/api/objc/RTCVideoSource+Private.h" |
| +#import "webrtc/base/objc/NSString+StdString.h" |
| + |
| +@implementation RTCVideoTrack { |
| + NSMutableArray *_adapters; |
| +} |
| + |
| +@synthesize source = _source; |
| + |
| +- (instancetype)initWithFactory:(RTCPeerConnectionFactory *)factory |
| + source:(RTCVideoSource *)source |
| + trackId:(NSString *)trackId { |
| + NSParameterAssert(factory); |
| + NSParameterAssert(source); |
| + NSParameterAssert(trackId.length); |
| + std::string nativeID = [NSString stdStringForString:trackId]; |
| + rtc::scoped_refptr<webrtc::VideoTrackInterface> track = |
| + factory.nativeFactory->CreateVideoTrack(nativeID, |
| + source.nativeVideoSource); |
| + if (self = [super initWithTrack:track]) { |
| + _adapters = [NSMutableArray array]; |
| + _source = source; |
| + } |
| + return self; |
| +} |
| + |
| +- (instancetype)initWithTrack: |
|
tkchin_webrtc
2016/01/20 22:12:00
To avoid all these bits of nastiness of pointer co
hjon
2016/01/21 00:23:43
Acknowledged.
|
| + (rtc::scoped_refptr<webrtc::MediaStreamTrackInterface>)track { |
| + NSParameterAssert(track); |
| + if (self = [super initWithTrack:track]) { |
| + _adapters = [NSMutableArray array]; |
| + rtc::scoped_refptr<webrtc::VideoSourceInterface> source = |
| + self.nativeVideoTrack->GetSource(); |
| + if (source) { |
| + _source = [[RTCVideoSource alloc] initWithMediaSource:source.get()]; |
| + } |
| + } |
| + return self; |
| +} |
| + |
| +- (void)dealloc { |
| + for (RTCVideoRendererAdapter *adapter in _adapters) { |
| + self.nativeVideoTrack->RemoveRenderer(adapter.nativeVideoRenderer); |
| + } |
| +} |
| + |
| +- (void)addRenderer:(id<RTCVideoRenderer>)renderer { |
| + // Make sure we don't have this renderer yet. |
| + for (RTCVideoRendererAdapter *adapter in _adapters) { |
| + NSAssert(adapter.videoRenderer != renderer, |
| + @"|renderer| is already attached to this track"); |
| + } |
| + // Create a wrapper that provides a native pointer for us. |
| + RTCVideoRendererAdapter* adapter = |
| + [[RTCVideoRendererAdapter alloc] initWithVideoRenderer:renderer]; |
| + [_adapters addObject:adapter]; |
| + self.nativeVideoTrack->AddRenderer(adapter.nativeVideoRenderer); |
| +} |
| + |
| +- (void)removeRenderer:(id<RTCVideoRenderer>)renderer { |
| + RTCVideoRendererAdapter *adapter; |
| + __block NSUInteger indexToRemove = NSNotFound; |
| + [_adapters enumerateObjectsUsingBlock:^(RTCVideoRendererAdapter *adapter, |
| + NSUInteger idx, |
| + BOOL *stop) { |
| + if (adapter.videoRenderer == renderer) { |
| + indexToRemove = idx; |
| + *stop = YES; |
| + } |
| + }]; |
| + if (indexToRemove == NSNotFound) { |
| + return; |
| + } |
| + self.nativeVideoTrack->RemoveRenderer(adapter.nativeVideoRenderer); |
| + [_adapters removeObjectAtIndex:indexToRemove]; |
| +} |
| + |
| +#pragma mark - Private |
| + |
| +- (rtc::scoped_refptr<webrtc::VideoTrackInterface>)nativeVideoTrack { |
| + return static_cast<webrtc::VideoTrackInterface*>(self.nativeTrack.get()); |
|
tkchin_webrtc
2016/01/20 22:12:00
space *
hjon
2016/01/21 00:23:43
Done.
|
| +} |
| + |
| +@end |