Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(711)

Side by Side Diff: webrtc/examples/objc/AppRTCDemo/mac/APPRTCViewController.m

Issue 2050153003: Update Unit test for AppRTCMobile app (Closed) Base URL: https://chromium.googlesource.com/external/webrtc.git@master
Patch Set: Rebase to current master Created 4 years, 5 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
OLDNEW
1 /* 1 /*
2 * Copyright 2014 The WebRTC Project Authors. All rights reserved. 2 * Copyright 2014 The WebRTC Project Authors. All rights reserved.
3 * 3 *
4 * Use of this source code is governed by a BSD-style license 4 * Use of this source code is governed by a BSD-style license
5 * that can be found in the LICENSE file in the root of the source 5 * that can be found in the LICENSE file in the root of the source
6 * tree. An additional intellectual property rights grant can be found 6 * tree. An additional intellectual property rights grant can be found
7 * in the file PATENTS. All contributing project authors may 7 * in the file PATENTS. All contributing project authors may
8 * be found in the AUTHORS file in the root of the source tree. 8 * be found in the AUTHORS file in the root of the source tree.
9 */ 9 */
10 10
11 #import "APPRTCViewController.h" 11 #import "APPRTCViewController.h"
12 12
13 #import <AVFoundation/AVFoundation.h> 13 #import <AVFoundation/AVFoundation.h>
14 14
15 #import "WebRTC/RTCNSGLVideoView.h" 15 #import "WebRTC/RTCNSGLVideoView.h"
16 #import "WebRTC/RTCVideoTrack.h" 16 #import "WebRTC/RTCVideoTrack.h"
17 17
18 #import "ARDAppClient.h" 18 #import "ARDAppClient.h"
19 19
20 static NSUInteger const kContentWidth = 1280; 20 static NSUInteger const kContentWidth = 1080;
21 static NSUInteger const kContentHeight = 720; 21 static NSUInteger const kContentHeight = 520;
22 static NSUInteger const kRoomFieldWidth = 80; 22 static NSUInteger const kRoomFieldWidth = 80;
23 static NSUInteger const kLogViewHeight = 280; 23 static NSUInteger const kLogViewHeight = 180;
24 24
25 @class APPRTCMainView; 25 @class APPRTCMainView;
26 @protocol APPRTCMainViewDelegate 26 @protocol APPRTCMainViewDelegate
27 27
28 - (void)appRTCMainView:(APPRTCMainView*)mainView 28 - (void)appRTCMainView:(APPRTCMainView*)mainView
29 didEnterRoomId:(NSString*)roomId; 29 didEnterRoomId:(NSString*)roomId;
30 30
31 @end 31 @end
32 32
33 @interface APPRTCMainView : NSView 33 @interface APPRTCMainView : NSView
(...skipping 25 matching lines...) Expand all
59 59
60 - (instancetype)initWithFrame:(NSRect)frame { 60 - (instancetype)initWithFrame:(NSRect)frame {
61 if (self = [super initWithFrame:frame]) { 61 if (self = [super initWithFrame:frame]) {
62 [self setupViews]; 62 [self setupViews];
63 } 63 }
64 return self; 64 return self;
65 } 65 }
66 66
67 - (void)updateConstraints { 67 - (void)updateConstraints {
68 NSParameterAssert( 68 NSParameterAssert(
69 _roomField != nil && _scrollView != nil && _remoteVideoView != nil); 69 _roomField != nil && _scrollView != nil && _remoteVideoView != nil
70 && _localVideoView != nil);
70 [self removeConstraints:[self constraints]]; 71 [self removeConstraints:[self constraints]];
71 NSDictionary* viewsDictionary = 72 NSDictionary* viewsDictionary =
72 NSDictionaryOfVariableBindings(_roomLabel, 73 NSDictionaryOfVariableBindings(_roomLabel,
73 _roomField, 74 _roomField,
74 _scrollView, 75 _scrollView,
76 _localVideoView,
75 _remoteVideoView); 77 _remoteVideoView);
76 78
77 NSSize remoteViewSize = [self remoteVideoViewSize]; 79 NSSize remoteViewSize = NSMakeSize(kContentWidth, kContentHeight);
80 NSSize localViewSize = NSMakeSize(200, 120);
78 NSDictionary* metrics = @{ 81 NSDictionary* metrics = @{
79 @"kLogViewHeight" : @(kLogViewHeight), 82 @"kLogViewHeight" : @(kLogViewHeight),
80 @"kRoomFieldWidth" : @(kRoomFieldWidth), 83 @"kRoomFieldWidth" : @(kRoomFieldWidth),
81 @"remoteViewWidth" : @(remoteViewSize.width), 84 @"remoteViewWidth" : @(remoteViewSize.width),
82 @"remoteViewHeight" : @(remoteViewSize.height), 85 @"remoteViewHeight" : @(remoteViewSize.height),
86 @"localViewWidth" : @(localViewSize.width),
87 @"localViewHeight" : @(localViewSize.height),
83 }; 88 };
84 // Declare this separately to avoid compiler warning about splitting string 89 // Declare this separately to avoid compiler warning about splitting string
85 // within an NSArray expression. 90 // within an NSArray expression.
86 NSString* verticalConstraint = 91 NSString* verticalConstraint =
87 @"V:|-[_roomLabel]-[_roomField]-[_scrollView(kLogViewHeight)]" 92 @"V:|-[_roomLabel]-[_roomField]-[_scrollView(kLogViewHeight)]"
88 "-[_remoteVideoView(remoteViewHeight)]-|"; 93 "-[_remoteVideoView(remoteViewHeight)]-|";
89 NSArray* constraintFormats = @[ 94 NSArray* constraintFormats = @[
90 verticalConstraint, 95 verticalConstraint,
96 @"V:|-(>=100)-[_localVideoView(localViewHeight)]-30-|",
91 @"|-[_roomLabel]", 97 @"|-[_roomLabel]",
92 @"|-[_roomField(kRoomFieldWidth)]", 98 @"|-[_roomField(kRoomFieldWidth)]",
93 @"|-[_scrollView(remoteViewWidth)]-|", 99 @"|-[_scrollView(remoteViewWidth)]-|",
94 @"|-[_remoteVideoView(remoteViewWidth)]-|", 100 @"|-[_remoteVideoView(remoteViewWidth)]-|",
101 @"|-30-[_localVideoView(localViewWidth)]-(>=100)-|",
95 ]; 102 ];
96 for (NSString* constraintFormat in constraintFormats) { 103 for (NSString* constraintFormat in constraintFormats) {
97 NSArray* constraints = 104 NSArray* constraints =
98 [NSLayoutConstraint constraintsWithVisualFormat:constraintFormat 105 [NSLayoutConstraint constraintsWithVisualFormat:constraintFormat
99 options:0 106 options:0
100 metrics:metrics 107 metrics:metrics
101 views:viewsDictionary]; 108 views:viewsDictionary];
102 for (NSLayoutConstraint* constraint in constraints) { 109 for (NSLayoutConstraint* constraint in constraints) {
103 [self addConstraint:constraint]; 110 [self addConstraint:constraint];
104 } 111 }
(...skipping 22 matching lines...) Expand all
127 134
128 - (void)videoView:(RTCNSGLVideoView*)videoView 135 - (void)videoView:(RTCNSGLVideoView*)videoView
129 didChangeVideoSize:(NSSize)size { 136 didChangeVideoSize:(NSSize)size {
130 if (videoView == _remoteVideoView) { 137 if (videoView == _remoteVideoView) {
131 _remoteVideoSize = size; 138 _remoteVideoSize = size;
132 } else if (videoView == _localVideoView) { 139 } else if (videoView == _localVideoView) {
133 _localVideoSize = size; 140 _localVideoSize = size;
134 } else { 141 } else {
135 return; 142 return;
136 } 143 }
137 [self setNeedsUpdateConstraints:YES]; 144 //[self setNeedsUpdateConstraints:YES];
138 } 145 }
139 146
140 #pragma mark - Private 147 #pragma mark - Private
141 148
142 - (void)setupViews { 149 - (void)setupViews {
143 NSParameterAssert([[self subviews] count] == 0); 150 NSParameterAssert([[self subviews] count] == 0);
144 151
145 _roomLabel = [[NSTextField alloc] initWithFrame:NSZeroRect]; 152 _roomLabel = [[NSTextField alloc] initWithFrame:NSZeroRect];
146 [_roomLabel setTranslatesAutoresizingMaskIntoConstraints:NO]; 153 [_roomLabel setTranslatesAutoresizingMaskIntoConstraints:NO];
147 [_roomLabel setBezeled:NO]; 154 [_roomLabel setBezeled:NO];
(...skipping 33 matching lines...) Expand 10 before | Expand all | Expand 10 after
181 0 188 0
182 }; 189 };
183 NSOpenGLPixelFormat* pixelFormat = 190 NSOpenGLPixelFormat* pixelFormat =
184 [[NSOpenGLPixelFormat alloc] initWithAttributes:attributes]; 191 [[NSOpenGLPixelFormat alloc] initWithAttributes:attributes];
185 _remoteVideoView = [[RTCNSGLVideoView alloc] initWithFrame:NSZeroRect 192 _remoteVideoView = [[RTCNSGLVideoView alloc] initWithFrame:NSZeroRect
186 pixelFormat:pixelFormat]; 193 pixelFormat:pixelFormat];
187 [_remoteVideoView setTranslatesAutoresizingMaskIntoConstraints:NO]; 194 [_remoteVideoView setTranslatesAutoresizingMaskIntoConstraints:NO];
188 _remoteVideoView.delegate = self; 195 _remoteVideoView.delegate = self;
189 [self addSubview:_remoteVideoView]; 196 [self addSubview:_remoteVideoView];
190 197
191 // TODO(tkchin): create local video view. 198 _localVideoView = [[RTCNSGLVideoView alloc] initWithFrame:NSZeroRect
192 // https://code.google.com/p/webrtc/issues/detail?id=3417. 199 pixelFormat:pixelFormat];
200 [_localVideoView setTranslatesAutoresizingMaskIntoConstraints:NO];
201 _localVideoView.delegate = self;
202 [self addSubview:_localVideoView];
193 } 203 }
194 204
195 - (NSSize)remoteVideoViewSize { 205 - (NSSize)remoteVideoViewSize {
196 if (_remoteVideoSize.width > 0 && _remoteVideoSize.height > 0) { 206 if (_remoteVideoSize.width > 0 && _remoteVideoSize.height > 0) {
197 return _remoteVideoSize; 207 return _remoteVideoSize;
198 } else { 208 } else {
199 return NSMakeSize(kContentWidth, kContentHeight); 209 return NSMakeSize(kContentWidth, kContentHeight);
200 } 210 }
201 } 211 }
202 212
203 - (NSSize)localVideoViewSize { 213 - (NSSize)localVideoViewSize {
204 return NSZeroSize; 214 if (_localVideoSize.width > 0 && _localVideoSize.height > 0) {
215 return _localVideoSize;
216 } else {
217 return NSMakeSize(200, 120);
218 }
205 } 219 }
206 220
207 @end 221 @end
208 222
209 @interface APPRTCViewController () 223 @interface APPRTCViewController ()
210 <ARDAppClientDelegate, APPRTCMainViewDelegate> 224 <ARDAppClientDelegate, APPRTCMainViewDelegate>
211 @property(nonatomic, readonly) APPRTCMainView* mainView; 225 @property(nonatomic, readonly) APPRTCMainView* mainView;
212 @end 226 @end
213 227
214 @implementation APPRTCViewController { 228 @implementation APPRTCViewController {
(...skipping 36 matching lines...) Expand 10 before | Expand all | Expand 10 after
251 } 265 }
252 } 266 }
253 267
254 - (void)appClient:(ARDAppClient *)client 268 - (void)appClient:(ARDAppClient *)client
255 didChangeConnectionState:(RTCIceConnectionState)state { 269 didChangeConnectionState:(RTCIceConnectionState)state {
256 } 270 }
257 271
258 - (void)appClient:(ARDAppClient *)client 272 - (void)appClient:(ARDAppClient *)client
259 didReceiveLocalVideoTrack:(RTCVideoTrack *)localVideoTrack { 273 didReceiveLocalVideoTrack:(RTCVideoTrack *)localVideoTrack {
260 _localVideoTrack = localVideoTrack; 274 _localVideoTrack = localVideoTrack;
275 [_localVideoTrack addRenderer:self.mainView.localVideoView];
261 } 276 }
262 277
263 - (void)appClient:(ARDAppClient *)client 278 - (void)appClient:(ARDAppClient *)client
264 didReceiveRemoteVideoTrack:(RTCVideoTrack *)remoteVideoTrack { 279 didReceiveRemoteVideoTrack:(RTCVideoTrack *)remoteVideoTrack {
265 _remoteVideoTrack = remoteVideoTrack; 280 _remoteVideoTrack = remoteVideoTrack;
266 [_remoteVideoTrack addRenderer:self.mainView.remoteVideoView]; 281 [_remoteVideoTrack addRenderer:self.mainView.remoteVideoView];
267 } 282 }
268 283
269 - (void)appClient:(ARDAppClient *)client 284 - (void)appClient:(ARDAppClient *)client
270 didError:(NSError *)error { 285 didError:(NSError *)error {
(...skipping 32 matching lines...) Expand 10 before | Expand all | Expand 10 after
303 _remoteVideoTrack = nil; 318 _remoteVideoTrack = nil;
304 [self.mainView.remoteVideoView renderFrame:nil]; 319 [self.mainView.remoteVideoView renderFrame:nil];
305 } 320 }
306 321
307 - (void)disconnect { 322 - (void)disconnect {
308 [self resetUI]; 323 [self resetUI];
309 [_client disconnect]; 324 [_client disconnect];
310 } 325 }
311 326
312 @end 327 @end
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698