Index: talk/examples/objc/AppRTCDemo/ios/ARDVideoCallView.m |
diff --git a/talk/examples/objc/AppRTCDemo/ios/ARDVideoCallView.m b/talk/examples/objc/AppRTCDemo/ios/ARDVideoCallView.m |
deleted file mode 100644 |
index 47bfe8956f7e5307085fca3e37fb30b511882db6..0000000000000000000000000000000000000000 |
--- a/talk/examples/objc/AppRTCDemo/ios/ARDVideoCallView.m |
+++ /dev/null |
@@ -1,179 +0,0 @@ |
-/* |
- * libjingle |
- * Copyright 2015 Google Inc. |
- * |
- * 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. |
- */ |
- |
-#import "ARDVideoCallView.h" |
- |
-#import <AVFoundation/AVFoundation.h> |
-#import "UIImage+ARDUtilities.h" |
- |
-static CGFloat const kButtonPadding = 16; |
-static CGFloat const kButtonSize = 48; |
-static CGFloat const kLocalVideoViewSize = 120; |
-static CGFloat const kLocalVideoViewPadding = 8; |
- |
-@interface ARDVideoCallView () <RTCEAGLVideoViewDelegate> |
-@end |
- |
-@implementation ARDVideoCallView { |
- UIButton *_cameraSwitchButton; |
- UIButton *_hangupButton; |
- CGSize _localVideoSize; |
- CGSize _remoteVideoSize; |
- BOOL _useRearCamera; |
-} |
- |
-@synthesize statusLabel = _statusLabel; |
-@synthesize localVideoView = _localVideoView; |
-@synthesize remoteVideoView = _remoteVideoView; |
-@synthesize delegate = _delegate; |
- |
-- (instancetype)initWithFrame:(CGRect)frame { |
- if (self = [super initWithFrame:frame]) { |
- _remoteVideoView = [[RTCEAGLVideoView alloc] initWithFrame:CGRectZero]; |
- _remoteVideoView.delegate = self; |
- [self addSubview:_remoteVideoView]; |
- |
- // TODO(tkchin): replace this with a view that renders layer from |
- // AVCaptureSession. |
- _localVideoView = [[RTCEAGLVideoView alloc] initWithFrame:CGRectZero]; |
- _localVideoView.delegate = self; |
- [self addSubview:_localVideoView]; |
- |
- // TODO(tkchin): don't display this if we can't actually do camera switch. |
- _cameraSwitchButton = [UIButton buttonWithType:UIButtonTypeCustom]; |
- _cameraSwitchButton.backgroundColor = [UIColor whiteColor]; |
- _cameraSwitchButton.layer.cornerRadius = kButtonSize / 2; |
- _cameraSwitchButton.layer.masksToBounds = YES; |
- UIImage *image = [UIImage imageNamed:@"ic_switch_video_black_24dp.png"]; |
- [_cameraSwitchButton setImage:image forState:UIControlStateNormal]; |
- [_cameraSwitchButton addTarget:self |
- action:@selector(onCameraSwitch:) |
- forControlEvents:UIControlEventTouchUpInside]; |
- [self addSubview:_cameraSwitchButton]; |
- |
- _hangupButton = [UIButton buttonWithType:UIButtonTypeCustom]; |
- _hangupButton.backgroundColor = [UIColor redColor]; |
- _hangupButton.layer.cornerRadius = kButtonSize / 2; |
- _hangupButton.layer.masksToBounds = YES; |
- image = [UIImage imageForName:@"ic_call_end_black_24dp.png" |
- color:[UIColor whiteColor]]; |
- [_hangupButton setImage:image forState:UIControlStateNormal]; |
- [_hangupButton addTarget:self |
- action:@selector(onHangup:) |
- forControlEvents:UIControlEventTouchUpInside]; |
- [self addSubview:_hangupButton]; |
- |
- _statusLabel = [[UILabel alloc] initWithFrame:CGRectZero]; |
- _statusLabel.font = [UIFont fontWithName:@"Roboto" size:16]; |
- _statusLabel.textColor = [UIColor whiteColor]; |
- [self addSubview:_statusLabel]; |
- } |
- return self; |
-} |
- |
-- (void)layoutSubviews { |
- CGRect bounds = self.bounds; |
- if (_remoteVideoSize.width > 0 && _remoteVideoSize.height > 0) { |
- // Aspect fill remote video into bounds. |
- CGRect remoteVideoFrame = |
- AVMakeRectWithAspectRatioInsideRect(_remoteVideoSize, bounds); |
- CGFloat scale = 1; |
- if (remoteVideoFrame.size.width > remoteVideoFrame.size.height) { |
- // Scale by height. |
- scale = bounds.size.height / remoteVideoFrame.size.height; |
- } else { |
- // Scale by width. |
- scale = bounds.size.width / remoteVideoFrame.size.width; |
- } |
- remoteVideoFrame.size.height *= scale; |
- remoteVideoFrame.size.width *= scale; |
- _remoteVideoView.frame = remoteVideoFrame; |
- _remoteVideoView.center = |
- CGPointMake(CGRectGetMidX(bounds), CGRectGetMidY(bounds)); |
- } else { |
- _remoteVideoView.frame = bounds; |
- } |
- |
- if (_localVideoSize.width && _localVideoSize.height > 0) { |
- // Aspect fit local video view into a square box. |
- CGRect localVideoFrame = |
- CGRectMake(0, 0, kLocalVideoViewSize, kLocalVideoViewSize); |
- localVideoFrame = |
- AVMakeRectWithAspectRatioInsideRect(_localVideoSize, localVideoFrame); |
- |
- // Place the view in the bottom right. |
- localVideoFrame.origin.x = CGRectGetMaxX(bounds) |
- - localVideoFrame.size.width - kLocalVideoViewPadding; |
- localVideoFrame.origin.y = CGRectGetMaxY(bounds) |
- - localVideoFrame.size.height - kLocalVideoViewPadding; |
- _localVideoView.frame = localVideoFrame; |
- } else { |
- _localVideoView.frame = bounds; |
- } |
- |
- // Place hangup button in the bottom left. |
- _hangupButton.frame = |
- CGRectMake(CGRectGetMinX(bounds) + kButtonPadding, |
- CGRectGetMaxY(bounds) - kButtonPadding - |
- kButtonSize, |
- kButtonSize, |
- kButtonSize); |
- |
- // Place button to the right of hangup button. |
- CGRect cameraSwitchFrame = _hangupButton.frame; |
- cameraSwitchFrame.origin.x = |
- CGRectGetMaxX(cameraSwitchFrame) + kButtonPadding; |
- _cameraSwitchButton.frame = cameraSwitchFrame; |
- |
- [_statusLabel sizeToFit]; |
- _statusLabel.center = |
- CGPointMake(CGRectGetMidX(bounds), CGRectGetMidY(bounds)); |
-} |
- |
-#pragma mark - RTCEAGLVideoViewDelegate |
- |
-- (void)videoView:(RTCEAGLVideoView*)videoView didChangeVideoSize:(CGSize)size { |
- if (videoView == _localVideoView) { |
- _localVideoSize = size; |
- _localVideoView.hidden = CGSizeEqualToSize(CGSizeZero, _localVideoSize); |
- } else if (videoView == _remoteVideoView) { |
- _remoteVideoSize = size; |
- } |
- [self setNeedsLayout]; |
-} |
- |
-#pragma mark - Private |
- |
-- (void)onCameraSwitch:(id)sender { |
- [_delegate videoCallViewDidSwitchCamera:self]; |
-} |
- |
-- (void)onHangup:(id)sender { |
- [_delegate videoCallViewDidHangup:self]; |
-} |
- |
-@end |