 Chromium Code Reviews
 Chromium Code Reviews Issue 1559753002:
  Move RTCAVFoundationCapturer to webrtc/api/objc.  (Closed) 
  Base URL: https://chromium.googlesource.com/external/webrtc.git@updateRTCVideoSource
    
  
    Issue 1559753002:
  Move RTCAVFoundationCapturer to webrtc/api/objc.  (Closed) 
  Base URL: https://chromium.googlesource.com/external/webrtc.git@updateRTCVideoSource| Index: webrtc/api/objc/avfoundationvideocapturer.mm | 
| diff --git a/talk/app/webrtc/objc/avfoundationvideocapturer.mm b/webrtc/api/objc/avfoundationvideocapturer.mm | 
| similarity index 81% | 
| copy from talk/app/webrtc/objc/avfoundationvideocapturer.mm | 
| copy to webrtc/api/objc/avfoundationvideocapturer.mm | 
| index 0f9dc6825e9135461a6d8d8c5ad713c00c2c01b3..bea42f28730af48736548115c955ae472417743f 100644 | 
| --- a/talk/app/webrtc/objc/avfoundationvideocapturer.mm | 
| +++ b/webrtc/api/objc/avfoundationvideocapturer.mm | 
| @@ -1,31 +1,14 @@ | 
| /* | 
| - * libjingle | 
| - * Copyright 2015 Google Inc. | 
| + * Copyright 2015 The WebRTC project authors. All Rights Reserved. | 
| * | 
| - * Redistribution and use in source and binary forms, with or without | 
| - * modification, are permitted provided that the following conditions are met: | 
| - * | 
| - * 1. Redistributions of source code must retain the above copyright notice, | 
| - * this list of conditions and the following disclaimer. | 
| - * 2. Redistributions in binary form must reproduce the above copyright notice, | 
| - * this list of conditions and the following disclaimer in the documentation | 
| - * and/or other materials provided with the distribution. | 
| - * 3. The name of the author may not be used to endorse or promote products | 
| - * derived from this software without specific prior written permission. | 
| - * | 
| - * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR IMPLIED | 
| - * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF | 
| - * MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO | 
| - * EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, | 
| - * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, | 
| - * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; | 
| - * OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, | 
| - * WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR | 
| - * OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF | 
| - * ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | 
| + * 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 "talk/app/webrtc/objc/avfoundationvideocapturer.h" | 
| +#include "avfoundationvideocapturer.h" | 
| 
tkchin_webrtc
2016/01/20 21:51:12
full path
 
hjon
2016/01/20 22:25:34
Done.
 | 
| #include "webrtc/base/bind.h" | 
| @@ -50,14 +33,14 @@ static cricket::VideoFormat const kDefaultFormat = | 
| @interface RTCAVFoundationVideoCapturerInternal : NSObject | 
| <AVCaptureVideoDataOutputSampleBufferDelegate> | 
| -@property(nonatomic, readonly) AVCaptureSession* captureSession; | 
| +@property(nonatomic, readonly) AVCaptureSession *captureSession; | 
| @property(nonatomic, readonly) BOOL isRunning; | 
| @property(nonatomic, assign) BOOL useBackCamera; // Defaults to NO. | 
| // We keep a pointer back to AVFoundationVideoCapturer to make callbacks on it | 
| // when we receive frames. This is safe because this object should be owned by | 
| // it. | 
| -- (instancetype)initWithCapturer:(webrtc::AVFoundationVideoCapturer*)capturer; | 
| +- (instancetype)initWithCapturer:(webrtc::AVFoundationVideoCapturer *)capturer; | 
| - (void)startCaptureAsync; | 
| - (void)stopCaptureAsync; | 
| @@ -65,11 +48,11 @@ static cricket::VideoFormat const kDefaultFormat = | 
| @implementation RTCAVFoundationVideoCapturerInternal { | 
| // Keep pointers to inputs for convenience. | 
| - AVCaptureDeviceInput* _frontDeviceInput; | 
| - AVCaptureDeviceInput* _backDeviceInput; | 
| - AVCaptureVideoDataOutput* _videoOutput; | 
| + AVCaptureDeviceInput *_frontDeviceInput; | 
| + AVCaptureDeviceInput *_backDeviceInput; | 
| + AVCaptureVideoDataOutput *_videoOutput; | 
| // The cricket::VideoCapturer that owns this class. Should never be NULL. | 
| - webrtc::AVFoundationVideoCapturer* _capturer; | 
| + webrtc::AVFoundationVideoCapturer *_capturer; | 
| BOOL _orientationHasChanged; | 
| } | 
| @@ -77,14 +60,14 @@ static cricket::VideoFormat const kDefaultFormat = | 
| @synthesize useBackCamera = _useBackCamera; | 
| @synthesize isRunning = _isRunning; | 
| -- (instancetype)initWithCapturer:(webrtc::AVFoundationVideoCapturer*)capturer { | 
| +- (instancetype)initWithCapturer:(webrtc::AVFoundationVideoCapturer *)capturer { | 
| NSParameterAssert(capturer); | 
| if (self = [super init]) { | 
| _capturer = capturer; | 
| if (![self setupCaptureSession]) { | 
| return nil; | 
| } | 
| - NSNotificationCenter* center = [NSNotificationCenter defaultCenter]; | 
| + NSNotificationCenter *center = [NSNotificationCenter defaultCenter]; | 
| [center addObserver:self | 
| selector:@selector(deviceOrientationDidChange:) | 
| name:UIDeviceOrientationDidChangeNotification | 
| @@ -92,7 +75,7 @@ static cricket::VideoFormat const kDefaultFormat = | 
| [center addObserverForName:AVCaptureSessionRuntimeErrorNotification | 
| object:nil | 
| queue:nil | 
| - usingBlock:^(NSNotification* notification) { | 
| + usingBlock:^(NSNotification *notification) { | 
| NSLog(@"Capture session error: %@", notification.userInfo); | 
| }]; | 
| } | 
| @@ -143,9 +126,9 @@ static cricket::VideoFormat const kDefaultFormat = | 
| #pragma mark AVCaptureVideoDataOutputSampleBufferDelegate | 
| -- (void)captureOutput:(AVCaptureOutput*)captureOutput | 
| +- (void)captureOutput:(AVCaptureOutput *)captureOutput | 
| didOutputSampleBuffer:(CMSampleBufferRef)sampleBuffer | 
| - fromConnection:(AVCaptureConnection*)connection { | 
| + fromConnection:(AVCaptureConnection *)connection { | 
| NSParameterAssert(captureOutput == _videoOutput); | 
| if (!_isRunning) { | 
| return; | 
| @@ -153,9 +136,9 @@ static cricket::VideoFormat const kDefaultFormat = | 
| _capturer->CaptureSampleBuffer(sampleBuffer); | 
| } | 
| -- (void)captureOutput:(AVCaptureOutput*)captureOutput | 
| +- (void)captureOutput:(AVCaptureOutput *)captureOutput | 
| didDropSampleBuffer:(CMSampleBufferRef)sampleBuffer | 
| - fromConnection:(AVCaptureConnection*)connection { | 
| + fromConnection:(AVCaptureConnection *)connection { | 
| NSLog(@"Dropped sample buffer."); | 
| } | 
| @@ -164,7 +147,7 @@ static cricket::VideoFormat const kDefaultFormat = | 
| - (BOOL)setupCaptureSession { | 
| _captureSession = [[AVCaptureSession alloc] init]; | 
| #if defined(__IPHONE_7_0) && __IPHONE_OS_VERSION_MAX_ALLOWED >= __IPHONE_7_0 | 
| - NSString* version = [[UIDevice currentDevice] systemVersion]; | 
| + NSString *version = [[UIDevice currentDevice] systemVersion]; | 
| if ([version integerValue] >= 7) { | 
| _captureSession.usesApplicationAudioSession = NO; | 
| } | 
| @@ -179,7 +162,7 @@ static cricket::VideoFormat const kDefaultFormat = | 
| // currently supported on iPhone / iPad. | 
| _videoOutput = [[AVCaptureVideoDataOutput alloc] init]; | 
| _videoOutput.videoSettings = @{ | 
| - (NSString*)kCVPixelBufferPixelFormatTypeKey : | 
| + (NSString *)kCVPixelBufferPixelFormatTypeKey : | 
| @(kCVPixelFormatType_420YpCbCr8BiPlanarFullRange) | 
| }; | 
| _videoOutput.alwaysDiscardsLateVideoFrames = NO; | 
| @@ -192,9 +175,9 @@ static cricket::VideoFormat const kDefaultFormat = | 
| [_captureSession addOutput:_videoOutput]; | 
| // Find the capture devices. | 
| - AVCaptureDevice* frontCaptureDevice = nil; | 
| - AVCaptureDevice* backCaptureDevice = nil; | 
| - for (AVCaptureDevice* captureDevice in | 
| + AVCaptureDevice *frontCaptureDevice = nil; | 
| + AVCaptureDevice *backCaptureDevice = nil; | 
| + for (AVCaptureDevice *captureDevice in | 
| [AVCaptureDevice devicesWithMediaType:AVMediaTypeVideo]) { | 
| if (captureDevice.position == AVCaptureDevicePositionBack) { | 
| backCaptureDevice = captureDevice; | 
| @@ -209,7 +192,7 @@ static cricket::VideoFormat const kDefaultFormat = | 
| } | 
| // Set up the session inputs. | 
| - NSError* error = nil; | 
| + NSError *error = nil; | 
| _frontDeviceInput = | 
| [AVCaptureDeviceInput deviceInputWithDevice:frontCaptureDevice | 
| error:&error]; | 
| @@ -238,13 +221,13 @@ static cricket::VideoFormat const kDefaultFormat = | 
| return YES; | 
| } | 
| -- (void)deviceOrientationDidChange:(NSNotification*)notification { | 
| +- (void)deviceOrientationDidChange:(NSNotification *)notification { | 
| _orientationHasChanged = YES; | 
| [self updateOrientation]; | 
| } | 
| - (void)updateOrientation { | 
| - AVCaptureConnection* connection = | 
| + AVCaptureConnection *connection = | 
| [_videoOutput connectionWithMediaType:AVMediaTypeVideo]; | 
| if (!connection.supportsVideoOrientation) { | 
| // TODO(tkchin): set rotation bit on frames. | 
| @@ -278,8 +261,8 @@ static cricket::VideoFormat const kDefaultFormat = | 
| - (void)updateSessionInput { | 
| // Update the current session input to match what's stored in _useBackCamera. | 
| [_captureSession beginConfiguration]; | 
| - AVCaptureDeviceInput* oldInput = _backDeviceInput; | 
| - AVCaptureDeviceInput* newInput = _frontDeviceInput; | 
| + AVCaptureDeviceInput *oldInput = _backDeviceInput; | 
| + AVCaptureDeviceInput *newInput = _frontDeviceInput; | 
| if (_useBackCamera) { | 
| oldInput = _frontDeviceInput; | 
| newInput = _backDeviceInput; | 
| @@ -383,8 +366,8 @@ void AVFoundationVideoCapturer::CaptureSampleBuffer( | 
| static size_t const kYPlaneIndex = 0; | 
| static size_t const kUVPlaneIndex = 1; | 
| - uint8_t* yPlaneAddress = | 
| - (uint8_t*)CVPixelBufferGetBaseAddressOfPlane(imageBuffer, kYPlaneIndex); | 
| + uint8_t *yPlaneAddress = | 
| + (uint8_t *)CVPixelBufferGetBaseAddressOfPlane(imageBuffer, kYPlaneIndex); | 
| size_t yPlaneHeight = | 
| CVPixelBufferGetHeightOfPlane(imageBuffer, kYPlaneIndex); | 
| size_t yPlaneWidth = | 
| @@ -399,8 +382,8 @@ void AVFoundationVideoCapturer::CaptureSampleBuffer( | 
| yPlaneBytesPerRow * yPlaneHeight + uvPlaneBytesPerRow * uvPlaneHeight; | 
| // Sanity check assumption that planar bytes are contiguous. | 
| - uint8_t* uvPlaneAddress = | 
| - (uint8_t*)CVPixelBufferGetBaseAddressOfPlane(imageBuffer, kUVPlaneIndex); | 
| + uint8_t *uvPlaneAddress = | 
| + (uint8_t *)CVPixelBufferGetBaseAddressOfPlane(imageBuffer, kUVPlaneIndex); | 
| RTC_DCHECK( | 
| uvPlaneAddress == yPlaneAddress + yPlaneHeight * yPlaneBytesPerRow); | 
| @@ -427,7 +410,7 @@ void AVFoundationVideoCapturer::CaptureSampleBuffer( | 
| } | 
| void AVFoundationVideoCapturer::SignalFrameCapturedOnStartThread( | 
| - const cricket::CapturedFrame* frame) { | 
| + const cricket::CapturedFrame *frame) { | 
| RTC_DCHECK(_startThread->IsCurrent()); | 
| // This will call a superclass method that will perform the frame conversion | 
| // to I420. |